2017-07-20 02:49:41 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Contracts\Repository;
|
|
|
|
|
2018-01-05 04:49:50 +00:00
|
|
|
use Illuminate\Support\Collection;
|
2018-01-11 05:19:03 +00:00
|
|
|
use Illuminate\Contracts\Pagination\LengthAwarePaginator;
|
2018-01-05 04:49:50 +00:00
|
|
|
|
2017-07-20 02:49:41 +01:00
|
|
|
interface AllocationRepositoryInterface extends RepositoryInterface
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Set an array of allocation IDs to be assigned to a specific server.
|
|
|
|
*
|
2017-08-22 04:10:48 +01:00
|
|
|
* @param int|null $server
|
2019-09-06 05:32:57 +01:00
|
|
|
* @param array $ids
|
2017-07-20 02:49:41 +01:00
|
|
|
* @return int
|
|
|
|
*/
|
2018-01-05 04:49:50 +00:00
|
|
|
public function assignAllocationsToServer(int $server = null, array $ids): int;
|
2017-07-22 03:17:42 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return all of the allocations for a specific node.
|
|
|
|
*
|
2017-08-22 04:10:48 +01:00
|
|
|
* @param int $node
|
2018-01-05 04:49:50 +00:00
|
|
|
* @return \Illuminate\Support\Collection
|
2017-07-22 03:17:42 +01:00
|
|
|
*/
|
2018-01-05 04:49:50 +00:00
|
|
|
public function getAllocationsForNode(int $node): Collection;
|
2018-01-09 04:12:19 +00:00
|
|
|
|
2018-01-11 05:19:03 +00:00
|
|
|
/**
|
|
|
|
* Return all of the allocations for a node in a paginated format.
|
|
|
|
*
|
|
|
|
* @param int $node
|
|
|
|
* @param int $perPage
|
|
|
|
* @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
|
|
|
|
*/
|
|
|
|
public function getPaginatedAllocationsForNode(int $node, int $perPage = 100): LengthAwarePaginator;
|
|
|
|
|
2018-01-09 04:12:19 +00:00
|
|
|
/**
|
|
|
|
* Return all of the unique IPs that exist for a given node.
|
|
|
|
*
|
|
|
|
* @param int $node
|
|
|
|
* @return \Illuminate\Support\Collection
|
|
|
|
*/
|
|
|
|
public function getUniqueAllocationIpsForNode(int $node): Collection;
|
2018-01-21 22:02:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return all of the allocations that exist for a node that are not currently
|
|
|
|
* allocated.
|
|
|
|
*
|
|
|
|
* @param int $node
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getUnassignedAllocationIds(int $node): array;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get an array of all allocations that are currently assigned to a given server.
|
|
|
|
*
|
|
|
|
* @param int $server
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getAssignedAllocationIds(int $server): array;
|
2018-01-28 23:14:14 +00:00
|
|
|
|
|
|
|
/**
|
2018-05-13 15:50:56 +01:00
|
|
|
* Return a concatenated result set of node ips that already have at least one
|
2018-01-28 23:14:14 +00:00
|
|
|
* server assigned to that IP. This allows for filtering out sets for
|
|
|
|
* dedicated allocation IPs.
|
|
|
|
*
|
|
|
|
* If an array of nodes is passed the results will be limited to allocations
|
|
|
|
* in those nodes.
|
|
|
|
*
|
|
|
|
* @param array $nodes
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getDiscardableDedicatedAllocations(array $nodes = []): array;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a single allocation from those meeting the requirements.
|
|
|
|
*
|
|
|
|
* @param array $nodes
|
|
|
|
* @param array $ports
|
2019-09-06 05:32:57 +01:00
|
|
|
* @param bool $dedicated
|
2018-01-28 23:14:14 +00:00
|
|
|
* @return \Pterodactyl\Models\Allocation|null
|
2018-01-28 23:14:34 +00:00
|
|
|
*/
|
2018-01-28 23:14:14 +00:00
|
|
|
public function getRandomAllocation(array $nodes, array $ports, bool $dedicated = false);
|
2017-07-20 02:49:41 +01:00
|
|
|
}
|