manager = new Manager(); $this->forced_includes = []; $this->forced_index = 'data'; } private function buildManager() { $include = ''; if (request()->has('first_load') && request()->input('first_load') == 'true') { $include = implode(",", array_merge($this->forced_includes, $this->getRequestIncludes([]))); } elseif (request()->input('include') !== null) { $include = array_merge($this->forced_includes, explode(",", request()->input('include'))); $include = implode(",", $include); } elseif (count($this->forced_includes) >= 1) { $include = implode(",", $this->forced_includes); } $this->manager->parseIncludes($include); $this->serializer = request()->input('serializer') ?: EntityTransformer::API_SERIALIZER_ARRAY; if ($this->serializer === EntityTransformer::API_SERIALIZER_JSON) { $this->manager->setSerializer(new JsonApiSerializer()); } else { $this->manager->setSerializer(new ArraySerializer()); } } /** * Catch all fallback route * for non-existant route */ public function notFound() { return response()->json(['message' => '404 | Nothing to see here!'], 404) ->header('X-API-VERSION', config('ninja.api_version')) ->header('X-APP-VERSION', config('ninja.app_version')); } public function notFoundClient() { return abort(404); } protected function errorResponse($response, $httpErrorCode = 400) { $error['error'] = $response; $error = json_encode($error, JSON_PRETTY_PRINT); $headers = self::getApiHeaders(); return response()->make($error, $httpErrorCode, $headers); } protected function listResponse($query) { $this->buildManager(); $transformer = new $this->entity_transformer(Input::get('serializer')); $includes = $transformer->getDefaultIncludes(); $includes = $this->getRequestIncludes($includes); $query->with($includes); if (auth()->user()->cannot('view_'.$this->entity_type)) { if ($this->entity_type == Company::class || $this->entity_type == Design::class) { //no user keys exist on the company table, so we need to skip } elseif ($this->entity_type == User::class) { //$query->where('id', '=', auth()->user()->id); @todo why? } else { $query->where('user_id', '=', auth()->user()->id); } } if (request()->has('updated_at') && request()->input('updated_at') > 0) { $updated_at = intval(request()->input('updated_at')); $query->where('updated_at', '>=', date('Y-m-d H:i:s', $updated_at)); } $data = $this->createCollection($query, $transformer, $this->entity_type); return $this->response($data); } protected function createCollection($query, $transformer, $entity_type) { $this->buildManager(); if ($this->serializer && $this->serializer != EntityTransformer::API_SERIALIZER_JSON) { $entity_type = null; } if (is_a($query, "Illuminate\Database\Eloquent\Builder")) { $limit = Input::get('per_page', 20); $paginator = $query->paginate($limit); $query = $paginator->getCollection(); $resource = new Collection($query, $transformer, $entity_type); $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); } else { $resource = new Collection($query, $transformer, $entity_type); } return $this->manager->createData($resource)->toArray(); } protected function response($response) { $index = request()->input('index') ?: $this->forced_index; if ($index == 'none') { unset($response['meta']); } else { $meta = isset($response['meta']) ? $response['meta'] : null; $response = [ $index => $response, ]; if ($meta) { $response['meta'] = $meta; unset($response[$index]['meta']); } if (request()->include_static) { $response['static'] = Statics::company(auth()->user()->getCompany()->getLocale()); } } ksort($response); $response = json_encode($response, JSON_PRETTY_PRINT); $headers = self::getApiHeaders(); return response()->make($response, 200, $headers); } protected function itemResponse($item) { $this->buildManager(); $transformer = new $this->entity_transformer(Input::get('serializer')); $data = $this->createItem($item, $transformer, $this->entity_type); if (request()->include_static) { $data['static'] = Statics::company(auth()->user()->getCompany()->getLocale()); } return $this->response($data); } protected function createItem($data, $transformer, $entity_type) { if ($this->serializer && $this->serializer != EntityTransformer::API_SERIALIZER_JSON) { $entity_type = null; } $resource = new Item($data, $transformer, $entity_type); return $this->manager->createData($resource)->toArray(); } public static function getApiHeaders($count = 0) { return [ 'Content-Type' => 'application/json', 'X-Api-Version' => config('ninja.api_version'), 'X-App-Version' => config('ninja.app_version'), ]; } protected function getRequestIncludes($data) { $first_load = [ 'account', 'user.company_user', 'token', 'company.activities', 'company.users.company_user', 'company.tax_rates', 'company.groups', 'company.company_gateways.gateway', 'company.clients.contacts', 'company.products', 'company.invoices', 'company.payments.paymentables', 'company.quotes', 'company.credits', 'company.vendors.contacts', 'company.expenses', 'company.tasks', 'company.projects', 'company.designs', ]; $mini_load = [ 'account', 'user.company_user', 'token', 'company.activities', 'company.users.company_user', 'company.tax_rates', 'company.groups', ]; /** * Thresholds for displaying large account on first load */ if (request()->has('first_load') && request()->input('first_load') == 'true') { if (auth()->user()->getCompany()->invoices->count() > 1000) { $data = $mini_load; } else { $data = $first_load; } } else { $included = request()->input('include'); $included = explode(',', $included); foreach ($included as $include) { if ($include == 'clients') { $data[] = 'clients.contacts'; } elseif ($include) { $data[] = $include; } } } return $data; } public function flutterRoute() { if ((bool)$this->checkAppSetup() !== false) { $data = []; if (Ninja::isSelfHost()) { $account = Account::all()->first(); $data['report_errors'] = $account->report_errors; } else { $data['report_errors'] = true; } return view('index.index', $data); } return redirect('/setup'); } }