<?php namespace Pterodactyl\Repositories\Eloquent; use Pterodactyl\Models\Mount; use Pterodactyl\Models\Server; use Illuminate\Support\Collection; use Illuminate\Database\Eloquent\ModelNotFoundException; use Pterodactyl\Exceptions\Repository\RecordNotFoundException; class MountRepository extends EloquentRepository { /** * Return the model backing this repository. * * @return string */ public function model() { return Mount::class; } /** * Return mounts with a count of eggs, nodes, and servers attached to it. * * @return \Illuminate\Support\Collection */ public function getAllWithDetails(): Collection { return $this->getBuilder()->withCount('eggs', 'nodes')->get($this->getColumns()); } /** * Return all of the mounts and their respective relations. * * @param string $id * @return mixed * * @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) { throw new RecordNotFoundException; } } /** * Return mounts available to a server (ignoring if they are or are not mounted). * * @param Server $server * @return \Illuminate\Support\Collection */ 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()); } }