2017-07-20 01:49:41 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Repositories\Eloquent;
|
|
|
|
|
2018-01-05 04:49:50 +00:00
|
|
|
use Illuminate\Support\Collection;
|
2017-07-20 01:49:41 +00:00
|
|
|
use Pterodactyl\Models\Allocation;
|
|
|
|
use Pterodactyl\Contracts\Repository\AllocationRepositoryInterface;
|
|
|
|
|
|
|
|
class AllocationRepository extends EloquentRepository implements AllocationRepositoryInterface
|
|
|
|
{
|
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* Return the model backing this repository.
|
|
|
|
*
|
|
|
|
* @return string
|
2017-07-20 01:49:41 +00:00
|
|
|
*/
|
|
|
|
public function model()
|
|
|
|
{
|
|
|
|
return Allocation::class;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* Set an array of allocation IDs to be assigned to a specific server.
|
|
|
|
*
|
|
|
|
* @param int|null $server
|
|
|
|
* @param array $ids
|
|
|
|
* @return int
|
2017-07-20 01:49:41 +00:00
|
|
|
*/
|
2018-01-05 04:49:50 +00:00
|
|
|
public function assignAllocationsToServer(int $server = null, array $ids): int
|
2017-07-20 01:49:41 +00:00
|
|
|
{
|
|
|
|
return $this->getBuilder()->whereIn('id', $ids)->update(['server_id' => $server]);
|
|
|
|
}
|
2017-07-22 02:17:42 +00:00
|
|
|
|
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* Return all of the allocations for a specific node.
|
|
|
|
*
|
|
|
|
* @param int $node
|
|
|
|
* @return \Illuminate\Support\Collection
|
2017-07-22 02:17:42 +00:00
|
|
|
*/
|
2018-01-05 04:49:50 +00:00
|
|
|
public function getAllocationsForNode(int $node): Collection
|
2017-07-22 02:17:42 +00:00
|
|
|
{
|
2018-01-05 04:49:50 +00:00
|
|
|
return $this->getBuilder()->where('node_id', $node)->get($this->getColumns());
|
2017-07-22 02:17:42 +00:00
|
|
|
}
|
2017-07-20 01:49:41 +00:00
|
|
|
}
|