<?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.', ]; } }