flightRepo = $flightRepo; $this->flightSvc = $flightSvc; } /** * Return all the flights, paginated * * @param Request $request * * @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection */ public function index(Request $request) { return $this->search($request); } /** * @param $id * * @return FlightResource */ public function get($id) { $flight = $this->flightRepo->find($id); $this->flightSvc->filterSubfleets(Auth::user(), $flight); return new FlightResource($flight); } /** * @param Request $request * * @return mixed */ public function search(Request $request) { $where = [ 'active' => true, 'visible' => true, ]; // Allow the option to bypass some of these restrictions for the searches if (!$request->filled('ignore_restrictions') || $request->get('ignore_restrictions') === '0' ) { if (setting('pilots.restrict_to_company')) { $where['airline_id'] = Auth::user()->airline_id; } if (setting('pilots.only_flights_from_current')) { $where['dpt_airport_id'] = Auth::user()->curr_airport_id; } } try { $this->flightRepo->resetCriteria(); $this->flightRepo->searchCriteria($request); $this->flightRepo->pushCriteria(new WhereCriteria($request, $where)); $this->flightRepo->pushCriteria(new RequestCriteria($request)); $flights = $this->flightRepo->paginate(); } catch (RepositoryException $e) { return response($e, 503); } // TODO: Remove any flights here that a user doesn't have permissions to foreach ($flights as $flight) { $this->flightSvc->filterSubfleets(Auth::user(), $flight); } return FlightResource::collection($flights); } /** * Get a flight's route * * @param $id * @param Request $request * * @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection */ public function route($id, Request $request) { $flight = $this->flightRepo->find($id); $route = $this->flightSvc->getRoute($flight); return NavdataResource::collection($route); } }