2017-09-24 02:45:25 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Transformers\Daemon;
|
|
|
|
|
2017-09-24 18:34:00 +01:00
|
|
|
use Carbon\Carbon;
|
2017-09-24 02:45:25 +01:00
|
|
|
use Pterodactyl\Models\DaemonKey;
|
|
|
|
use Pterodactyl\Models\Permission;
|
|
|
|
use League\Fractal\TransformerAbstract;
|
|
|
|
use Pterodactyl\Contracts\Repository\SubuserRepositoryInterface;
|
2017-11-05 22:07:50 +00:00
|
|
|
use Pterodactyl\Contracts\Repository\DaemonKeyRepositoryInterface;
|
2017-09-24 02:45:25 +01:00
|
|
|
|
|
|
|
class ApiKeyTransformer extends TransformerAbstract
|
|
|
|
{
|
2017-09-24 18:34:00 +01:00
|
|
|
/**
|
2017-11-05 22:07:50 +00:00
|
|
|
* @var \Pterodactyl\Contracts\Repository\DaemonKeyRepositoryInterface
|
2017-09-24 18:34:00 +01:00
|
|
|
*/
|
2017-11-05 22:07:50 +00:00
|
|
|
private $keyRepository;
|
2017-09-24 18:34:00 +01:00
|
|
|
|
2017-09-24 02:45:25 +01:00
|
|
|
/**
|
|
|
|
* @var \Pterodactyl\Contracts\Repository\SubuserRepositoryInterface
|
|
|
|
*/
|
2017-11-05 22:07:50 +00:00
|
|
|
private $repository;
|
2017-09-24 02:45:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ApiKeyTransformer constructor.
|
|
|
|
*
|
2017-11-05 22:07:50 +00:00
|
|
|
* @param \Pterodactyl\Contracts\Repository\DaemonKeyRepositoryInterface $keyRepository
|
2019-09-06 05:32:57 +01:00
|
|
|
* @param \Pterodactyl\Contracts\Repository\SubuserRepositoryInterface $repository
|
2017-09-24 02:45:25 +01:00
|
|
|
*/
|
2017-11-05 22:07:50 +00:00
|
|
|
public function __construct(DaemonKeyRepositoryInterface $keyRepository, SubuserRepositoryInterface $repository)
|
2017-09-24 02:45:25 +01:00
|
|
|
{
|
|
|
|
$this->repository = $repository;
|
2017-11-05 22:07:50 +00:00
|
|
|
$this->keyRepository = $keyRepository;
|
2017-09-24 02:45:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a listing of servers that a daemon key can access.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Models\DaemonKey $key
|
|
|
|
* @return array
|
|
|
|
*
|
|
|
|
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
|
|
|
|
*/
|
|
|
|
public function transform(DaemonKey $key)
|
|
|
|
{
|
2017-11-05 22:07:50 +00:00
|
|
|
$this->keyRepository->loadServerAndUserRelations($key);
|
|
|
|
|
|
|
|
if ($key->user_id === $key->getRelation('server')->owner_id || $key->getRelation('user')->root_admin) {
|
2017-09-24 02:45:25 +01:00
|
|
|
return [
|
2017-11-05 22:07:50 +00:00
|
|
|
'id' => $key->getRelation('server')->uuid,
|
2017-09-24 18:34:00 +01:00
|
|
|
'is_temporary' => true,
|
2017-11-05 22:07:50 +00:00
|
|
|
'expires_in' => max(Carbon::now()->diffInSeconds($key->expires_at, false), 0),
|
2017-09-24 02:45:25 +01:00
|
|
|
'permissions' => ['s:*'],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$subuser = $this->repository->getWithPermissionsUsingUserAndServer($key->user_id, $key->server_id);
|
|
|
|
|
2017-11-05 22:07:50 +00:00
|
|
|
$permissions = $subuser->getRelation('permissions')->pluck('permission')->toArray();
|
2017-09-24 02:45:25 +01:00
|
|
|
$mappings = Permission::getPermissions(true);
|
2017-11-18 22:50:58 +00:00
|
|
|
$daemonPermissions = ['s:console'];
|
2017-09-24 02:45:25 +01:00
|
|
|
|
|
|
|
foreach ($permissions as $permission) {
|
2018-03-04 03:31:44 +00:00
|
|
|
if (! is_null(array_get($mappings, $permission))) {
|
|
|
|
$daemonPermissions[] = array_get($mappings, $permission);
|
2017-09-24 02:45:25 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
2017-11-05 22:07:50 +00:00
|
|
|
'id' => $key->getRelation('server')->uuid,
|
2017-09-24 18:34:00 +01:00
|
|
|
'is_temporary' => true,
|
2017-11-05 22:07:50 +00:00
|
|
|
'expires_in' => max(Carbon::now()->diffInSeconds($key->expires_at, false), 0),
|
2017-09-24 18:34:00 +01:00
|
|
|
'permissions' => $daemonPermissions,
|
2017-09-24 02:45:25 +01:00
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|