60 lines
1.4 KiB
PHP
60 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
class Project extends BaseModel
|
|
{
|
|
protected $guarded = [];
|
|
|
|
static public 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();
|
|
});
|
|
}
|
|
|
|
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 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);
|
|
}
|
|
}
|