mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-24 09:50:39 +00:00
create Socialite Login/Register
This commit is contained in:
@@ -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);
|
||||
}
|
||||
|
||||
|
||||
@@ -0,0 +1,19 @@
|
||||
<?php
|
||||
namespace App\Users\Controllers\Authentication;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Users\Actions\CreateNewUserAction;
|
||||
use App\Users\Requests\RegisterUserRequest;
|
||||
|
||||
class RegisterAuthenticationController extends Controller
|
||||
{
|
||||
public function __construct(
|
||||
public CreateNewUserAction $createNewUser,
|
||||
) {
|
||||
}
|
||||
|
||||
public function __invoke(RegisterUserRequest $request)
|
||||
{
|
||||
($this->createNewUser)($request);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,49 @@
|
||||
<?php
|
||||
namespace App\Users\Controllers\Authentication;
|
||||
|
||||
use App\Users\Models\User;
|
||||
use App\Http\Controllers\Controller;
|
||||
use Laravel\Socialite\Facades\Socialite;
|
||||
use App\Users\Actions\CreateNewUserAction;
|
||||
use Illuminate\Contracts\Auth\StatefulGuard;
|
||||
|
||||
class SocialiteAuthenticationController extends Controller
|
||||
{
|
||||
public function __construct(
|
||||
protected StatefulGuard $guard,
|
||||
public CreateNewUserAction $createNewUser,
|
||||
) {
|
||||
}
|
||||
|
||||
public function redirect($provider)
|
||||
{
|
||||
$url = Socialite::driver($provider)->stateless()->redirect()->getTargetUrl();
|
||||
|
||||
return response()->json([
|
||||
'url' => $url
|
||||
]);
|
||||
}
|
||||
|
||||
public function callback($provider)
|
||||
{
|
||||
// Get socialite user
|
||||
$provider_user = Socialite::driver($provider)->stateless()->user();
|
||||
|
||||
// Check if user exist already
|
||||
$user = User::whereEmail($provider_user->email)->first();
|
||||
|
||||
if($user) {
|
||||
// Login User
|
||||
$this->guard->login($user);
|
||||
|
||||
} else {
|
||||
// Add user avatar from socialite
|
||||
$provider_user->avatar = get_socialite_avatar($provider_user->avatar);
|
||||
|
||||
// Create User
|
||||
($this->createNewUser)($provider_user);
|
||||
}
|
||||
|
||||
return response('Loged in', 200);
|
||||
}
|
||||
}
|
||||
@@ -27,6 +27,7 @@ class UserResource extends JsonResource
|
||||
'email' => is_demo() ? obfuscate_email($this->email) : $this->email,
|
||||
'role' => $this->role,
|
||||
'two_factor_authentication' => $this->two_factor_secret ? true : false,
|
||||
'socialite_account' => $this->password ? false : true,
|
||||
'folders' => $this->folder_tree,
|
||||
'storage' => $this->storage,
|
||||
'created_at_formatted' => format_date($this->created_at, '%d. %B. %Y'),
|
||||
|
||||
Reference in New Issue
Block a user