forked from Alex/Pterodactyl-Panel
107 lines
2.8 KiB
PHP
107 lines
2.8 KiB
PHP
<?php
|
|
|
|
namespace Pterodactyl\Models;
|
|
|
|
/**
|
|
* @property int $id
|
|
* @property int $server_id
|
|
* @property int $old_node
|
|
* @property int $new_node
|
|
* @property int $old_allocation
|
|
* @property int $new_allocation
|
|
* @property array|null $old_additional_allocations
|
|
* @property array|null $new_additional_allocations
|
|
* @property bool|null $successful
|
|
* @property bool $archived
|
|
* @property \Carbon\Carbon $created_at
|
|
* @property \Carbon\Carbon $updated_at
|
|
* @property \Pterodactyl\Models\Server $server
|
|
* @property \Pterodactyl\Models\Node $oldNode
|
|
* @property \Pterodactyl\Models\Node $newNode
|
|
*/
|
|
class ServerTransfer extends Model
|
|
{
|
|
/**
|
|
* The resource name for this model when it is transformed into an
|
|
* API representation using fractal.
|
|
*/
|
|
public const RESOURCE_NAME = 'server_transfer';
|
|
|
|
/**
|
|
* The table associated with the model.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $table = 'server_transfers';
|
|
|
|
/**
|
|
* Fields that are not mass assignable.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $guarded = ['id', 'created_at', 'updated_at'];
|
|
|
|
/**
|
|
* Cast values to correct type.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $casts = [
|
|
'server_id' => 'int',
|
|
'old_node' => 'int',
|
|
'new_node' => 'int',
|
|
'old_allocation' => 'int',
|
|
'new_allocation' => 'int',
|
|
'old_additional_allocations' => 'array',
|
|
'new_additional_allocations' => 'array',
|
|
'successful' => 'bool',
|
|
'archived' => 'bool',
|
|
];
|
|
|
|
/**
|
|
* @var array
|
|
*/
|
|
public static $validationRules = [
|
|
'server_id' => 'required|numeric|exists:servers,id',
|
|
'old_node' => 'required|numeric',
|
|
'new_node' => 'required|numeric',
|
|
'old_allocation' => 'required|numeric',
|
|
'new_allocation' => 'required|numeric',
|
|
'old_additional_allocations' => 'nullable|array',
|
|
'old_additional_allocations.*' => 'numeric',
|
|
'new_additional_allocations' => 'nullable|array',
|
|
'new_additional_allocations.*' => 'numeric',
|
|
'successful' => 'sometimes|nullable|boolean',
|
|
];
|
|
|
|
/**
|
|
* Gets the server associated with a server transfer.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
*/
|
|
public function server()
|
|
{
|
|
return $this->belongsTo(Server::class);
|
|
}
|
|
|
|
/**
|
|
* Gets the source node associated with a server transfer.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasOne
|
|
*/
|
|
public function oldNode()
|
|
{
|
|
return $this->hasOne(Node::class, 'id', 'old_node');
|
|
}
|
|
|
|
/**
|
|
* Gets the target node associated with a server transfer.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasOne
|
|
*/
|
|
public function newNode()
|
|
{
|
|
return $this->hasOne(Node::class, 'id', 'new_node');
|
|
}
|
|
}
|