Init
This commit is contained in:
109
app/Http/Controllers/Auth/SocialiteController.php
Normal file
109
app/Http/Controllers/Auth/SocialiteController.php
Normal file
@@ -0,0 +1,109 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Auth;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Illuminate\Support\Str;
|
||||
use Laravel\Socialite\Facades\Socialite;
|
||||
|
||||
class SocialiteController extends Controller
|
||||
{
|
||||
/**
|
||||
* Suggest a username based on social profile.
|
||||
*/
|
||||
protected function suggestUsername($socialUser): string
|
||||
{
|
||||
return Str::slug(
|
||||
$socialUser->getNickname() ?? explode('@', $socialUser->getEmail())[0],
|
||||
'_'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get enabled providers from config.
|
||||
*/
|
||||
protected function getEnabledProviders(): array
|
||||
{
|
||||
return collect(config('auth-ui.providers', []))
|
||||
->filter(fn ($provider) => $provider['enabled'] ?? false)
|
||||
->keys()
|
||||
->all();
|
||||
}
|
||||
|
||||
/**
|
||||
* Redirect the user to the provider authentication page.
|
||||
*/
|
||||
public function redirect(string $provider): RedirectResponse
|
||||
{
|
||||
if (! in_array($provider, $this->getEnabledProviders())) {
|
||||
abort(404, 'Provider not enabled');
|
||||
}
|
||||
|
||||
return Socialite::driver($provider)->redirect();
|
||||
}
|
||||
|
||||
/**
|
||||
* Obtain the user information from provider.
|
||||
*/
|
||||
public function callback(string $provider): RedirectResponse
|
||||
{
|
||||
if (! in_array($provider, $this->getEnabledProviders())) {
|
||||
abort(404, 'Provider not enabled');
|
||||
}
|
||||
|
||||
try {
|
||||
$socialUser = Socialite::driver($provider)->user();
|
||||
} catch (\Exception $e) {
|
||||
return redirect()->route('login')->withErrors([
|
||||
'email' => 'Unable to authenticate with '.$provider.'. Please try again.',
|
||||
]);
|
||||
}
|
||||
|
||||
// Find existing user by provider ID or email
|
||||
$user = User::where('email', $socialUser->getEmail())->first();
|
||||
|
||||
if (! $user) {
|
||||
// Create new user if registration is enabled
|
||||
if (! config('auth-ui.features.registration')) {
|
||||
return redirect()->route('login')->withErrors([
|
||||
'email' => 'Registration is disabled. Please contact an administrator.',
|
||||
]);
|
||||
}
|
||||
|
||||
$name = $socialUser->getName() ?? $socialUser->getNickname() ?? 'User';
|
||||
$nameParts = explode(' ', $name, 2);
|
||||
$suggestedUsername = $this->suggestUsername($socialUser);
|
||||
|
||||
// Check if username is already taken
|
||||
if (User::where('username', $suggestedUsername)->exists()) {
|
||||
// Store social data in session and redirect to complete profile
|
||||
session()->put('socialite_user', [
|
||||
'email' => $socialUser->getEmail(),
|
||||
'first_name' => $nameParts[0],
|
||||
'last_name' => $nameParts[1] ?? '',
|
||||
'suggested_username' => $suggestedUsername,
|
||||
'provider' => $provider,
|
||||
]);
|
||||
|
||||
return redirect()->route('auth.complete-profile');
|
||||
}
|
||||
|
||||
$user = User::create([
|
||||
'username' => $suggestedUsername,
|
||||
'first_name' => $nameParts[0],
|
||||
'last_name' => $nameParts[1] ?? '',
|
||||
'email' => $socialUser->getEmail(),
|
||||
'password' => Hash::make(Str::random(24)),
|
||||
'email_verified_at' => now(),
|
||||
]);
|
||||
}
|
||||
|
||||
Auth::login($user, remember: true);
|
||||
|
||||
return redirect()->intended(config('auth-ui.redirects.login', '/'));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user