147 lines
4.1 KiB
PHP
147 lines
4.1 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use OpenApi\Attributes as OA;
|
|
|
|
#[OA\Schema(
|
|
description: 'Project model',
|
|
type: 'object',
|
|
properties: [
|
|
'id' => ['type' => 'integer'],
|
|
'uuid' => ['type' => 'string'],
|
|
'name' => ['type' => 'string'],
|
|
'environments' => new OA\Property(
|
|
property: 'environments',
|
|
type: 'array',
|
|
items: new OA\Items(ref: '#/components/schemas/Environment'),
|
|
description: 'The environments of the project.'
|
|
),
|
|
]
|
|
)]
|
|
class Project extends BaseModel
|
|
{
|
|
protected $guarded = [];
|
|
|
|
public static function ownedByCurrentTeam()
|
|
{
|
|
return Project::whereTeamId(currentTeam()->id)->orderBy('name');
|
|
}
|
|
|
|
protected static function booted()
|
|
{
|
|
static::created(function ($project) {
|
|
ProjectSetting::create([
|
|
'project_id' => $project->id,
|
|
]);
|
|
Environment::create([
|
|
'name' => 'production',
|
|
'project_id' => $project->id,
|
|
]);
|
|
});
|
|
static::deleting(function ($project) {
|
|
$project->environments()->delete();
|
|
$project->settings()->delete();
|
|
$shared_variables = $project->environment_variables();
|
|
foreach ($shared_variables as $shared_variable) {
|
|
ray('Deleting project shared variable: '.$shared_variable->name);
|
|
$shared_variable->delete();
|
|
}
|
|
});
|
|
}
|
|
|
|
public function environment_variables()
|
|
{
|
|
return $this->hasMany(SharedEnvironmentVariable::class);
|
|
}
|
|
|
|
public function environments()
|
|
{
|
|
return $this->hasMany(Environment::class);
|
|
}
|
|
|
|
public function settings()
|
|
{
|
|
return $this->hasOne(ProjectSetting::class);
|
|
}
|
|
|
|
public function team()
|
|
{
|
|
return $this->belongsTo(Team::class);
|
|
}
|
|
|
|
public function services()
|
|
{
|
|
return $this->hasManyThrough(Service::class, Environment::class);
|
|
}
|
|
|
|
public function applications()
|
|
{
|
|
return $this->hasManyThrough(Application::class, Environment::class);
|
|
}
|
|
|
|
public function postgresqls()
|
|
{
|
|
return $this->hasManyThrough(StandalonePostgresql::class, Environment::class);
|
|
}
|
|
|
|
public function redis()
|
|
{
|
|
return $this->hasManyThrough(StandaloneRedis::class, Environment::class);
|
|
}
|
|
|
|
public function keydbs()
|
|
{
|
|
return $this->hasManyThrough(StandaloneKeydb::class, Environment::class);
|
|
}
|
|
|
|
public function dragonflies()
|
|
{
|
|
return $this->hasManyThrough(StandaloneDragonfly::class, Environment::class);
|
|
}
|
|
|
|
public function clickhouses()
|
|
{
|
|
return $this->hasManyThrough(StandaloneClickhouse::class, Environment::class);
|
|
}
|
|
|
|
public function mongodbs()
|
|
{
|
|
return $this->hasManyThrough(StandaloneMongodb::class, Environment::class);
|
|
}
|
|
|
|
public function mysqls()
|
|
{
|
|
return $this->hasManyThrough(StandaloneMysql::class, Environment::class);
|
|
}
|
|
|
|
public function mariadbs()
|
|
{
|
|
return $this->hasManyThrough(StandaloneMariadb::class, Environment::class);
|
|
}
|
|
|
|
public function resource_count()
|
|
{
|
|
return $this->applications()->count() + $this->postgresqls()->count() + $this->redis()->count() + $this->mongodbs()->count() + $this->mysqls()->count() + $this->mariadbs()->count() + $this->keydbs()->count() + $this->dragonflies()->count() + $this->clickhouses()->count() + $this->services()->count();
|
|
}
|
|
|
|
public function databases()
|
|
{
|
|
return $this->postgresqls()->get()->merge($this->redis()->get())->merge($this->mongodbs()->get())->merge($this->mysqls()->get())->merge($this->mariadbs()->get())->merge($this->keydbs()->get())->merge($this->dragonflies()->get())->merge($this->clickhouses()->get());
|
|
}
|
|
|
|
public function default_environment()
|
|
{
|
|
$default = $this->environments()->where('name', 'production')->first();
|
|
if ($default) {
|
|
return $default->name;
|
|
}
|
|
$default = $this->environments()->get();
|
|
if ($default->count() > 0) {
|
|
return $default->sortBy('created_at')->first()->name;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}
|