query('per_page', '10'); if ($perPage < 1 || $perPage > 100) { throw new QueryValueOutOfRangeHttpException('per_page', 1, 100); } $allocations = QueryBuilder::for(Allocation::query()->where('node_id', '=', $node->id)) ->allowedFilters([ 'id', 'ip', 'port', 'alias', AllowedFilter::callback('server_id', function (Builder $query, $value) { if ($value === '0') { $query->whereNull('server_id'); } else { $query->where('server_id', '=', $value); } }), ]) ->allowedSorts(['id', 'ip', 'port', 'server_id']) ->paginate($perPage); return $this->fractal->collection($allocations) ->transformWith(AllocationTransformer::class) ->toArray(); } /** * Store new allocations for a given node. * * @throws \Pterodactyl\Exceptions\DisplayException * @throws \Pterodactyl\Exceptions\Service\Allocation\CidrOutOfRangeException * @throws \Pterodactyl\Exceptions\Service\Allocation\InvalidPortMappingException * @throws \Pterodactyl\Exceptions\Service\Allocation\PortOutOfRangeException * @throws \Pterodactyl\Exceptions\Service\Allocation\TooManyPortsInRangeException */ public function store(StoreAllocationRequest $request, Node $node): Response { $this->assignmentService->handle($node, $request->validated()); return $this->returnNoContent(); } /** * Delete a specific allocation from the Panel. * * @throws \Pterodactyl\Exceptions\Service\Allocation\ServerUsingAllocationException */ public function delete(DeleteAllocationRequest $request, Node $node, Allocation $allocation): Response { $this->deletionService->handle($allocation); return $this->returnNoContent(); } }