vito/app/Models/SshKey.php
Saeed Vaziry 5c72f12490 init
2023-07-02 12:47:50 +02:00

67 lines
1.6 KiB
PHP

<?php
namespace App\Models;
use App\Enums\SshKeyStatus;
use App\Jobs\SshKey\DeleteSshKeyFromServer;
use App\Jobs\SshKey\DeploySshKeyToServer;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
/**
* @property int $user_id
* @property string $name
* @property string $public_key
* @property User $user
* @property Server[] $servers
*/
class SshKey extends AbstractModel
{
use HasFactory;
protected $fillable = [
'user_id',
'name',
'public_key',
];
protected $casts = [
'user_id' => 'integer',
'public_key' => 'encrypted',
];
public function user(): BelongsTo
{
return $this->belongsTo(User::class);
}
public function servers(): BelongsToMany
{
return $this->belongsToMany(Server::class, 'server_ssh_keys')
->withPivot('status')
->withTimestamps();
}
public function existsOnServer(Server $server): bool
{
return (bool) $this->servers()->where('id', $server->id)->first();
}
public function deployTo(Server $server): void
{
$server->sshKeys()->attach($this, [
'status' => SshKeyStatus::ADDING,
]);
dispatch(new DeploySshKeyToServer($server, $this))->onConnection('ssh');
}
public function deleteFrom(Server $server): void
{
$this->servers()->updateExistingPivot($server->id, [
'status' => SshKeyStatus::DELETING,
]);
dispatch(new DeleteSshKeyFromServer($server, $this))->onConnection('ssh');
}
}