*/ use HasFactory; /** * 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. */ protected $table = 'server_transfers'; /** * Fields that are not mass assignable. */ protected $guarded = ['id', 'created_at', 'updated_at']; /** * Cast values to correct type. */ 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', ]; public static array $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<\Pterodactyl\Models\Server, $this> */ public function server(): BelongsTo { return $this->belongsTo(Server::class); } /** * Gets the source node associated with a server transfer. * * @return \Illuminate\Database\Eloquent\Relations\HasOne<\Pterodactyl\Models\Node, $this> */ public function oldNode(): HasOne { return $this->hasOne(Node::class, 'id', 'old_node'); } /** * Gets the target node associated with a server transfer. * * @return \Illuminate\Database\Eloquent\Relations\HasOne<\Pterodactyl\Models\Node, $this> */ public function newNode(): HasOne { return $this->hasOne(Node::class, 'id', 'new_node'); } }