'staff_1', 'requestData' => [ 'query' => [ 'validation' => DataValidator::alpha(), 'error' => ERRORS::INVALID_QUERY ], 'page' => [ 'validation' => DataValidator::numeric(), 'error' => ERRORS::INVALID_PAGE ] ] ]; } public function handler() { Response::respondSuccess([ 'tickets' => $this->getTicketList()->toArray(), 'pages' => $this->getTotalPages() ]); } private function getTicketList() { $query = $this->getSearchQuery(); return Ticket::find($query, [ Controller::request('query') . '%', '%' . Controller::request('query') . '%', Controller::request('query') . '%' ]); } private function getSearchQuery() { $page = Controller::request('page'); $query = " (title LIKE ? OR title LIKE ?) AND "; $query .= $this->getStaffDepartmentsQueryFilter(); $query .= "ORDER BY CASE WHEN (title LIKE ?) THEN 1 ELSE 2 END ASC LIMIT 10 OFFSET " . (($page-1)*10); return $query; } private function getTotalPages() { $query = " (title LIKE ? OR title LIKE ?) AND "; $query .= $this->getStaffDepartmentsQueryFilter(); $ticketQuantity = Ticket::count($query, [ Controller::request('query') . '%', '%' . Controller::request('query') . '%' ]); return ceil($ticketQuantity / 10); } private function getStaffDepartmentsQueryFilter() { $user = Controller::getLoggedUser(); $query = ' ('; foreach ($user->sharedDepartmentList as $department) { $query .= 'department_id=' . $department->id . ' OR '; } $query = substr($query, 0, -3); $query .= ') '; return $query; } }