3 namespace BookStack\Http\Controllers\Api;
5 use BookStack\Api\ListingResponseBuilder;
6 use BookStack\Http\Controllers\Controller;
7 use Illuminate\Database\Eloquent\Builder;
8 use Illuminate\Http\JsonResponse;
10 abstract class ApiController extends Controller
12 protected $rules = [];
13 protected $fieldsToExpose = [];
16 * Provide a paginated listing JSON response in a standard format
17 * taking into account any pagination parameters passed by the user.
19 protected function apiListingResponse(Builder $query, array $fields, array $modifiers = []): JsonResponse
21 $listing = new ListingResponseBuilder($query, request(), $fields);
23 foreach ($modifiers as $modifier) {
24 $listing->modifyResults($modifier);
27 return $listing->toResponse();
31 * Get the validation rules for this controller.
32 * Defaults to a $rules property but can be a rules() method.
34 public function getValdationRules(): array
36 if (method_exists($this, 'rules')) {
37 return $this->rules();