2016-11-27 00:29:57 +00:00
|
|
|
<?php
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2017-08-24 03:34:11 +01:00
|
|
|
namespace Pterodactyl\Repositories\Eloquent;
|
2016-11-27 00:29:57 +00:00
|
|
|
|
2017-08-27 20:55:25 +01:00
|
|
|
use Pterodactyl\Models\Subuser;
|
2019-11-03 20:20:11 +00:00
|
|
|
use Illuminate\Support\Collection;
|
2017-08-27 20:55:25 +01:00
|
|
|
use Pterodactyl\Exceptions\Repository\RecordNotFoundException;
|
|
|
|
use Pterodactyl\Contracts\Repository\SubuserRepositoryInterface;
|
2016-11-27 00:29:57 +00:00
|
|
|
|
2017-08-24 03:34:11 +01:00
|
|
|
class SubuserRepository extends EloquentRepository implements SubuserRepositoryInterface
|
2016-11-27 00:29:57 +00:00
|
|
|
{
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* Return the model backing this repository.
|
|
|
|
*
|
|
|
|
* @return string
|
2017-03-19 23:36:50 +00:00
|
|
|
*/
|
2017-08-24 03:34:11 +01:00
|
|
|
public function model()
|
2016-11-27 00:29:57 +00:00
|
|
|
{
|
2017-08-24 03:34:11 +01:00
|
|
|
return Subuser::class;
|
2016-11-27 00:29:57 +00:00
|
|
|
}
|
2017-08-26 19:31:18 +01:00
|
|
|
|
2019-11-03 20:20:11 +00:00
|
|
|
/**
|
|
|
|
* Returns the subusers for the given server instance with the associated user
|
|
|
|
* and permission relationships pre-loaded.
|
|
|
|
*
|
|
|
|
* @param int $server
|
|
|
|
* @return \Illuminate\Support\Collection
|
|
|
|
*/
|
|
|
|
public function getSubusersForServer(int $server): Collection
|
|
|
|
{
|
|
|
|
return $this->getBuilder()
|
|
|
|
->with('user', 'permissions')
|
|
|
|
->where('server_id', $server)
|
|
|
|
->get()
|
|
|
|
->toBase();
|
|
|
|
}
|
|
|
|
|
2017-08-27 00:08:11 +01:00
|
|
|
/**
|
2017-10-28 03:42:53 +01:00
|
|
|
* Return a subuser with the associated server relationship.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Models\Subuser $subuser
|
2019-09-06 05:32:57 +01:00
|
|
|
* @param bool $refresh
|
2017-10-28 03:42:53 +01:00
|
|
|
* @return \Pterodactyl\Models\Subuser
|
2017-08-27 00:08:11 +01:00
|
|
|
*/
|
2017-11-05 18:38:39 +00:00
|
|
|
public function loadServerAndUserRelations(Subuser $subuser, bool $refresh = false): Subuser
|
2017-08-27 00:08:11 +01:00
|
|
|
{
|
2017-10-28 03:42:53 +01:00
|
|
|
if (! $subuser->relationLoaded('server') || $refresh) {
|
|
|
|
$subuser->load('server');
|
2017-09-05 00:12:13 +01:00
|
|
|
}
|
|
|
|
|
2017-11-05 18:38:39 +00:00
|
|
|
if (! $subuser->relationLoaded('user') || $refresh) {
|
|
|
|
$subuser->load('user');
|
|
|
|
}
|
|
|
|
|
2017-10-28 03:42:53 +01:00
|
|
|
return $subuser;
|
2017-09-05 00:12:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-10-28 03:42:53 +01:00
|
|
|
* Return a subuser with the associated permissions relationship.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Models\Subuser $subuser
|
2019-09-06 05:32:57 +01:00
|
|
|
* @param bool $refresh
|
2017-10-28 03:42:53 +01:00
|
|
|
* @return \Pterodactyl\Models\Subuser
|
2017-09-05 00:12:13 +01:00
|
|
|
*/
|
2017-10-28 03:42:53 +01:00
|
|
|
public function getWithPermissions(Subuser $subuser, bool $refresh = false): Subuser
|
2017-09-05 00:12:13 +01:00
|
|
|
{
|
2017-10-28 03:42:53 +01:00
|
|
|
if (! $subuser->relationLoaded('permissions') || $refresh) {
|
|
|
|
$subuser->load('permissions');
|
|
|
|
}
|
2017-09-05 00:12:13 +01:00
|
|
|
|
2017-10-28 03:42:53 +01:00
|
|
|
if (! $subuser->relationLoaded('user') || $refresh) {
|
|
|
|
$subuser->load('user');
|
2017-08-27 00:08:11 +01:00
|
|
|
}
|
|
|
|
|
2017-10-28 03:42:53 +01:00
|
|
|
return $subuser;
|
2017-08-27 00:08:11 +01:00
|
|
|
}
|
|
|
|
|
2017-09-24 02:45:25 +01:00
|
|
|
/**
|
2017-11-05 22:07:50 +00:00
|
|
|
* 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
|
2017-09-24 02:45:25 +01:00
|
|
|
*/
|
2017-11-05 22:07:50 +00:00
|
|
|
public function getWithPermissionsUsingUserAndServer(int $user, int $server): Subuser
|
2017-09-24 02:45:25 +01:00
|
|
|
{
|
|
|
|
$instance = $this->getBuilder()->with('permissions')->where([
|
|
|
|
['user_id', '=', $user],
|
|
|
|
['server_id', '=', $server],
|
|
|
|
])->first();
|
|
|
|
|
|
|
|
if (is_null($instance)) {
|
|
|
|
throw new RecordNotFoundException;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $instance;
|
|
|
|
}
|
2016-11-27 00:29:57 +00:00
|
|
|
}
|