lasthourcloud/app/Actions/Fortify/CreateNewUser.php

73 lines
2.2 KiB
PHP
Raw Normal View History

<?php
namespace App\Actions\Fortify;
2023-04-25 08:06:45 +00:00
use App\Models\InstanceSettings;
use App\Models\User;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
use Illuminate\Validation\Rule;
use Laravel\Fortify\Contracts\CreatesNewUsers;
class CreateNewUser implements CreatesNewUsers
{
use PasswordValidationRules;
/**
* Validate and create a newly registered user.
*
2024-06-10 20:43:34 +00:00
* @param array<string, string> $input
*/
public function create(array $input): User
{
2023-05-16 15:09:50 +00:00
$settings = InstanceSettings::get();
2024-06-10 20:43:34 +00:00
if (! $settings->is_registration_enabled) {
2023-04-25 08:06:45 +00:00
abort(403);
}
Validator::make($input, [
'name' => ['required', 'string', 'max:255'],
'email' => [
'required',
'string',
'email',
'max:255',
Rule::unique(User::class),
],
'password' => $this->passwordRules(),
])->validate();
if (User::count() == 0) {
// If this is the first user, make them the root user
// Team is already created in the database/seeders/ProductionSeeder.php
$user = User::create([
'id' => 0,
'name' => $input['name'],
'email' => $input['email'],
'password' => Hash::make($input['password']),
]);
2023-06-09 13:55:21 +00:00
$team = $user->teams()->first();
2023-06-13 13:59:25 +00:00
// Disable registration after first user is created
$settings = InstanceSettings::get();
$settings->is_registration_enabled = false;
$settings->save();
} else {
$user = User::create([
'name' => $input['name'],
'email' => $input['email'],
'password' => Hash::make($input['password']),
]);
2023-06-09 13:55:21 +00:00
$team = $user->teams()->first();
2023-10-09 12:20:55 +00:00
if (isCloud()) {
$user->sendVerificationEmail();
} else {
$user->markEmailAsVerified();
}
}
// Set session variable
2023-04-13 15:17:30 +00:00
session(['currentTeam' => $user->currentTeam = $team]);
2024-06-10 20:43:34 +00:00
2023-04-13 13:48:27 +00:00
return $user;
}
}