lasthourcloud/app/Models/SwarmDocker.php

76 lines
1.9 KiB
PHP
Raw Normal View History

2023-03-27 14:31:42 +02:00
<?php
namespace App\Models;
class SwarmDocker extends BaseModel
{
2023-11-28 15:49:24 +01:00
protected $guarded = [];
2023-03-27 14:31:42 +02:00
public function applications()
{
return $this->morphMany(Application::class, 'destination');
}
2023-11-28 15:49:24 +01:00
public function postgresqls()
{
return $this->morphMany(StandalonePostgresql::class, 'destination');
}
public function redis()
{
return $this->morphMany(StandaloneRedis::class, 'destination');
}
2024-04-10 15:00:46 +02:00
public function keydbs()
{
return $this->morphMany(StandaloneKeydb::class, 'destination');
}
public function dragonflies()
{
return $this->morphMany(StandaloneDragonfly::class, 'destination');
}
public function clickhouses()
{
return $this->morphMany(StandaloneClickhouse::class, 'destination');
}
2023-11-28 15:49:24 +01:00
public function mongodbs()
{
return $this->morphMany(StandaloneMongodb::class, 'destination');
}
public function mysqls()
{
return $this->morphMany(StandaloneMysql::class, 'destination');
}
public function mariadbs()
{
return $this->morphMany(StandaloneMariadb::class, 'destination');
}
2023-05-02 12:47:52 +02:00
public function server()
{
return $this->belongsTo(Server::class);
}
2023-11-28 15:49:24 +01:00
public function services()
{
return $this->morphMany(Service::class, 'destination');
}
public function databases()
{
$postgresqls = $this->postgresqls;
$redis = $this->redis;
$mongodbs = $this->mongodbs;
$mysqls = $this->mysqls;
$mariadbs = $this->mariadbs;
2024-04-10 15:00:46 +02:00
$keydbs = $this->keydbs;
$dragonflies = $this->dragonflies;
$clickhouses = $this->clickhouses;
return $postgresqls->concat($redis)->concat($mongodbs)->concat($mysqls)->concat($mariadbs)->concat($keydbs)->concat($dragonflies)->concat($clickhouses);
2023-11-28 15:49:24 +01:00
}
public function attachedTo()
{
return $this->applications?->count() > 0 || $this->databases()->count() > 0;
}
2023-03-27 14:31:42 +02:00
}