<?php namespace Pterodactyl\Contracts\Repository; use Pterodactyl\Models\Subuser; interface SubuserRepositoryInterface extends RepositoryInterface { /** * Return a subuser with the associated server relationship. * * @param \Pterodactyl\Models\Subuser $subuser * @param bool $refresh * @return \Pterodactyl\Models\Subuser */ public function loadServerAndUserRelations(Subuser $subuser, bool $refresh = false): Subuser; /** * Return a subuser with the associated permissions relationship. * * @param \Pterodactyl\Models\Subuser $subuser * @param bool $refresh * @return \Pterodactyl\Models\Subuser */ public function getWithPermissions(Subuser $subuser, bool $refresh = false): Subuser; /** * Return a subuser and associated permissions given a user_id and server_id. * * @param int $user * @param int $server * @return \Pterodactyl\Models\Subuser * * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function getWithPermissionsUsingUserAndServer(int $user, int $server): Subuser; /** * Find a subuser and return with server and permissions relationships. * * @param int $id * @return \Illuminate\Database\Eloquent\Collection * * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function getWithServerAndPermissions($id); /** * Return a subuser and their associated connection key for a server. * * @param int $user * @param int $server * @return \Pterodactyl\Models\Subuser * * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function getWithKey($user, $server); }