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; $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; }); } public function render() { return view('livewire.project.resource.index'); } }