84 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Pterodactyl\Contracts\Repository;
 | |
| 
 | |
| use Illuminate\Support\Collection;
 | |
| use Illuminate\Contracts\Pagination\LengthAwarePaginator;
 | |
| 
 | |
| interface AllocationRepositoryInterface extends RepositoryInterface
 | |
| {
 | |
|     /**
 | |
|      * Set an array of allocation IDs to be assigned to a specific server.
 | |
|      *
 | |
|      * @param int|null $server
 | |
|      * @param array $ids
 | |
|      * @return int
 | |
|      */
 | |
|     public function assignAllocationsToServer(int $server = null, array $ids): int;
 | |
| 
 | |
|     /**
 | |
|      * Return all of the allocations for a specific node.
 | |
|      *
 | |
|      * @param int $node
 | |
|      * @return \Illuminate\Support\Collection
 | |
|      */
 | |
|     public function getAllocationsForNode(int $node): Collection;
 | |
| 
 | |
|     /**
 | |
|      * 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;
 | |
| 
 | |
|     /**
 | |
|      * 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;
 | |
| 
 | |
|     /**
 | |
|      * 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;
 | |
| 
 | |
|     /**
 | |
|      * Return a concatenated result set of node ips that already have at least one
 | |
|      * 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
 | |
|      * @param bool $dedicated
 | |
|      * @return \Pterodactyl\Models\Allocation|null
 | |
|      */
 | |
|     public function getRandomAllocation(array $nodes, array $ports, bool $dedicated = false);
 | |
| }
 | 
