1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-10 13:12:50 +01:00
invoiceninja/app/Http/Controllers/BaseController.php

236 lines
6.4 KiB
PHP
Raw Normal View History

2019-03-28 22:34:58 +01:00
<?php
2019-05-11 05:32:07 +02:00
/**
* Invoice Ninja (https://invoiceninja.com)
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://opensource.org/licenses/AAL
*/
2019-03-28 22:34:58 +01:00
namespace App\Http\Controllers;
use App\Transformers\ArraySerializer;
use App\Transformers\EntityTransformer;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Log;
use League\Fractal\Manager;
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
use League\Fractal\Resource\Collection;
use League\Fractal\Resource\Item;
use League\Fractal\Serializer\JsonApiSerializer;
/**
*
*/
2019-03-28 22:34:58 +01:00
class BaseController extends Controller
{
/**
* Passed from the parent when we need to force
* includes internally rather than externally via
* the REQUEST 'include' variable.
*
* @var array
*/
public $forced_includes;
/**
* Fractal manager
* @var object
*/
protected $manager;
2019-03-28 22:34:58 +01:00
public function __construct()
{
2019-03-28 22:34:58 +01:00
$this->manager = new Manager();
$this->forced_includes = [];
}
private function buildManager()
{
if(request()->input('include') !== null)
{
$request_include = explode(",", request()->input('include'));
$include = array_merge($this->forced_includes, $request_include);
$include = implode(",", $include);
}
else
{
if(count($this->forced_includes)>=1)
$include = implode(",", $this->forced_includes);
else
$include = '';
2019-03-28 22:34:58 +01:00
}
Log::error('forced includes = ' . print_r($this->forced_includes,1));
Log::error('includes = ' . $include);
$this->manager->parseIncludes($include);
2019-03-28 22:34:58 +01:00
$this->serializer = request()->input('serializer') ?: EntityTransformer::API_SERIALIZER_ARRAY;
if ($this->serializer === EntityTransformer::API_SERIALIZER_JSON)
{
2019-03-28 22:34:58 +01:00
$this->manager->setSerializer(new JsonApiSerializer());
} else
{
2019-03-28 22:34:58 +01:00
$this->manager->setSerializer(new ArraySerializer());
}
2019-03-28 22:34:58 +01:00
}
/**
* Catch all fallback route
* for non-existant route
*/
public function notFound()
{
return response()->json([
'message' => 'Nothing to see here!'], 404);
}
2019-03-28 22:34:58 +01:00
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();
2019-04-03 04:34:28 +02:00
$transformer = new $this->entity_transformer(Input::get('serializer'));
2019-03-28 22:34:58 +01:00
$includes = $transformer->getDefaultIncludes();
$includes = $this->getRequestIncludes($includes);
$query->with($includes);
2019-04-03 04:34:28 +02:00
$data = $this->createCollection($query, $transformer, $this->entity_type);
2019-03-28 22:34:58 +01:00
return $this->response($data);
}
2019-04-03 04:34:28 +02:00
protected function createCollection($query, $transformer, $entity_type)
2019-03-28 22:34:58 +01:00
{
$this->buildManager();
2019-03-28 22:34:58 +01:00
if ($this->serializer && $this->serializer != EntityTransformer::API_SERIALIZER_JSON) {
2019-04-03 04:34:28 +02:00
$entity_type = null;
2019-03-28 22:34:58 +01:00
}
if (is_a($query, "Illuminate\Database\Eloquent\Builder")) {
$limit = Input::get('per_page', 20);
$paginator = $query->paginate($limit);
$query = $paginator->getCollection();
2019-04-03 04:34:28 +02:00
$resource = new Collection($query, $transformer, $entity_type);
2019-03-28 22:34:58 +01:00
$resource->setPaginator(new IlluminatePaginatorAdapter($paginator));
} else {
2019-04-03 04:34:28 +02:00
$resource = new Collection($query, $transformer, $entity_type);
2019-03-28 22:34:58 +01:00
}
return $this->manager->createData($resource)->toArray();
}
protected function response($response)
{
$index = request()->input('index') ?: 'data';
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']);
}
}
$response = json_encode($response, JSON_PRETTY_PRINT);
$headers = self::getApiHeaders();
return response()->make($response, 200, $headers);
}
protected function itemResponse($item)
{
$this->buildManager();
2019-03-28 22:34:58 +01:00
2019-04-03 04:34:28 +02:00
$transformer = new $this->entity_transformer(Input::get('serializer'));
2019-03-28 22:34:58 +01:00
2019-04-03 04:34:28 +02:00
$data = $this->createItem($item, $transformer, $this->entity_type);
2019-03-28 22:34:58 +01:00
return $this->response($data);
}
2019-04-03 04:34:28 +02:00
protected function createItem($data, $transformer, $entity_type)
2019-03-28 22:34:58 +01:00
{
if ($this->serializer && $this->serializer != EntityTransformer::API_SERIALIZER_JSON) {
2019-04-03 04:34:28 +02:00
$entity_type = null;
2019-03-28 22:34:58 +01:00
}
2019-04-03 04:34:28 +02:00
$resource = new Item($data, $transformer, $entity_type);
2019-03-28 22:34:58 +01:00
return $this->manager->createData($resource)->toArray();
}
public static function getApiHeaders($count = 0)
{
return [
'Content-Type' => 'application/json',
//'Access-Control-Allow-Origin' => '*',
//'Access-Control-Allow-Methods' => 'GET',
//'Access-Control-Allow-Headers' => 'Origin, Content-Type, Accept, Authorization, X-Requested-With',
//'Access-Control-Allow-Credentials' => 'true',
'X-Total-Count' => $count,
'X-Muudeo-Version' => config('ninja.api_version'),
//'X-Rate-Limit-Limit' - The number of allowed requests in the current period
//'X-Rate-Limit-Remaining' - The number of remaining requests in the current period
//'X-Rate-Limit-Reset' - The number of seconds left in the current period,
];
}
protected function getRequestIncludes($data)
{
$included = request()->input('include');
$included = explode(',', $included);
foreach ($included as $include) {
if ($include == 'clients') {
$data[] = 'clients.contacts';
} elseif ($include == 'tracks') {
$data[] = 'tracks.comments';
$data[] = 'tracks.tags';
} elseif ($include) {
$data[] = $include;
}
}
return $data;
}
}