2015-12-08 23:33:33 +00:00
|
|
|
<?php
|
2016-01-20 00:10:39 +00:00
|
|
|
/**
|
2016-01-20 21:05:16 +00:00
|
|
|
* Pterodactyl - Panel
|
2017-01-24 22:57:08 +00:00
|
|
|
* Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
|
2016-01-20 00:10:39 +00:00
|
|
|
*
|
2017-09-26 02:43:01 +00:00
|
|
|
* This software is licensed under the terms of the MIT license.
|
|
|
|
* https://opensource.org/licenses/MIT
|
2016-01-20 00:10:39 +00:00
|
|
|
*/
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2015-12-08 23:33:33 +00:00
|
|
|
namespace Pterodactyl\Models;
|
|
|
|
|
2017-08-09 04:24:55 +00:00
|
|
|
use Sofa\Eloquence\Eloquence;
|
|
|
|
use Sofa\Eloquence\Validable;
|
2015-12-08 23:33:33 +00:00
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2017-08-12 20:29:01 +00:00
|
|
|
use Sofa\Eloquence\Contracts\CleansAttributes;
|
2017-08-09 04:24:55 +00:00
|
|
|
use Sofa\Eloquence\Contracts\Validable as ValidableContract;
|
2015-12-08 23:33:33 +00:00
|
|
|
|
2017-08-12 20:29:01 +00:00
|
|
|
class ServiceOption extends Model implements CleansAttributes, ValidableContract
|
2015-12-08 23:33:33 +00:00
|
|
|
{
|
2017-08-09 04:24:55 +00:00
|
|
|
use Eloquence, Validable;
|
|
|
|
|
2015-12-08 23:33:33 +00:00
|
|
|
/**
|
|
|
|
* The table associated with the model.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $table = 'service_options';
|
|
|
|
|
2016-02-15 20:21:28 +00:00
|
|
|
/**
|
|
|
|
* Fields that are not mass assignable.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2017-10-03 03:51:13 +00:00
|
|
|
protected $fillable = [
|
|
|
|
'name',
|
|
|
|
'description',
|
|
|
|
'docker_image',
|
|
|
|
'config_files',
|
|
|
|
'config_startup',
|
|
|
|
'config_logs',
|
|
|
|
'config_stop',
|
|
|
|
'config_from',
|
|
|
|
'startup',
|
|
|
|
'script_is_privileged',
|
|
|
|
'script_install',
|
|
|
|
'script_entry',
|
|
|
|
'script_container',
|
|
|
|
'copy_script_from',
|
|
|
|
];
|
2016-02-15 20:21:28 +00:00
|
|
|
|
2017-08-09 04:24:55 +00:00
|
|
|
/**
|
|
|
|
* Cast values to correct type.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $casts = [
|
|
|
|
'service_id' => 'integer',
|
2017-10-03 03:51:13 +00:00
|
|
|
'config_from' => 'integer',
|
2017-08-09 04:24:55 +00:00
|
|
|
'script_is_privileged' => 'boolean',
|
2017-10-03 03:51:13 +00:00
|
|
|
'copy_script_from' => 'integer',
|
2017-08-09 04:24:55 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected static $applicationRules = [
|
|
|
|
'service_id' => 'required',
|
|
|
|
'name' => 'required',
|
|
|
|
'description' => 'required',
|
|
|
|
'tag' => 'required',
|
|
|
|
'docker_image' => 'sometimes',
|
|
|
|
'startup' => 'sometimes',
|
|
|
|
'config_from' => 'sometimes',
|
|
|
|
'config_stop' => 'required_without:config_from',
|
|
|
|
'config_startup' => 'required_without:config_from',
|
|
|
|
'config_logs' => 'required_without:config_from',
|
|
|
|
'config_files' => 'required_without:config_from',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected static $dataIntegrityRules = [
|
2017-10-03 03:51:13 +00:00
|
|
|
'service_id' => 'bail|numeric|exists:services,id',
|
2017-10-04 04:31:04 +00:00
|
|
|
'uuid' => 'string|size:36',
|
2017-08-09 04:24:55 +00:00
|
|
|
'name' => 'string|max:255',
|
|
|
|
'description' => 'string',
|
2017-10-04 04:31:04 +00:00
|
|
|
'tag' => 'bail|string|max:150',
|
2017-08-09 04:24:55 +00:00
|
|
|
'docker_image' => 'string|max:255',
|
|
|
|
'startup' => 'nullable|string',
|
2017-10-03 03:51:13 +00:00
|
|
|
'config_from' => 'bail|nullable|numeric|exists:service_options,id',
|
2017-08-09 04:24:55 +00:00
|
|
|
'config_stop' => 'nullable|string|max:255',
|
|
|
|
'config_startup' => 'nullable|json',
|
|
|
|
'config_logs' => 'nullable|json',
|
|
|
|
'config_files' => 'nullable|json',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $attributes = [
|
|
|
|
'config_stop' => null,
|
|
|
|
'config_startup' => null,
|
|
|
|
'config_logs' => null,
|
|
|
|
'config_files' => null,
|
|
|
|
'startup' => null,
|
|
|
|
'docker_image' => null,
|
|
|
|
];
|
2016-12-12 19:30:57 +00:00
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Returns the display startup string for the option and will use the parent
|
|
|
|
* service one if the option does not have one defined.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-10-04 01:18:27 +00:00
|
|
|
public function getDisplayStartupAttribute()
|
2017-03-19 23:36:50 +00:00
|
|
|
{
|
|
|
|
return (is_null($this->startup)) ? $this->service->startup : $this->startup;
|
|
|
|
}
|
2017-02-09 22:43:54 +00:00
|
|
|
|
2017-04-27 20:16:57 +00:00
|
|
|
/**
|
|
|
|
* Returns the install script for the option; if option is copying from another
|
|
|
|
* it will return the copied script.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-10-04 01:18:27 +00:00
|
|
|
public function getCopyScriptInstallAttribute()
|
2017-04-27 20:16:57 +00:00
|
|
|
{
|
2017-10-04 01:18:27 +00:00
|
|
|
return (is_null($this->copy_script_from)) ? $this->script_install : $this->scriptFrom->script_install;
|
2017-04-27 20:16:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the entry command for the option; if option is copying from another
|
|
|
|
* it will return the copied entry command.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-10-04 01:18:27 +00:00
|
|
|
public function getCopyScriptEntryAttribute()
|
2017-04-27 20:16:57 +00:00
|
|
|
{
|
2017-10-04 01:18:27 +00:00
|
|
|
return (is_null($this->copy_script_from)) ? $this->script_entry : $this->scriptFrom->script_entry;
|
2017-04-27 20:16:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the install container for the option; if option is copying from another
|
|
|
|
* it will return the copied install container.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-10-04 01:18:27 +00:00
|
|
|
public function getCopyScriptContainerAttribute()
|
2017-04-27 20:16:57 +00:00
|
|
|
{
|
2017-10-04 01:18:27 +00:00
|
|
|
return (is_null($this->copy_script_from)) ? $this->script_container : $this->scriptFrom->script_container;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the file configuration for a service option.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getInheritConfigFilesAttribute()
|
|
|
|
{
|
|
|
|
return is_null($this->config_from) ? $this->config_files : $this->configFrom->config_files;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the startup configuration for a service option.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getInheritConfigStartupAttribute()
|
|
|
|
{
|
|
|
|
return is_null($this->config_from) ? $this->config_startup : $this->configFrom->config_startup;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the log reading configuration for a service option.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getInheritConfigLogsAttribute()
|
|
|
|
{
|
|
|
|
return is_null($this->config_from) ? $this->config_logs : $this->configFrom->config_logs;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the stop command configuration for a service option.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getInheritConfigStopAttribute()
|
|
|
|
{
|
|
|
|
return is_null($this->config_from) ? $this->config_stop : $this->configFrom->config_stop;
|
2017-04-27 20:16:57 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Gets service associated with a service option.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
|
|
|
public function service()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Service::class);
|
|
|
|
}
|
2017-02-05 22:58:17 +00:00
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Gets all servers associated with this service option.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
|
|
*/
|
|
|
|
public function servers()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Server::class, 'option_id');
|
|
|
|
}
|
2017-02-05 22:58:17 +00:00
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Gets all variables associated with this service.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
|
|
*/
|
|
|
|
public function variables()
|
|
|
|
{
|
|
|
|
return $this->hasMany(ServiceVariable::class, 'option_id');
|
|
|
|
}
|
2017-02-02 21:01:18 +00:00
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Gets all packs associated with this service.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
|
|
*/
|
|
|
|
public function packs()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Pack::class, 'option_id');
|
|
|
|
}
|
2017-04-27 20:16:57 +00:00
|
|
|
|
2017-08-09 04:24:55 +00:00
|
|
|
/**
|
|
|
|
* Get the parent service option from which to copy scripts.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
2017-10-04 01:18:27 +00:00
|
|
|
public function scriptFrom()
|
2017-04-27 20:16:57 +00:00
|
|
|
{
|
2017-05-02 00:58:36 +00:00
|
|
|
return $this->belongsTo(self::class, 'copy_script_from');
|
2017-04-27 20:16:57 +00:00
|
|
|
}
|
2017-10-04 01:18:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the parent service option from which to copy configuration settings.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
|
|
|
public function configFrom()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(self::class, 'config_from');
|
|
|
|
}
|
2015-12-08 23:33:33 +00:00
|
|
|
}
|