create Socialite Login/Register

This commit is contained in:
Milos Holba
2021-12-16 14:07:33 +01:00
parent 73cd950054
commit f37c4f62b7
18 changed files with 509 additions and 1504 deletions

View File

@@ -22,12 +22,14 @@ class CreateNewUserAction extends Controller
* Validate and create a new user.
*/
public function __invoke(
RegisterUserRequest $request
$data
): Application | ResponseFactory | Response {
$settings = get_settings([
'storage_default', 'registration', 'user_verification',
]);
$socialite_auth = ! isset($data['password']) ?? true;
// Check if account registration is enabled
if (! intval($settings['registration'])) {
abort(401);
@@ -35,12 +37,12 @@ class CreateNewUserAction extends Controller
// Create user
$user = User::create([
'password' => bcrypt($request->input('password')),
'email' => $request->input('email'),
'password' => ! $socialite_auth ? bcrypt($data['password']) : null,
'email' => $data['email'],
]);
// Mark as verified if verification is disabled
if (! intval($settings['user_verification'])) {
if (! intval($settings['user_verification']) || $socialite_auth) {
$user->markEmailAsVerified();
}
@@ -49,8 +51,9 @@ class CreateNewUserAction extends Controller
$user
->settings()
->create([
'name' => $request->input('name'),
'name' => $data['name'],
'storage_capacity' => $settings['storage_default'],
'avatar' => $data->avatar ? $data->avatar : null,
]);
UserSettings::reguard();
@@ -58,7 +61,7 @@ class CreateNewUserAction extends Controller
event(new Registered($user));
// Log in if verification is disabled
if (! intval($settings['user_verification'])) {
if (! intval($settings['user_verification']) || $socialite_auth) {
$this->guard->login($user);
}