public function indexAction() { $limit = $this->request->getQuery('limit', 'int', 25); $limit = $limit > 100 ? 100 : $limit; $limit = $limit < 10 ? 10 : $limit; $orderMapping = array('id' => 'id ASC', '-id' => 'id DESC', 'created_at' => 'createdAt ASC', '-created_at' => 'createdAt DESC'); $order = $this->request->getQuery('order', 'string', '-created_at'); $query = array('q' => $this->request->getQuery('q', 'string'), 'status' => $this->request->getQuery('status', 'string'), 'uid' => $this->request->getQuery('uid', 'int'), 'cid' => $this->request->getQuery('cid', 'int'), 'username' => $this->request->getQuery('username', 'string'), 'order' => $order, 'limit' => $limit, 'page' => $this->request->getQuery('page', 'int', 1)); $form = new Forms\FilterForm(); $form->setValues($this->request->getQuery()); $this->view->setVar('form', $form); $commentManager = new Models\CommentManager(); $comments = $commentManager->findComments($query); $paginator = new \Eva\EvaEngine\Paginator(array("builder" => $comments, "limit" => $limit, "page" => $query['page'])); $paginator->setQuery($query); $pager = $paginator->getPaginate(); $this->view->setVar('pager', $pager); return $paginator; }
/** * * @SWG\Api( * path="/comments", * description="Comment related api", * produces="['application/json']", * @SWG\Operations( * @SWG\Operation( * method="GET", * summary="Get comment list", * notes="Returns comment list", * @SWG\Parameters( * @SWG\Parameter( * name="q", * description="Keyword", * paramType="query", * required=false, * type="string" * ), * @SWG\Parameter( * name="status", * description="Status, allow value : pending | published | deleted | draft", * paramType="query", * required=false, * type="string" * ), * @SWG\Parameter( * name="uid", * description="User ID", * paramType="query", * required=false, * type="integer" * ), * @SWG\Parameter( * name="order", * description="Order, allow value : +-id, +-created_at, +-sortOrder default is -created_at", * paramType="query", * required=false, * type="string" * ), * @SWG\Parameter( * name="limit", * description="Limit max:100 | min:3; default is 25", * paramType="query", * required=false, * type="integer" * ) * ) * ) * ) * ) */ public function indexAction() { $limit = $this->request->getQuery('limit', 'int', 25); $limit = $limit > 100 ? 100 : $limit; $limit = $limit < 3 ? 3 : $limit; $order = $this->request->getQuery('order', 'string', '-created_at'); $query = array('q' => $this->request->getQuery('q', 'string'), 'status' => $this->request->getQuery('status', 'string'), 'uid' => $this->request->getQuery('uid', 'int'), 'username' => $this->request->getQuery('username', 'string'), 'order' => $order, 'limit' => $limit, 'page' => $this->request->getQuery('page', 'int', 1)); $form = new Forms\FilterForm(); $form->setValues($this->request->getQuery()); $commentManger = new Models\CommentManager(); $comments = $commentManger->findComments($query); $paginator = new \Eva\EvaEngine\Paginator(array("builder" => $comments, "limit" => $limit, "page" => $query['page'])); $paginator->setQuery($query); $pager = $paginator->getPaginate(); $commentArray = array(); if ($pager->items) { foreach ($pager->items as $key => $comment) { $commentArray[] = $comment->dump(array('id', 'threadId', 'title', 'codeType', 'content', 'status', 'createdAt')); } } $data = array('paginator' => $this->getApiPaginator($paginator), 'results' => $commentArray); return $this->response->setJsonContent($data); }