agriserv / sso
A package to integrate with Agriserv SSO.
Requires
- guzzlehttp/guzzle: ^7.0
- laravel/framework: ^8.0|^9.0|^10.0|^11.0|^12.0
This package is auto-updated.
Last update: 2025-06-06 08:30:49 UTC
README
Easily integrate your application with AgriServ SSO.
Installation Steps
1. Install the Package
Add the package to your Laravel application via Composer:
composer require agriserv/sso
2. Publish the Configuration and Controller
php artisan vendor:publish --provider="Agriserv\SSO\AgriservSsoServiceProvider" --tag="config"
This will create a config/sso.php file in your application.
php artisan vendor:publish --provider="Agriserv\SSO\AgriservSsoServiceProvider" --tag="sso-controller"
This will publish a controller to your application at: app/Http/Controllers/LoginSsoController.php.
3. Set Up an Application in AgriServ SSO
Ask the AgriServ SSO Administrator to generate an application for you. Provide them with the following details: CALL_BACK_URI: Your application's callback URL.
4. Configure the .env File
Add the following variables to your .env file:
SSO_BASE_URI="https://sso.agriserv.sa" SSO_ID="APP_ID" # Replace with the Application ID provided by AgriServ Admin SSO_SECRET_KEY="SECRET_KEY" # Replace with the Secret Key provided by AgriServ Admin SSO_REDIRECT_URI="CALL_BACK_URI" # Replace with your callback URL
5. Override the handleUserInfo Method
Once the LoginSsoController is published, you can override the handleUserInfo method to handle the logic for processing user data from SSO.
Example: Handling User Info
Open the app/Http/Controllers/LoginSsoController.php
file, and modify the handleUserInfo
method as needed:
<?php namespace App\Http\Controllers; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Log; class LoginSsoController extends \Agriserv\SSO\Http\Controllers\SsoController { /** * Handle the fetched user info. * * @param array $userInfo * @return mixed */ protected function handleUserInfo(array $userInfo) { $userModel = app(config('sso.user_model')); // Create or update the user $user = $userModel::updateOrCreate([ 'sso_id' => $userData['sso_id'] ?? $userInfo['id'], ], $userData); // Dynamically assign roles $this->syncUserRoles($user, $userInfo['roles']); // Log the user in Auth::login($user); // Redirect after login return redirect()->to(session('previousUrl') ?? '/'); } /** * Sync roles with the local user. */ private function syncUserRoles($user, array $roles) { if (method_exists($user, 'syncRoles')) { try { $user->syncRoles($roles); } catch (\Exception|\Throwable $e) { Log::warning("Failed to sync roles: " . $e->getMessage()); } } } }
6. Test Your Integration
Test your SSO integration by navigating to the SSO login route (e.g., /auth/sso
). Ensure users are logged in and synchronized correctly with your application.
7. Add Middleware for the protected routes
Route::middleware('sso_auth')->group(function () {
// Add routes
}