dba = $dba; $this->twitterStatus = $twitterStatus; } protected function rawContent(array $request = []) { $this->checkAllowedScope(BaseApi::SCOPE_READ); $uid = BaseApi::getCurrentUserID(); if (empty($request['list_id'])) { throw new HTTPException\BadRequestException('list_id not specified'); } // params $count = $this->getRequestValue($request, 'count', 20, 1, 100); $page = $this->getRequestValue($request, 'page', 1, 1); $since_id = $this->getRequestValue($request, 'since_id', 0, 0); $max_id = $this->getRequestValue($request, 'max_id', 0, 0); $exclude_replies = $this->getRequestValue($request, 'exclude_replies', false); $conversation_id = $this->getRequestValue($request, 'conversation_id', 0, 0); $include_entities = $this->getRequestValue($request, 'include_entities', false); $start = max(0, ($page - 1) * $count); $members = $this->dba->selectToArray('group_member', ['contact-id'], ['gid' => $request['list_id']]); $cids = array_column($members, 'contact-id'); $condition = ['uid' => $uid, 'gravity' => [Item::GRAVITY_PARENT, Item::GRAVITY_COMMENT], 'contact-id' => $cids]; $condition = DBA::mergeConditions($condition, ["`uri-id` > ?", $since_id]); if ($max_id > 0) { $condition[0] .= " AND `uri-id` <= ?"; $condition[] = $max_id; } if ($exclude_replies) { $condition[0] .= ' AND `gravity` = ?'; $condition[] = Item::GRAVITY_PARENT; } if ($conversation_id > 0) { $condition[0] .= " AND `parent-uri-id` = ?"; $condition[] = $conversation_id; } $params = ['order' => ['uri-id' => true], 'limit' => [$start, $count]]; $statuses = Post::selectForUser($uid, [], $condition, $params); $items = []; while ($status = $this->dba->fetch($statuses)) { $items[] = $this->twitterStatus->createFromUriId($status['uri-id'], $status['uid'], $include_entities)->toArray(); } $this->dba->close($statuses); $this->response->addFormattedContent('statuses', ['status' => $items], $this->parameters['extension'] ?? null, Contact::getPublicIdByUserId($uid)); } }