2021-06-26 15:23:15 +00:00
|
|
|
<?php
|
|
|
|
|
2023-05-18 20:53:39 +01:00
|
|
|
namespace BookStack\Http;
|
2019-12-28 14:58:07 +00:00
|
|
|
|
|
|
|
use BookStack\Api\ListingResponseBuilder;
|
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
|
|
use Illuminate\Http\JsonResponse;
|
|
|
|
|
2020-11-22 14:56:19 +00:00
|
|
|
abstract class ApiController extends Controller
|
2019-12-28 14:58:07 +00:00
|
|
|
{
|
2020-01-12 14:45:54 +00:00
|
|
|
protected $rules = [];
|
|
|
|
|
2019-12-28 14:58:07 +00:00
|
|
|
/**
|
|
|
|
* Provide a paginated listing JSON response in a standard format
|
|
|
|
* taking into account any pagination parameters passed by the user.
|
|
|
|
*/
|
2022-02-03 12:33:26 +00:00
|
|
|
protected function apiListingResponse(Builder $query, array $fields, array $modifiers = []): JsonResponse
|
2019-12-28 14:58:07 +00:00
|
|
|
{
|
2022-02-03 12:33:26 +00:00
|
|
|
$listing = new ListingResponseBuilder($query, request(), $fields);
|
|
|
|
|
|
|
|
foreach ($modifiers as $modifier) {
|
|
|
|
$listing->modifyResults($modifier);
|
|
|
|
}
|
2021-06-26 15:23:15 +00:00
|
|
|
|
2019-12-28 14:58:07 +00:00
|
|
|
return $listing->toResponse();
|
|
|
|
}
|
2020-01-12 14:45:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the validation rules for this controller.
|
2021-11-14 22:03:22 +00:00
|
|
|
* Defaults to a $rules property but can be a rules() method.
|
2020-01-12 14:45:54 +00:00
|
|
|
*/
|
2022-02-03 16:52:28 +00:00
|
|
|
public function getValidationRules(): array
|
2020-01-12 14:45:54 +00:00
|
|
|
{
|
2023-02-18 18:36:34 +00:00
|
|
|
return $this->rules();
|
|
|
|
}
|
2021-11-14 22:03:22 +00:00
|
|
|
|
2023-02-18 18:36:34 +00:00
|
|
|
/**
|
|
|
|
* Get the validation rules for the actions in this controller.
|
|
|
|
* Defaults to a $rules property but can be a rules() method.
|
|
|
|
*/
|
|
|
|
protected function rules(): array
|
|
|
|
{
|
2020-01-12 14:45:54 +00:00
|
|
|
return $this->rules;
|
|
|
|
}
|
2021-03-07 22:24:05 +00:00
|
|
|
}
|