Bring up-to-date and simple Socialite support to your Filament admin panel with this plugin. Adds OAuth buttons to your login page.
โจ Key Features:
Perfect for: Laravel and Filament users seeking straightforward OAuth integration.
[!WARNING] Socialment v4 is currently in beta. Please report any issues you encounter.
โ ๏ธ Caution is advised if you choose to use this package in production.
๐ Socialment v3 support is still available on the 3.x branch.
๐ฎ Demo Project: ChrisReedIO/Socialment-Demo
Not yet updated to v4.
This package extends Laravel Socialite. Socialite currently supports authentication via Facebook, Twitter, LinkedIn, Google, GitHub, GitLab, and Bitbucket out of the box.
๐ Useful Links:
Install the package via Composer:
composer require chrisreedio/socialment
Perform the initial setup:
php artisan socialment:install
Edit your panel's custom theme.css and add:
@source '../../../../vendor/chrisreedio/socialment/resources';
[!IMPORTANT] Don't skip this step! Without it, the plugin styling won't be applied.
If you don't have a custom theme, you should create one before adding the source.
To learn more about creating a custom theme, see the Filament documentation.
Include the plugin in your panel configuration:
// In your PanelProvider (e.g., app/Providers/Filament/AdminPanelProvider.php)
$panel
->plugins([
// ... Other Plugins
\ChrisReedIO\Socialment\SocialmentPlugin::make(),
])
You need to configure OAuth providers in two places:
Choose from stock providers or community providers.
Example: GitHub (Stock Provider)
Add to config/services.php:
'github' => [
'client_id' => env('GITHUB_CLIENT_ID'),
'client_secret' => env('GITHUB_CLIENT_SECRET'),
'redirect' => env('GITHUB_REDIRECT_URI'),
],
Example: Azure Active Directory (Community Provider)
Install the provider package:
composer require socialiteproviders/microsoft-azure
Add to config/services.php:
'azure' => [
'client_id' => env('AZURE_CLIENT_ID'),
'client_secret' => env('AZURE_CLIENT_SECRET'),
'redirect' => env('AZURE_REDIRECT_URI'),
'tenant' => env('AZURE_TENANT_ID'),
'proxy' => env('PROXY'), // optional
],
Add to app/Providers/EventServiceProvider.php:
protected $listen = [
// ... other listeners
\SocialiteProviders\Manager\SocialiteWasCalled::class => [
// ... other providers
\SocialiteProviders\Azure\AzureExtendSocialite::class.'@handle',
],
];
Add providers to your panel configuration:
$panel->plugins([
\ChrisReedIO\Socialment\SocialmentPlugin::make()
->registerProvider('github', 'fab-github', 'GitHub')
->registerProvider('azure', 'fab-microsoft', 'Azure Active Directory'),
]);
Parameters:
provider_name - Matches your config/services.php keyicon - Font Awesome brand icon (search icons)label - Display name for the button[!NOTE] URL Pattern:
https://yourdomain.com/login/{provider}/callbackExamples:
- GitHub:
https://yourdomain.com/login/github/callback- Azure:
https://yourdomain.com/login/azure/callback
Control when OAuth buttons appear:
$panel->plugins([
\ChrisReedIO\Socialment\SocialmentPlugin::make()
->visible(fn () => config('app.env') !== 'production')
]);
Set a custom route for failed logins:
$panel->plugins([
\ChrisReedIO\Socialment\SocialmentPlugin::make()
->loginRoute('filament.staff.auth.login')
// Or use a closure
->loginRoute(fn () => SomeFunctionToGetTheRouteName())
]);
Add custom logic before/after login:
// In a service provider's boot() method
use ChrisReedIO\Socialment\Models\ConnectedAccount;
use ChrisReedIO\Socialment\Facades\Socialment;
use ChrisReedIO\Socialment\Exceptions\AbortedLoginException;
public function boot(): void
{
// Pre-login hook
Socialment::preLogin(function (ConnectedAccount $connectedAccount) {
// Custom pre-login logic here
Log::info('User about to login', ['provider' => $connectedAccount->provider]);
});
// Post-login hook
Socialment::postLogin(function (ConnectedAccount $connectedAccount) {
Log::info('User logged in with ' . $connectedAccount->provider . ' account', [
'user' => $connectedAccount->user->email,
]);
});
}
Use the pre-login hook to verify user access via an external service before allowing authentication:
use ChrisReedIO\Socialment\Models\ConnectedAccount;
use ChrisReedIO\Socialment\Facades\Socialment;
use ChrisReedIO\Socialment\Exceptions\AbortedLoginException;
use Illuminate\Support\Facades\Http;
public function boot(): void
{
// Check to see of the use has sufficient permissions to access the application.
Socialment::preLogin(function (ConnectedAccount $connectedAccount) { // Sets up a hook on the 'plugin' itself
// Handle custom post login logic here.
$groups = (new GraphConnector($connectedAccount->token))
->users()->groups($connectedAccount->provider_user_id);
// Grab the results from the lazy collection
$groupNames = collect($groups->pluck('displayName')->all());
// Filter the list of system roles by the groups the user is a member of in Azure AD
$roles = Role::all()->filter(fn ($role) => $groupNames->contains($role->sso_group));
// Sync the user's roles with the filtered list
$connectedAccount->user->roles()->sync($roles);
// If the user has no roles, abort the login
if ($connectedAccount->user->roles->isEmpty()) {
throw new AbortedLoginException('You are not authorized to access this application.');
}
});
}
Publish and customize the config:
php artisan vendor:publish --tag="socialment-config"
Key config options:
return [
'view' => [
'prompt' => 'Or Login Via', // Text above provider buttons
'providers-list' => 'socialment::providers-list', // Custom view
],
'models' => [
'user' => '\\App\\Models\\User', // Custom user model
],
];
Publish and customize the views:
php artisan vendor:publish --tag="socialment-views"
Views will be copied to resources/views/vendor/socialment/.
This package uses Blade Font Awesome by Owen Voke.
Search for brand icons on the Font Awesome Website.
[!CAUTION] ๐งช Experimental Feature
This feature is still in development and highly experimental. Expect breaking changes and bugs. Use at your own risk.
This feature may be spun off into a separate package in the future.
Enable shared authentication between your Filament backend and Single Page Application frontend. Both must be hosted on the same domain.
1. Add SPA routes to routes/web.php:
// Pass your SPA route prefix (default: 'spa')
Route::spaAuth('dashboard');
Route::middleware('auth:sanctum')
->prefix('dashboard')
->as('dashboard.')
->group(function () {
// Your SPA API routes
});
2. Update CORS configuration in config/cors.php:
'paths' => [
// ... Other Paths
'spa/*', // Or your custom prefix
],
'supports_credentials' => true,
3. Set environment variables:
SANCTUM_STATEFUL_DOMAINS="https://frontend.localhost:3000,https://backend.localhost"
SESSION_DOMAIN=".localhost"
SESSION_SECURE_COOKIE=true
SPA_URL="https://frontend.localhost:3000"
Key points:
SESSION_DOMAIN should start with a period (.localhost)SPA_URL points to your frontend applicationUpdate the config file:
'spa' => [
'home' => env('SPA_URL', 'http://localhost:3000'),
'responses' => [
// Custom JsonResource for API responses
// 'me' => \App\Http\Resources\UserResponse::class,
],
],
[!NOTE] Tests have yet to be written for this package. They are on the TODO list. PRs welcome!
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.
How can I help you explore Laravel packages today?