joeystowe / ms-graph-api
Laravel MS Graph API
Requires
- php: ^8.1
- laravel/socialite: ^5.11
- socialiteproviders/microsoft-azure: ^5.1
Requires (Dev)
- orchestra/testbench: ^6.0
- phpunit/phpunit: ^9.0
This package is auto-updated.
Last update: 2025-03-25 23:36:38 UTC
README
This adds helper methods to call the MS Graph API and installs a middleware/routes to implement MS Authentication
Installation
You can install the package via composer:
composer require joeystowe/ms-graph-api:^1.0
Usage
SSO Authentication
The plugin installs a middleware ('ms-auth') and 2 routes (/auth/callback and /logout). To protect a route with authentication you must apply the middleware to the desired routes and set your env variables
Apply middleware example
Route::get('/', function () { return view('welcome'); })->middleware('ms-auth');
Or use middleware groups
Route::middleware('ms-auth')->group(function () { Route::get('/admin/dashboard', 'AdminController@dashboard'); });
Caution
You can not add the middleware globally or in the web group because the auth callback method needs to be publicy accessible
Set you .env variables
// services.php ... 'azure' => [ 'client_id' => env('AZURE_CLIENT_ID'), 'client_secret' => env('AZURE_CLIENT_SECRET'), 'tenant' => env('AZURE_TENANT_ID'), 'redirect' => env('AZURE_REDIRECT_URI'), ], ...
// .env ... AZURE_CLIENT_ID=<YOUR CLIENT ID> AZURE_CLIENT_SECRET=<YOUR CLIENT SECRET> AZURE_REDIRECT_URI=http://localhost:8080/auth/callback AZURE_TENANT_ID=<YOUR TENANT ID> ...
Accessing the user
The ms-auth middleware sets the following scoped session values
session()->put('ms:user', (object)$user); session()->put('ms:username', $user['bannerUsername']); session()->put('ms:email', $user['email']); session()->put('ms:principalName', $user['principalName']); session()->put('ms:id', $user['id']); session()->put('ms:session-token', $user['token']);
You can reference these directly or you can use the LoggedInUser helper class:
// Returns an object with the following properties set Joeystowe\MsGraphApi\LoggedInUser::user(); { "id" => "1111-2222-33333-44444" //ms user id "name" => "John Doe" //Full Name "email" => "john.doe@eng.ua.edu" "principalName" => "jdoe@ua.edu" "bannerUsername" => "jdoe" "token" => "1111-2222-3333-4444" //ms session token } //Fetch users properties as an array Joeystowe\MsGraphApi\LoggedInUser::userArray(); //Fetch users properties as a pre-filled User model Joeystowe\MsGraphApi\LoggedInUser::userModel(); //Fetch a single user attribute (throws exception is property is not found) Joeystowe\MsGraphApi\LoggedInUser::userAttribute('principalName') //returns "jdoe@ua.edu"
Logging Out
Simply hit the '/logout' route to log the user out. After logging out from MS the user will be redirected to a '/postLogout' page. Be sure to set your APP_URL correctly so the "log back in" url will work correctly.
You will also need to publish the assets for the postLogout page to be fully functional:
php artisan vendor:publish --tag=assets --ansi --force
Calling Graph API
The plugin also gives you helper methods to call the MS graph API
Logged In User Methods
Groups
$user = Joeystowe\MsGraphApi\LoggedInUser::user(); //resolve instance of current user API $graphApi = app(Joeystowe\MsGraphApi\MsGraphCurrentUserApi::class, ['token' => $user->token]); //Get all user's groups, returns array of groups $graphApi->groups() //Check if a user is in a specific group, returns boolean $graphApi->inGroup(groupId: $groupIdToCheck)
Changelog
Please see CHANGELOG for more information what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.