167 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Livewire\Project\Service;
 | 
						|
 | 
						|
use App\Actions\Database\StartDatabaseProxy;
 | 
						|
use App\Actions\Database\StopDatabaseProxy;
 | 
						|
use App\Models\InstanceSettings;
 | 
						|
use App\Models\ServiceDatabase;
 | 
						|
use Illuminate\Support\Facades\Auth;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
use Illuminate\Support\Facades\Hash;
 | 
						|
use Livewire\Component;
 | 
						|
 | 
						|
class Database extends Component
 | 
						|
{
 | 
						|
    public ServiceDatabase $database;
 | 
						|
 | 
						|
    public ?string $db_url_public = null;
 | 
						|
 | 
						|
    public $fileStorages;
 | 
						|
 | 
						|
    public $parameters;
 | 
						|
 | 
						|
    protected $listeners = ['refreshFileStorages'];
 | 
						|
 | 
						|
    protected $rules = [
 | 
						|
        'database.human_name' => 'nullable',
 | 
						|
        'database.description' => 'nullable',
 | 
						|
        'database.image' => 'required',
 | 
						|
        'database.exclude_from_status' => 'required|boolean',
 | 
						|
        'database.public_port' => 'nullable|integer',
 | 
						|
        'database.is_public' => 'required|boolean',
 | 
						|
        'database.is_log_drain_enabled' => 'required|boolean',
 | 
						|
    ];
 | 
						|
 | 
						|
    public function render()
 | 
						|
    {
 | 
						|
        return view('livewire.project.service.database');
 | 
						|
    }
 | 
						|
 | 
						|
    public function mount()
 | 
						|
    {
 | 
						|
        $this->parameters = get_route_parameters();
 | 
						|
        if ($this->database->is_public) {
 | 
						|
            $this->db_url_public = $this->database->getServiceDatabaseUrl();
 | 
						|
        }
 | 
						|
        $this->refreshFileStorages();
 | 
						|
    }
 | 
						|
 | 
						|
    public function delete($password)
 | 
						|
    {
 | 
						|
        if (! data_get(InstanceSettings::get(), 'disable_two_step_confirmation')) {
 | 
						|
            if (! Hash::check($password, Auth::user()->password)) {
 | 
						|
                $this->addError('password', 'The provided password is incorrect.');
 | 
						|
 | 
						|
                return;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        try {
 | 
						|
            $this->database->delete();
 | 
						|
            $this->dispatch('success', 'Database deleted.');
 | 
						|
 | 
						|
            return redirect()->route('project.service.configuration', $this->parameters);
 | 
						|
        } catch (\Throwable $e) {
 | 
						|
            return handleError($e, $this);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function instantSaveExclude()
 | 
						|
    {
 | 
						|
        $this->submit();
 | 
						|
    }
 | 
						|
 | 
						|
    public function instantSaveLogDrain()
 | 
						|
    {
 | 
						|
        if (! $this->database->service->destination->server->isLogDrainEnabled()) {
 | 
						|
            $this->database->is_log_drain_enabled = false;
 | 
						|
            $this->dispatch('error', 'Log drain is not enabled on the server. Please enable it first.');
 | 
						|
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        $this->submit();
 | 
						|
        $this->dispatch('success', 'You need to restart the service for the changes to take effect.');
 | 
						|
    }
 | 
						|
 | 
						|
    public function convertToApplication()
 | 
						|
    {
 | 
						|
        try {
 | 
						|
            $service = $this->database->service;
 | 
						|
            $serviceDatabase = $this->database;
 | 
						|
 | 
						|
            // Check if application with same name already exists
 | 
						|
            if ($service->applications()->where('name', $serviceDatabase->name)->exists()) {
 | 
						|
                throw new \Exception('An application with this name already exists.');
 | 
						|
            }
 | 
						|
 | 
						|
            // Create new parameters removing database_uuid
 | 
						|
            $redirectParams = collect($this->parameters)
 | 
						|
                ->except('database_uuid')
 | 
						|
                ->all();
 | 
						|
 | 
						|
            DB::transaction(function () use ($service, $serviceDatabase) {
 | 
						|
                $service->applications()->create([
 | 
						|
                    'name' => $serviceDatabase->name,
 | 
						|
                    'human_name' => $serviceDatabase->human_name,
 | 
						|
                    'description' => $serviceDatabase->description,
 | 
						|
                    'exclude_from_status' => $serviceDatabase->exclude_from_status,
 | 
						|
                    'is_log_drain_enabled' => $serviceDatabase->is_log_drain_enabled,
 | 
						|
                    'image' => $serviceDatabase->image,
 | 
						|
                    'service_id' => $service->id,
 | 
						|
                    'is_migrated' => true,
 | 
						|
                ]);
 | 
						|
                $serviceDatabase->delete();
 | 
						|
            });
 | 
						|
 | 
						|
            return redirect()->route('project.service.configuration', $redirectParams);
 | 
						|
        } catch (\Throwable $e) {
 | 
						|
            return handleError($e, $this);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function instantSave()
 | 
						|
    {
 | 
						|
        if ($this->database->is_public && ! $this->database->public_port) {
 | 
						|
            $this->dispatch('error', 'Public port is required.');
 | 
						|
            $this->database->is_public = false;
 | 
						|
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        if ($this->database->is_public) {
 | 
						|
            if (! str($this->database->status)->startsWith('running')) {
 | 
						|
                $this->dispatch('error', 'Database must be started to be publicly accessible.');
 | 
						|
                $this->database->is_public = false;
 | 
						|
 | 
						|
                return;
 | 
						|
            }
 | 
						|
            StartDatabaseProxy::run($this->database);
 | 
						|
            $this->db_url_public = $this->database->getServiceDatabaseUrl();
 | 
						|
            $this->dispatch('success', 'Database is now publicly accessible.');
 | 
						|
        } else {
 | 
						|
            StopDatabaseProxy::run($this->database);
 | 
						|
            $this->db_url_public = null;
 | 
						|
            $this->dispatch('success', 'Database is no longer publicly accessible.');
 | 
						|
        }
 | 
						|
        $this->submit();
 | 
						|
    }
 | 
						|
 | 
						|
    public function refreshFileStorages()
 | 
						|
    {
 | 
						|
        $this->fileStorages = $this->database->fileStorages()->get();
 | 
						|
    }
 | 
						|
 | 
						|
    public function submit()
 | 
						|
    {
 | 
						|
        try {
 | 
						|
            $this->validate();
 | 
						|
            $this->database->save();
 | 
						|
            updateCompose($this->database);
 | 
						|
            $this->dispatch('success', 'Database saved.');
 | 
						|
        } catch (\Throwable) {
 | 
						|
        } finally {
 | 
						|
            $this->dispatch('generateDockerCompose');
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |