This is most common method used to avoid interactive login & when you want to run an script in unattended mode. Let’s start by Registering an application in Azure.
Below are the steps to register an application in Azure AD:
- Sign in to Microsoft Entra admin center & expand Identity from left side blade panel.
- Next Click on Applications > App registrations, then on New registration
data:image/s3,"s3://crabby-images/abe86/abe8696a48564bbd211ae263e1063956c06c1095" alt=""
- Type any name you want to give, you can chose any name which is relevant to the app.
- We will use name MSGraph-CBA
- Select Accounts in any organizational directory (Any Azure AD directory – Multitenant) and personal Microsoft accounts & Register
data:image/s3,"s3://crabby-images/2fe26/2fe26cc9a53d8b69489cdc94e564ab24e3b11527" alt=""
- Next you will see application overview for MSGraph-CBA application.
- Make note of the Application (client ID) and Directory (tenant) ID, we need them on later point of time.
data:image/s3,"s3://crabby-images/a038f/a038f9bf9fae69492e0afcdb45d55ad133f1947d" alt=""
- Configure Azure application API permissions, we need to add API permissions to the MSGraph-CBA application we have created, by following the below steps:
- Click on API permissions > Add a permission
data:image/s3,"s3://crabby-images/1b64c/1b64cd891038d9ddfdf562729919a8d62fa52051" alt=""
- Select Microsoft APIs > Microsoft Graph
data:image/s3,"s3://crabby-images/41629/416290c66a189b31ac9e281345012c64fc1fc070" alt=""
Select Application permissions
data:image/s3,"s3://crabby-images/c390d/c390de3e0f045c7a66d1fa4c3301e6517612f59c" alt=""
- Search for user.read.all
- Expand User and select User.Read.All
- Click Add permissions
data:image/s3,"s3://crabby-images/51199/511995fdece5a705b501594f96771f757490ed52" alt=""
- Click on Grant admin consent
- Click Yes
data:image/s3,"s3://crabby-images/fd513/fd513a26e78cb1a064869fab143bad8b6de162bb" alt=""
- The status shows a green checkmark
data:image/s3,"s3://crabby-images/e84eb/e84eb42230411d01b142287be91fe33c08d14ce7" alt=""
Now that the application is registered and the API permissions are set, we can configure two methods for authentication; Certificate or Client Secret. But we will be focusing on Client Secret based method.
Client Secret !! Ok the last step, we need to add a Client Secret that the application uses to prove its identity when requesting a token from Entra ID.
- Click on Certificates & secrets
- Click Client secrets > New client secret
- Give it the description MS Graph CBA Secret
- Select the expires date 730 days (24 months)
- Click Add
data:image/s3,"s3://crabby-images/4dd8c/4dd8c909a161f0114bc7dbbeba04f5d896af5055" alt=""
- Make note Client Secret Value we need it in the next step when connecting to Microsoft Graph
data:image/s3,"s3://crabby-images/ecfbc/ecfbc1fce40c4a5767a9c86e297bf5c2acf58102" alt=""
7. Connect to Microsoft Graph with Client Secret
Start Windows PowerShell and create below three variables to connect to Microsoft Graph PowerShell with Client Secret:
- $ClientId
- $TenantId
- $ClientSecret
# Configuration $ClientId = "46d72c45-2bd9-4bfa-af71-7c77ef5a" $TenantId = "ddecfe46-14ad-4d69-81b1-d8081230" $ClientSecret = "vAb8Q~tsEYKjgSN_MyHwfuTKidiMk5hniuk87n" # Convert the client secret to a secure string $ClientSecretPass = ConvertTo-SecureString -String $ClientSecret -AsPlainText -Force # Create a credential object using the client ID and secure string $ClientSecretCredential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $ClientId, $ClientSecretPass # Connect to Microsoft Graph with Client Secret Connect-MgGraph -TenantId $tenantId -ClientSecretCredential $ClientSecretCredential
Now that you are connected to Microsoft Graph PowerShell, run the Get-MgUser cmdlet to get the list of users.
Get-MgUser
Great !! That’s all