uisits / laravel-oidc
Shibboleth OIDC driver for Laravel Socialite
Installs: 1 630
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 1
pkg:composer/uisits/laravel-oidc
Requires
- illuminate/filesystem: ^9.0|^10.0
- illuminate/support: ^9.0|^10.0
- laravel/socialite: ^5.10
Requires (Dev)
- laravel/pint: ^1.10
- mockery/mockery: ^1.5
- orchestra/testbench: ^7.24|^8.5
- pestphp/pest: ^1.0|^2.6
- pestphp/pest-plugin-laravel: ^1.0|^2.0
- phpunit/phpunit: ^9.0|^10.1
README
Laravel Shibboleth is a comprehensive authentication package for Laravel applications that provides seamless integration with Shibboleth and OpenID Connect (OIDC) authentication protocols. This package supports OIDC authentication methods, allowing flexible implementation based on your organization's requirements. It includes features for user authorization via Spatie/permissions package, token introspection, and a simple installation process to get your authentication system up and running quickly.
Usage:
-
Install the package:
composer require uisits/laravel-oidc -
Important: Install the package:
php artisan shibboleth:install
Running this command performs the following actions:
- Installs
spatie/laravel-permissionin your app.- Publish assets such as images, build assets to appropriate directories in your project.
- Publish the
shibboleth-oidc.phpconfig file to your config folder.- Publish migrations.
- Set environment variables in .env file (Check the
config/shibboleth.phpfile) - For Tri-Campus authentication, set the environment variables as per the config file and set
'tri-campus-provider' => true,inconfig/shibboleth-oidc.phpfile.
Migrate database
Run php artisan migrate
You can extend the roles and permissions functionality to add new roles or permissions using Spatie Permission package
Token Introspection
For token introspection using OIDC add the following middleware to the app/Http/Kernel.php file:
Under alias property:
'introspect' => \UisIts\Oidc\Http\Middleware\Introspect::class,
Now you can use the middleware on your protected route as such:
use UisIts\Oidc\Http\Middleware\Introspect; Route::middleware(['introspect'])->get('/introspect', function (Request $request) { dump($request->bearerToken()); dd(Introspect::getUserFromToken($request->bearerToken())); })->name('introspect');
Note: Below is the response received when you get a user from token
Introspect::getUserFromToken($request->bearerToken()); array:8 [▼ // routes/api.php:24 "sub" => "xyz@abc.org" "uisedu_is_member_of" => array:42 [▶] "uisedu_uin" => "123456789" "preferred_username" => "xyz" "given_name" => "John" "preferred_display_name" => "Doe, John" "family_name" => "Doe" "email" => "xyz@abc.org" ];
Code Style
You can use Laravel pint to automatically fix code styles.
./vendor/bin/pint
Testing
You can run the tests for the package using pest.
./vendor/bin/pest
Issues and Concerns
Please open an issue on the GitHub repository with detailed description and logs (if available).
In case of security concerns, please write an email to UIS ITS ADDS Team.