feat: email, username and password validation when they are set via envs
This commit is contained in:
@@ -6,6 +6,8 @@ use App\Models\InstanceSettings;
|
|||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Illuminate\Database\Seeder;
|
use Illuminate\Database\Seeder;
|
||||||
use Illuminate\Support\Facades\Hash;
|
use Illuminate\Support\Facades\Hash;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use Illuminate\Validation\Rules\Password;
|
||||||
|
|
||||||
class RootUserSeeder extends Seeder
|
class RootUserSeeder extends Seeder
|
||||||
{
|
{
|
||||||
@@ -18,6 +20,25 @@ class RootUserSeeder extends Seeder
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (env('ROOT_USER_EMAIL') && env('ROOT_USER_PASSWORD')) {
|
if (env('ROOT_USER_EMAIL') && env('ROOT_USER_PASSWORD')) {
|
||||||
|
$validator = Validator::make([
|
||||||
|
'email' => env('ROOT_USER_EMAIL'),
|
||||||
|
'username' => env('ROOT_USERNAME', 'Root User'),
|
||||||
|
'password' => env('ROOT_USER_PASSWORD'),
|
||||||
|
], [
|
||||||
|
'email' => ['required', 'email:rfc,dns', 'max:255'],
|
||||||
|
'username' => ['required', 'string', 'min:3', 'max:255', 'regex:/^[a-zA-Z0-9\s-_]+$/'],
|
||||||
|
'password' => ['required', 'string', 'min:8', Password::min(8)->mixedCase()->letters()->numbers()->symbols()->uncompromised()],
|
||||||
|
]);
|
||||||
|
|
||||||
|
if ($validator->fails()) {
|
||||||
|
echo " Validation failed:\n";
|
||||||
|
foreach ($validator->errors()->all() as $error) {
|
||||||
|
echo " - {$error}\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
User::create([
|
User::create([
|
||||||
'id' => 0,
|
'id' => 0,
|
||||||
'name' => env('ROOT_USERNAME', 'Root User'),
|
'name' => env('ROOT_USERNAME', 'Root User'),
|
||||||
|
|||||||
Reference in New Issue
Block a user