3 namespace BookStack\Http;
5 use BookStack\Api\ListingResponseBuilder;
6 use Illuminate\Database\Eloquent\Builder;
7 use Illuminate\Http\JsonResponse;
9 abstract class ApiController extends Controller
11 protected $rules = [];
14 * Provide a paginated listing JSON response in a standard format
15 * taking into account any pagination parameters passed by the user.
17 protected function apiListingResponse(Builder $query, array $fields, array $modifiers = []): JsonResponse
19 $listing = new ListingResponseBuilder($query, request(), $fields);
21 foreach ($modifiers as $modifier) {
22 $listing->modifyResults($modifier);
25 return $listing->toResponse();
29 * Get the validation rules for this controller.
30 * Defaults to a $rules property but can be a rules() method.
32 public function getValidationRules(): array
34 return $this->rules();
38 * Get the validation rules for the actions in this controller.
39 * Defaults to a $rules property but can be a rules() method.
41 protected function rules(): array