misc_pterodactyl-panel/app/Repositories/Eloquent/MountRepository.php

58 lines
1.7 KiB
PHP
Raw Permalink Normal View History

<?php
namespace Pterodactyl\Repositories\Eloquent;
use Pterodactyl\Models\Mount;
2020-05-21 19:19:59 +00:00
use Pterodactyl\Models\Server;
2020-05-21 19:22:32 +00:00
use Illuminate\Support\Collection;
use Illuminate\Database\Eloquent\ModelNotFoundException;
use Pterodactyl\Exceptions\Repository\RecordNotFoundException;
class MountRepository extends EloquentRepository
{
/**
* Return the model backing this repository.
*/
public function model(): string
{
return Mount::class;
}
/**
* Return mounts with a count of eggs, nodes, and servers attached to it.
*/
public function getAllWithDetails(): Collection
{
return $this->getBuilder()->withCount('eggs', 'nodes')->get($this->getColumns());
}
/**
* Return all the mounts and their respective relations.
*
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
*/
public function getWithRelations(string $id): Mount
{
try {
return $this->getBuilder()->with('eggs', 'nodes')->findOrFail($id, $this->getColumns());
} catch (ModelNotFoundException $exception) {
2021-01-23 20:33:34 +00:00
throw new RecordNotFoundException();
}
}
2020-05-21 19:19:59 +00:00
/**
2020-05-21 20:27:23 +00:00
* Return mounts available to a server (ignoring if they are or are not mounted).
2020-05-21 19:19:59 +00:00
*/
public function getMountListForServer(Server $server): Collection
{
return $this->getBuilder()
->whereHas('eggs', function ($q) use ($server) {
$q->where('id', '=', $server->egg_id);
})
->whereHas('nodes', function ($q) use ($server) {
$q->where('id', '=', $server->node_id);
})
->get($this->getColumns());
}
}