2015-12-06 18:58:49 +00:00
|
|
|
<?php
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2015-12-06 18:58:49 +00:00
|
|
|
namespace Pterodactyl\Models;
|
|
|
|
|
2019-11-04 01:13:47 +00:00
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
|
2019-09-05 05:00:34 +01:00
|
|
|
class Permission extends Validable
|
2015-12-06 18:58:49 +00:00
|
|
|
{
|
2018-01-26 03:26:06 +00:00
|
|
|
/**
|
|
|
|
* The resource name for this model when it is transformed into an
|
|
|
|
* API representation using fractal.
|
|
|
|
*/
|
|
|
|
const RESOURCE_NAME = 'subuser_permission';
|
|
|
|
|
2020-03-19 04:08:32 +00:00
|
|
|
/**
|
|
|
|
* Constants defining different permissions available.
|
|
|
|
*/
|
2020-03-22 22:31:25 +00:00
|
|
|
const ACTION_WEBSOCKET = 'websocket.*';
|
|
|
|
const ACTION_CONTROL_CONSOLE = 'control.console';
|
|
|
|
const ACTION_CONTROL_START = 'control.start';
|
|
|
|
const ACTION_CONTROL_STOP = 'control.stop';
|
|
|
|
const ACTION_CONTROL_RESTART = 'control.restart';
|
|
|
|
const ACTION_CONTROL_KILL = 'control.kill';
|
|
|
|
|
|
|
|
const ACTION_DATABASE_READ = 'database.read';
|
|
|
|
const ACTION_DATABASE_CREATE = 'database.create';
|
|
|
|
const ACTION_DATABASE_UPDATE = 'database.update';
|
|
|
|
const ACTION_DATABASE_DELETE = 'database.delete';
|
|
|
|
const ACTION_DATABASE_VIEW_PASSWORD = 'database.view_password';
|
|
|
|
|
2020-03-19 04:08:32 +00:00
|
|
|
const ACTION_SCHEDULE_READ = 'schedule.read';
|
|
|
|
const ACTION_SCHEDULE_CREATE = 'schedule.create';
|
|
|
|
const ACTION_SCHEDULE_UPDATE = 'schedule.update';
|
|
|
|
const ACTION_SCHEDULE_DELETE = 'schedule.delete';
|
|
|
|
|
2020-03-22 22:31:25 +00:00
|
|
|
const ACTION_USER_READ = 'user.read';
|
|
|
|
const ACTION_USER_CREATE = 'user.create';
|
|
|
|
const ACTION_USER_UPDATE = 'user.update';
|
|
|
|
const ACTION_USER_DELETE = 'user.delete';
|
|
|
|
|
|
|
|
const ACTION_ALLOCATION_READ = 'allocation.read';
|
|
|
|
const ACTION_ALLOCIATION_UPDATE = 'allocation.update';
|
|
|
|
|
|
|
|
const ACTION_FILE_READ = 'file.read';
|
|
|
|
const ACTION_FILE_CREATE = 'file.create';
|
|
|
|
const ACTION_FILE_UPDATE = 'file.update';
|
|
|
|
const ACTION_FILE_DELETE = 'file.delete';
|
|
|
|
const ACTION_FILE_ARCHIVE = 'file.archive';
|
|
|
|
const ACTION_FILE_SFTP = 'file.sftp';
|
|
|
|
|
|
|
|
const ACTION_SETTINGS_RENAME = 'settings.rename';
|
|
|
|
const ACTION_SETTINGS_REINSTALL = 'settings.reinstall';
|
|
|
|
|
2017-02-10 00:38:54 +00:00
|
|
|
/**
|
|
|
|
* Should timestamps be used on this model.
|
|
|
|
*
|
2017-02-12 20:10:39 +00:00
|
|
|
* @var bool
|
2017-02-10 00:38:54 +00:00
|
|
|
*/
|
|
|
|
public $timestamps = false;
|
|
|
|
|
2015-12-06 18:58:49 +00:00
|
|
|
/**
|
|
|
|
* The table associated with the model.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $table = 'permissions';
|
|
|
|
|
2016-01-19 00:57:10 +00:00
|
|
|
/**
|
|
|
|
* Fields that are not mass assignable.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $guarded = ['id', 'created_at', 'updated_at'];
|
|
|
|
|
2017-02-09 23:44:07 +00:00
|
|
|
/**
|
|
|
|
* Cast values to correct type.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $casts = [
|
|
|
|
'subuser_id' => 'integer',
|
|
|
|
];
|
2016-01-27 03:17:51 +00:00
|
|
|
|
2017-09-25 03:12:30 +01:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2019-09-05 06:19:57 +01:00
|
|
|
public static $validationRules = [
|
|
|
|
'subuser_id' => 'required|numeric|min:1',
|
|
|
|
'permission' => 'required|string',
|
2017-09-25 03:12:30 +01:00
|
|
|
];
|
|
|
|
|
2017-03-30 20:30:59 +01:00
|
|
|
/**
|
2019-11-04 01:13:47 +00:00
|
|
|
* All of the permissions available on the system. You should use self::permissions()
|
|
|
|
* to retrieve them, and not directly access this array as it is subject to change.
|
2017-03-30 20:30:59 +01:00
|
|
|
*
|
|
|
|
* @var array
|
2019-11-04 01:13:47 +00:00
|
|
|
* @see \Pterodactyl\Models\Permission::permissions()
|
2017-03-30 20:30:59 +01:00
|
|
|
*/
|
|
|
|
protected static $permissions = [
|
2019-11-04 01:13:47 +00:00
|
|
|
'websocket' => [
|
|
|
|
// Allows the user to connect to the server websocket, this will give them
|
|
|
|
// access to view the console output as well as realtime server stats (CPU
|
|
|
|
// and Memory usage).
|
|
|
|
'*',
|
|
|
|
],
|
|
|
|
|
|
|
|
'control' => [
|
|
|
|
// Allows the user to send data to the server console process. A user with this
|
|
|
|
// permission will not be able to stop the server directly by issuing the specified
|
|
|
|
// stop command for the Egg, however depending on plugins and server configuration
|
|
|
|
// they may still be able to control the server power state.
|
|
|
|
'console', // power.send-command
|
|
|
|
|
|
|
|
// Allows the user to start/stop/restart/kill the server process.
|
|
|
|
'start', // power.power-start
|
|
|
|
'stop', // power.power-stop
|
|
|
|
'restart', // power.power-restart
|
|
|
|
'kill', // power.power-kill
|
|
|
|
],
|
|
|
|
|
|
|
|
'user' => [
|
|
|
|
// Allows a user to create a new user assigned to the server. They will not be able
|
|
|
|
// to assign any permissions they do not already have on their account as well.
|
|
|
|
'create', // subuser.create-subuser
|
|
|
|
'read', // subuser.list-subusers, subuser.view-subuser
|
|
|
|
'update', // subuser.edit-subuser
|
|
|
|
'delete', // subuser.delete-subuser
|
|
|
|
],
|
|
|
|
|
|
|
|
'file' => [
|
|
|
|
// Allows a user to create additional files and folders either via the Panel,
|
|
|
|
// or via a direct upload.
|
|
|
|
'create', // files.create-files, files.upload-files, files.copy-files, files.move-files
|
|
|
|
|
|
|
|
// Allows a user to view the contents of a directory as well as read the contents
|
|
|
|
// of a given file. A user with this permission will be able to download files
|
|
|
|
// as well.
|
|
|
|
'read', // files.list-files, files.download-files
|
|
|
|
|
|
|
|
// Allows a user to update the contents of an existing file or directory.
|
|
|
|
'update', // files.edit-files, files.save-files
|
|
|
|
|
|
|
|
// Allows a user to delete a file or directory.
|
|
|
|
'delete', // files.delete-files
|
|
|
|
|
|
|
|
// Allows a user to archive the contents of a directory as well as decompress existing
|
|
|
|
// archives on the system.
|
|
|
|
'archive', // files.compress-files, files.decompress-files
|
|
|
|
|
|
|
|
// Allows the user to connect and manage server files using their account
|
|
|
|
// credentials and a SFTP client.
|
|
|
|
'sftp', // files.access-sftp
|
|
|
|
],
|
|
|
|
|
|
|
|
// Controls permissions for editing or viewing a server's allocations.
|
|
|
|
'allocation' => [
|
|
|
|
'read', // server.view-allocations
|
|
|
|
'update', // server.edit-allocation
|
|
|
|
],
|
|
|
|
|
|
|
|
// Controls permissions for editing or viewing a server's startup parameters.
|
|
|
|
'startup' => [
|
|
|
|
'read', // server.view-startup
|
|
|
|
'update', // server.edit-startup
|
|
|
|
],
|
|
|
|
|
|
|
|
'database' => [
|
|
|
|
// Allows a user to create a new database for a server.
|
|
|
|
'create', // database.create-database
|
|
|
|
|
|
|
|
// Allows a user to view the databases associated with the server. If they do not also
|
|
|
|
// have the view_password permission they will only be able to see the connection address
|
|
|
|
// and the name of the user.
|
|
|
|
'read', // database.view-databases
|
|
|
|
|
|
|
|
// Allows a user to rotate the password on a database instance. If the user does not
|
|
|
|
// alow have the view_password permission they will not be able to see the updated password
|
|
|
|
// anywhere, but it will still be rotated.
|
|
|
|
'update', // database.reset-db-password
|
|
|
|
|
|
|
|
// Allows a user to delete a database instance.
|
|
|
|
'delete', // database.delete-database
|
|
|
|
|
|
|
|
// Allows a user to view the password associated with a database instance for the
|
|
|
|
// server. Note that a user without this permission may still be able to access these
|
|
|
|
// credentials by viewing files or the console.
|
|
|
|
'view_password', // database.reset-db-password
|
|
|
|
],
|
|
|
|
|
|
|
|
'schedule' => [
|
|
|
|
'create', // task.create-schedule
|
|
|
|
'read', // task.view-schedule, task.list-schedules
|
|
|
|
'update', // task.edit-schedule, task.queue-schedule, task.toggle-schedule
|
|
|
|
'delete', // task.delete-schedule
|
|
|
|
],
|
2020-03-22 22:31:25 +00:00
|
|
|
|
|
|
|
'settings' => [
|
|
|
|
'rename',
|
|
|
|
'reinstall',
|
|
|
|
],
|
2019-11-04 01:13:47 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns all of the permissions available on the system for a user to
|
|
|
|
* have when controlling a server.
|
|
|
|
*
|
2019-12-28 20:03:19 +00:00
|
|
|
* @return \Illuminate\Database\Eloquent\Collection
|
2019-11-04 01:13:47 +00:00
|
|
|
*/
|
|
|
|
public static function permissions(): Collection
|
|
|
|
{
|
|
|
|
return Collection::make(self::$permissions);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A list of all permissions available for a user.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
* @deprecated
|
|
|
|
*/
|
|
|
|
protected static $deprecatedPermissions = [
|
2017-03-30 20:30:59 +01:00
|
|
|
'power' => [
|
|
|
|
'power-start' => 's:power:start',
|
|
|
|
'power-stop' => 's:power:stop',
|
|
|
|
'power-restart' => 's:power:restart',
|
|
|
|
'power-kill' => 's:power:kill',
|
|
|
|
'send-command' => 's:command',
|
|
|
|
],
|
|
|
|
'subuser' => [
|
|
|
|
'list-subusers' => null,
|
|
|
|
'view-subuser' => null,
|
|
|
|
'edit-subuser' => null,
|
|
|
|
'create-subuser' => null,
|
|
|
|
'delete-subuser' => null,
|
|
|
|
],
|
|
|
|
'server' => [
|
2017-10-21 03:32:57 +01:00
|
|
|
'view-allocations' => null,
|
|
|
|
'edit-allocation' => null,
|
2017-03-30 20:30:59 +01:00
|
|
|
'view-startup' => null,
|
2017-08-22 04:10:48 +01:00
|
|
|
'edit-startup' => null,
|
2017-03-30 20:30:59 +01:00
|
|
|
],
|
2018-02-17 22:10:44 +00:00
|
|
|
'database' => [
|
|
|
|
'view-databases' => null,
|
|
|
|
'reset-db-password' => null,
|
2018-03-03 01:03:55 +00:00
|
|
|
'delete-database' => null,
|
|
|
|
'create-database' => null,
|
2017-03-30 20:30:59 +01:00
|
|
|
],
|
|
|
|
'file' => [
|
2018-02-17 22:10:44 +00:00
|
|
|
'access-sftp' => null,
|
2017-03-30 20:30:59 +01:00
|
|
|
'list-files' => 's:files:get',
|
|
|
|
'edit-files' => 's:files:read',
|
|
|
|
'save-files' => 's:files:post',
|
|
|
|
'move-files' => 's:files:move',
|
|
|
|
'copy-files' => 's:files:copy',
|
|
|
|
'compress-files' => 's:files:compress',
|
|
|
|
'decompress-files' => 's:files:decompress',
|
|
|
|
'create-files' => 's:files:create',
|
|
|
|
'upload-files' => 's:files:upload',
|
|
|
|
'delete-files' => 's:files:delete',
|
2018-02-17 22:10:44 +00:00
|
|
|
'download-files' => 's:files:download',
|
2017-03-30 20:30:59 +01:00
|
|
|
],
|
|
|
|
'task' => [
|
2017-09-14 03:46:43 +01:00
|
|
|
'list-schedules' => null,
|
|
|
|
'view-schedule' => null,
|
|
|
|
'toggle-schedule' => null,
|
|
|
|
'queue-schedule' => null,
|
|
|
|
'edit-schedule' => null,
|
|
|
|
'create-schedule' => null,
|
|
|
|
'delete-schedule' => null,
|
2017-03-30 20:30:59 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a collection of permissions available.
|
|
|
|
*
|
2017-08-24 03:34:11 +01:00
|
|
|
* @param bool $array
|
2019-12-28 20:03:19 +00:00
|
|
|
* @return array|\Illuminate\Database\Eloquent\Collection
|
2019-11-04 01:13:47 +00:00
|
|
|
* @deprecated
|
2017-03-30 20:30:59 +01:00
|
|
|
*/
|
2017-08-24 03:34:11 +01:00
|
|
|
public static function getPermissions($array = false)
|
2017-03-30 20:30:59 +01:00
|
|
|
{
|
2017-08-24 03:34:11 +01:00
|
|
|
if ($array) {
|
2019-11-04 01:13:47 +00:00
|
|
|
return collect(self::$deprecatedPermissions)->mapWithKeys(function ($item) {
|
2017-03-30 20:30:59 +01:00
|
|
|
return $item;
|
|
|
|
})->all();
|
|
|
|
}
|
|
|
|
|
2019-11-04 01:13:47 +00:00
|
|
|
return collect(self::$deprecatedPermissions);
|
2017-03-30 20:30:59 +01:00
|
|
|
}
|
2015-12-06 18:58:49 +00:00
|
|
|
}
|