2020-05-21 00:29:03 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Models;
|
|
|
|
|
2020-10-17 21:42:08 +01:00
|
|
|
use Illuminate\Validation\Rules\NotIn;
|
2022-10-14 17:59:20 +01:00
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
|
2020-10-17 21:42:08 +01:00
|
|
|
|
2020-05-21 00:29:03 +01:00
|
|
|
/**
|
2021-01-28 04:52:11 +00:00
|
|
|
* @property int $id
|
|
|
|
* @property string $uuid
|
|
|
|
* @property string $name
|
|
|
|
* @property string $description
|
|
|
|
* @property string $source
|
|
|
|
* @property string $target
|
|
|
|
* @property bool $read_only
|
|
|
|
* @property bool $user_mountable
|
|
|
|
* @property \Pterodactyl\Models\Egg[]|\Illuminate\Database\Eloquent\Collection $eggs
|
|
|
|
* @property \Pterodactyl\Models\Node[]|\Illuminate\Database\Eloquent\Collection $nodes
|
2020-05-21 21:23:12 +01:00
|
|
|
* @property \Pterodactyl\Models\Server[]|\Illuminate\Database\Eloquent\Collection $servers
|
2020-05-21 00:29:03 +01:00
|
|
|
*/
|
|
|
|
class Mount extends Model
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The resource name for this model when it is transformed into an
|
|
|
|
* API representation using fractal.
|
|
|
|
*/
|
2021-01-23 20:33:34 +00:00
|
|
|
public const RESOURCE_NAME = 'mount';
|
2020-05-21 00:29:03 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The table associated with the model.
|
|
|
|
*/
|
|
|
|
protected $table = 'mounts';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fields that are not mass assignable.
|
|
|
|
*/
|
2020-05-21 22:14:09 +01:00
|
|
|
protected $guarded = ['id', 'uuid'];
|
2020-05-21 01:00:53 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Default values for specific fields in the database.
|
|
|
|
*/
|
2020-09-13 18:04:30 +01:00
|
|
|
protected $casts = [
|
2020-05-21 02:11:20 +01:00
|
|
|
'id' => 'int',
|
2020-05-21 01:00:53 +01:00
|
|
|
'read_only' => 'bool',
|
|
|
|
'user_mountable' => 'bool',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Rules verifying that the data being stored matches the expectations of the database.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public static array $validationRules = [
|
2020-05-21 01:00:53 +01:00
|
|
|
'name' => 'required|string|min:2|max:64|unique:mounts,name',
|
2020-09-27 00:29:26 +01:00
|
|
|
'description' => 'nullable|string|max:191',
|
2020-05-21 01:00:53 +01:00
|
|
|
'source' => 'required|string',
|
|
|
|
'target' => 'required|string',
|
|
|
|
'read_only' => 'sometimes|boolean',
|
|
|
|
'user_mountable' => 'sometimes|boolean',
|
|
|
|
];
|
|
|
|
|
2020-10-17 21:42:08 +01:00
|
|
|
/**
|
|
|
|
* Implement language verification by overriding Eloquence's gather
|
|
|
|
* rules function.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public static function getRules(): array
|
2020-10-17 21:42:08 +01:00
|
|
|
{
|
|
|
|
$rules = parent::getRules();
|
|
|
|
|
|
|
|
$rules['source'][] = new NotIn(Mount::$invalidSourcePaths);
|
2020-10-17 21:43:07 +01:00
|
|
|
$rules['target'][] = new NotIn(Mount::$invalidTargetPaths);
|
2020-10-17 21:42:08 +01:00
|
|
|
|
|
|
|
return $rules;
|
|
|
|
}
|
|
|
|
|
2020-05-21 01:55:59 +01:00
|
|
|
/**
|
|
|
|
* Disable timestamps on this model.
|
|
|
|
*/
|
|
|
|
public $timestamps = false;
|
|
|
|
|
2020-10-17 21:37:18 +01:00
|
|
|
/**
|
2021-01-23 20:09:16 +00:00
|
|
|
* Blacklisted source paths.
|
2020-10-17 21:37:18 +01:00
|
|
|
*/
|
|
|
|
public static $invalidSourcePaths = [
|
|
|
|
'/etc/pterodactyl',
|
|
|
|
'/var/lib/pterodactyl/volumes',
|
|
|
|
'/srv/daemon-data',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
2021-01-23 20:09:16 +00:00
|
|
|
* Blacklisted target paths.
|
2020-10-17 21:37:18 +01:00
|
|
|
*/
|
|
|
|
public static $invalidTargetPaths = [
|
|
|
|
'/home/container',
|
|
|
|
];
|
|
|
|
|
2020-05-21 01:00:53 +01:00
|
|
|
/**
|
|
|
|
* Returns all eggs that have this mount assigned.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function eggs(): BelongsToMany
|
2020-05-21 01:00:53 +01:00
|
|
|
{
|
|
|
|
return $this->belongsToMany(Egg::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns all nodes that have this mount assigned.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function nodes(): BelongsToMany
|
2020-05-21 01:00:53 +01:00
|
|
|
{
|
2020-08-26 05:54:41 +01:00
|
|
|
return $this->belongsToMany(Node::class);
|
2020-05-21 01:00:53 +01:00
|
|
|
}
|
2020-05-21 21:23:12 +01:00
|
|
|
|
|
|
|
/**
|
2020-08-26 05:54:41 +01:00
|
|
|
* Returns all servers that have this mount assigned.
|
2020-05-21 21:23:12 +01:00
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function servers(): BelongsToMany
|
2020-05-21 21:23:12 +01:00
|
|
|
{
|
2020-08-26 05:54:41 +01:00
|
|
|
return $this->belongsToMany(Server::class);
|
2020-05-21 21:23:12 +01:00
|
|
|
}
|
2020-05-21 00:29:03 +01:00
|
|
|
}
|