lasthourcloud/app/Http/Controllers/DatabaseController.php

85 lines
3.4 KiB
PHP
Raw Normal View History

2023-08-07 16:46:40 +00:00
<?php
namespace App\Http\Controllers;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Validation\ValidatesRequests;
class DatabaseController extends Controller
{
use AuthorizesRequests, ValidatesRequests;
2023-08-07 16:46:40 +00:00
public function configuration()
{
2023-08-22 15:44:49 +00:00
$project = currentTeam()->load(['projects'])->projects->where('uuid', request()->route('project_uuid'))->first();
2023-08-07 16:46:40 +00:00
if (!$project) {
return redirect()->route('dashboard');
}
$environment = $project->load(['environments'])->environments->where('name', request()->route('environment_name'))->first()->load(['applications']);
if (!$environment) {
return redirect()->route('dashboard');
}
2023-10-12 15:18:33 +00:00
$database = $environment->databases()->where('uuid', request()->route('database_uuid'))->first();
2023-08-07 16:46:40 +00:00
if (!$database) {
return redirect()->route('dashboard');
}
return view('project.database.configuration', ['database' => $database]);
}
2023-08-09 14:47:24 +00:00
2023-08-11 08:42:57 +00:00
public function executions()
{
$backup_uuid = request()->route('backup_uuid');
2023-08-22 15:44:49 +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()->load(['applications']);
if (!$environment) {
return redirect()->route('dashboard');
}
2023-10-12 15:18:33 +00:00
$database = $environment->databases()->where('uuid', request()->route('database_uuid'))->first();
if (!$database) {
return redirect()->route('dashboard');
}
$backup = $database->scheduledBackups->where('uuid', $backup_uuid)->first();
if (!$backup) {
return redirect()->route('dashboard');
}
2023-08-11 08:42:57 +00:00
$executions = collect($backup->executions)->sortByDesc('created_at');
2023-08-11 14:13:53 +00:00
return view('project.database.backups.executions', [
'database' => $database,
'backup' => $backup,
'executions' => $executions,
2023-08-22 15:44:49 +00:00
's3s' => currentTeam()->s3s,
2023-08-11 14:13:53 +00:00
]);
}
2023-08-09 14:47:24 +00:00
public function backups()
{
2023-08-22 15:44:49 +00:00
$project = currentTeam()->load(['projects'])->projects->where('uuid', request()->route('project_uuid'))->first();
2023-08-09 14:47:24 +00:00
if (!$project) {
return redirect()->route('dashboard');
}
$environment = $project->load(['environments'])->environments->where('name', request()->route('environment_name'))->first()->load(['applications']);
if (!$environment) {
return redirect()->route('dashboard');
}
2023-10-12 15:18:33 +00:00
$database = $environment->databases()->where('uuid', request()->route('database_uuid'))->first();
2023-08-09 14:47:24 +00:00
if (!$database) {
return redirect()->route('dashboard');
}
2023-10-13 07:39:40 +00:00
// No backups for redis
if ($database->getMorphClass() === 'App\Models\StandaloneRedis') {
return redirect()->route('project.database.configuration', [
'project_uuid' => $project->uuid,
'environment_name' => $environment->name,
'database_uuid' => $database->uuid,
]);
}
2023-08-11 14:13:53 +00:00
return view('project.database.backups.all', [
'database' => $database,
2023-08-22 15:44:49 +00:00
's3s' => currentTeam()->s3s,
2023-08-11 14:13:53 +00:00
]);
2023-08-09 14:47:24 +00:00
}
2023-08-07 20:14:21 +00:00
}