How to use Microsoft Graph API with Laravel

By Dillon Smart · · · 0 Comments

Microsoft Graph API with Laravel

Microsoft Graph is a gateway to data and intelligence within Microsoft 365. Microsoft Graph is great to build apps for organizations and consumers using the vast amount of data stored in Microsoft 365. In this post, we are going to integrate with Microsoft Graph API in Laravel to get all users assigned to your tenant.

You will need to have already created an Azure App Registration to follow along with this post. If you are unsure how to create an Azure App Registration, take a look at this Quickstart Guide by Microsoft which will take you through the process.

Microsoft Graph API

Microsoft has created an open-source SDK for PHP on GitHub. Install the SDK using Composer.

composer require microsoft/microsoft-graph

Or you can edit your composer.json file: 

{
    "require": {
        "microsoft/microsoft-graph": "^1.57.0"
    }
}

To make requests to Microsoft Graph API we will be using GuzzleHTTP client. It’s a great package that makes it easy to send HTTP requests and integrate with web services. Also, Guzzle comes installed with Laravel, which is great. 

I have created a Trait to help with this example. To install the Trait, under the App directory, create a new empty directory called “Integrations“. Download the Trait from Gist, and place the file within the App/Integrations directory. 

Setup Microsoft Graph API in Laravel

To get started setting up Microsoft Graph API with Laravel, keys to the .env file in the root of your Laravel application.

MS_TENANT_ID=
MS_CLIENT_ID=
MS_CLIENT_SECRET=
MS_GRAPH_API_VERSION=v1.0

How to find your Microsoft Tenant ID

To find your Microsoft Tenant ID, log in to Microsoft Azure. From the menu, select Azure Active Directory > Overview. You can find the Tenant ID within the Overview tab. 

How to find your Microsoft Azure App Client ID and Client Secret

To find your Client ID, from the same menu in Azura Active Directory, select App Registrations > Your App > and Client Secrets, which can be found under Essentials. The Client Secret for your Azure App is only available at the creation of the app and cannot be retrieved afterward. 

Setup Azure app permissions

We will be getting a list of users in the tenant. The permissions required to make this API request are Application Permissions.

  • User.Read.All
Admin consent on your Microsoft 365 tenant is required for this permission

List all users using Microsoft Graph API

To help with Microsoft Graph in Laravel, I created a simple Trait to connect and list users within your Microsoft 365 tenant. This can be found on GitHub.

Use App\Integrations\MicrosoftGraph;

Return MicrosoftGraph::users();

You can get familiar with Microsoft Graph API by using Graph Explorer created by Microsoft to test different endpoints and responses.

Was this post helpful? Please leave a comment below.

LaravelMicrosoftMicrosoft Graph APIPHP

0 Comment

Was this helpful? Leave a comment!

This site uses Akismet to reduce spam. Learn how your comment data is processed.

PHP Numeric Literal Separator

Updated 14th December 2023

First introduced in PHP 7.4, the Numeric Literal Separator in PHP makes large integers within your code easy to read. Naturally, we find it easier to read number which are grouped, for example, 1,650,000. Using the numeric literal separator in PHP Since PHP 7.4, we can now use numbers like this: Adding an underscore between

Laravel Undefined Constant header_x_forwarded_all after upgrading Laravel version

Updated 1st January 2024

Upgrading to a newer version of Laravel can be exciting, but it can also be nerve racking if you are unfamiliar with the changes in newer version, especially if your upgrading multiple times. Have you received an “Undefined Constant” error in Laravel after upgrading? In this post, I will help you understand the changes under

Laravel php artisan make:auth command not defined

Updated 11th August 2022

Laravel 6.0 LTS came with a lot of changes to the framework, apart from moving the the new Semantic Versioning, Laravels famous php artisan make:auth command was dropped. php artisan make:auth Before the Laravel make:auth command would create all the Migrations, Models, Controllers and Routes needed to easily setup an authenticatable application in seconds. However,