2024-01-07 15:23:41 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Livewire\Project\Resource;
|
|
|
|
|
|
|
|
use App\Models\Environment;
|
|
|
|
use App\Models\Project;
|
|
|
|
use Livewire\Component;
|
|
|
|
|
|
|
|
class Index extends Component
|
|
|
|
{
|
|
|
|
public Project $project;
|
|
|
|
public Environment $environment;
|
2024-01-12 10:25:20 +00:00
|
|
|
public $applications = [];
|
|
|
|
public $postgresqls = [];
|
|
|
|
public $redis = [];
|
|
|
|
public $mongodbs = [];
|
|
|
|
public $mysqls = [];
|
|
|
|
public $mariadbs = [];
|
|
|
|
public $services = [];
|
|
|
|
public function mount()
|
|
|
|
{
|
2024-01-07 15:23:41 +00:00
|
|
|
$project = currentTeam()->load(['projects'])->projects->where('uuid', request()->route('project_uuid'))->first();
|
|
|
|
if (!$project) {
|
|
|
|
return redirect()->route('dashboard');
|
|
|
|
}
|
|
|
|
$environment = $project->load(['environments'])->environments->where('name', request()->route('environment_name'))->first();
|
|
|
|
if (!$environment) {
|
|
|
|
return redirect()->route('dashboard');
|
|
|
|
}
|
|
|
|
$this->project = $project;
|
|
|
|
$this->environment = $environment;
|
2024-01-12 10:25:20 +00:00
|
|
|
$this->applications = $environment->applications->sortBy('name');
|
|
|
|
$this->applications = $this->applications->map(function ($application) {
|
|
|
|
if (data_get($application, 'environment.project.uuid')) {
|
|
|
|
$application->hrefLink = route('project.application.configuration', [
|
|
|
|
'project_uuid' => data_get($application, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($application, 'environment.name'),
|
|
|
|
'application_uuid' => data_get($application, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $application;
|
|
|
|
});
|
|
|
|
$this->postgresqls = $environment->postgresqls->sortBy('name');
|
|
|
|
$this->postgresqls = $this->postgresqls->map(function ($postgresql) {
|
|
|
|
if (data_get($postgresql, 'environment.project.uuid')) {
|
|
|
|
$postgresql->hrefLink = route('project.database.configuration', [
|
|
|
|
'project_uuid' => data_get($postgresql, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($postgresql, 'environment.name'),
|
|
|
|
'database_uuid' => data_get($postgresql, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $postgresql;
|
|
|
|
});
|
|
|
|
$this->redis = $environment->redis->sortBy('name');
|
|
|
|
$this->redis = $this->redis->map(function ($redis) {
|
|
|
|
if (data_get($redis, 'environment.project.uuid')) {
|
|
|
|
$redis->hrefLink = route('project.database.configuration', [
|
|
|
|
'project_uuid' => data_get($redis, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($redis, 'environment.name'),
|
|
|
|
'database_uuid' => data_get($redis, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $redis;
|
|
|
|
});
|
|
|
|
$this->mongodbs = $environment->mongodbs->sortBy('name');
|
|
|
|
$this->mongodbs = $this->mongodbs->map(function ($mongodb) {
|
|
|
|
if (data_get($mongodb, 'environment.project.uuid')) {
|
|
|
|
$mongodb->hrefLink = route('project.database.configuration', [
|
|
|
|
'project_uuid' => data_get($mongodb, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($mongodb, 'environment.name'),
|
|
|
|
'database_uuid' => data_get($mongodb, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $mongodb;
|
|
|
|
});
|
|
|
|
$this->mysqls = $environment->mysqls->sortBy('name');
|
|
|
|
$this->mysqls = $this->mysqls->map(function ($mysql) {
|
|
|
|
if (data_get($mysql, 'environment.project.uuid')) {
|
|
|
|
$mysql->hrefLink = route('project.database.configuration', [
|
|
|
|
'project_uuid' => data_get($mysql, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($mysql, 'environment.name'),
|
|
|
|
'database_uuid' => data_get($mysql, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $mysql;
|
|
|
|
});
|
|
|
|
$this->mariadbs = $environment->mariadbs->sortBy('name');
|
|
|
|
$this->mariadbs = $this->mariadbs->map(function ($mariadb) {
|
|
|
|
if (data_get($mariadb, 'environment.project.uuid')) {
|
|
|
|
$mariadb->hrefLink = route('project.database.configuration', [
|
|
|
|
'project_uuid' => data_get($mariadb, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($mariadb, 'environment.name'),
|
|
|
|
'database_uuid' => data_get($mariadb, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $mariadb;
|
|
|
|
});
|
|
|
|
$this->services = $environment->services->sortBy('name');
|
|
|
|
$this->services = $this->services->map(function ($service) {
|
|
|
|
if (data_get($service, 'environment.project.uuid')) {
|
|
|
|
$service->hrefLink = route('project.service.configuration', [
|
|
|
|
'project_uuid' => data_get($service, 'environment.project.uuid'),
|
|
|
|
'environment_name' => data_get($service, 'environment.name'),
|
|
|
|
'service_uuid' => data_get($service, 'uuid')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $service;
|
|
|
|
});
|
2024-01-07 15:23:41 +00:00
|
|
|
}
|
|
|
|
public function render()
|
|
|
|
{
|
|
|
|
return view('livewire.project.resource.index');
|
|
|
|
}
|
|
|
|
}
|