53 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Http\Requests\Api\Client\Servers\Databases;
 | 
						|
 | 
						|
use Webmozart\Assert\Assert;
 | 
						|
use App\Models\Server;
 | 
						|
use Illuminate\Validation\Rule;
 | 
						|
use App\Models\Database;
 | 
						|
use App\Models\Permission;
 | 
						|
use Illuminate\Database\Query\Builder;
 | 
						|
use App\Contracts\Http\ClientPermissionsRequest;
 | 
						|
use App\Http\Requests\Api\Client\ClientApiRequest;
 | 
						|
use App\Services\Databases\DatabaseManagementService;
 | 
						|
 | 
						|
class StoreDatabaseRequest extends ClientApiRequest implements ClientPermissionsRequest
 | 
						|
{
 | 
						|
    public function permission(): string
 | 
						|
    {
 | 
						|
        return Permission::ACTION_DATABASE_CREATE;
 | 
						|
    }
 | 
						|
 | 
						|
    public function rules(): array
 | 
						|
    {
 | 
						|
        $server = $this->route()->parameter('server');
 | 
						|
 | 
						|
        Assert::isInstanceOf($server, Server::class);
 | 
						|
 | 
						|
        return [
 | 
						|
            'database' => [
 | 
						|
                'required',
 | 
						|
                'alpha_dash',
 | 
						|
                'min:3',
 | 
						|
                'max:48',
 | 
						|
                // Yes, I am aware that you could have the same database name across two unique hosts. However,
 | 
						|
                // I don't really care about that for this validation. We just want to make sure it is unique to
 | 
						|
                // the server itself. No need for complexity.
 | 
						|
                Rule::unique('databases')->where(function (Builder $query) use ($server) {
 | 
						|
                    $query->where('server_id', $server->id)
 | 
						|
                        ->where('database', DatabaseManagementService::generateUniqueDatabaseName($this->input('database'), $server->id));
 | 
						|
                }),
 | 
						|
            ],
 | 
						|
            'remote' => Database::getRulesForField('remote'),
 | 
						|
        ];
 | 
						|
    }
 | 
						|
 | 
						|
    public function messages(): array
 | 
						|
    {
 | 
						|
        return [
 | 
						|
            'database.unique' => 'The database name you have selected is already in use by this server.',
 | 
						|
        ];
 | 
						|
    }
 | 
						|
}
 |