data:image/s3,"s3://crabby-images/c45d4/c45d4300fb57d01eac9181337a092af5bbdfedb2" alt=""
Good Moring everyone! So excited to inform you that, Microsoft Graph .Net SDK is available and it can be included in the Console Application by installing NuGet packages.
- Graph
- Graph.Beta
- Graph.Core
- Graph.Auth
Click here to learn more about Microsoft Graph SDK available for other platforms and languages.
Auth Provider Instance
For this console application, I have used Client credentials provider. The client credential flow enables service applications to run without user interaction. Access is based on the identity of the application. Click here to choose a Microsoft Graph authentication provider based on scenario.
List Groups Graph API – Get all the groups using Graph API
Permissions required
- Permission Type â Application
- Permissions – Group.Read.All, Directory.Read.All, Group.ReadWrite.All, Directory.ReadWrite.All
In this article, you will see how to perform the following tasks,
- Register an Application in Azure – Register an app in Azure AD and add the required permissions to access the Graph API
- Create and run the console application
Register an application in Azure
Register an application in Azure AD to access the Graph API.
- Navigate to Azure portal.
- Search for App Registrations. Click App Registrations as show below
data:image/s3,"s3://crabby-images/5b829/5b829fcaa6cbccca4fe7241114c755dbebf4ca4f" alt=""
3. Click on the “New Registration”.
4. Enter the Name and click Register.
data:image/s3,"s3://crabby-images/2a199/2a199b2dc3e774735955fe2fe656d1ea3c6067e0" alt=""
5. App registered successfully. In the left navigation, click API Permissions.
data:image/s3,"s3://crabby-images/48256/48256ab0f2a9082670fbce02b33e3ef7d5dcfe7d" alt=""
6. Click Add a permission.
7. Select Microsoft Graph API as shown below:
data:image/s3,"s3://crabby-images/0d32c/0d32c4e2fe8cfcfb077987b47f7667104acee6f7" alt=""
8. Click Application Permissions.
data:image/s3,"s3://crabby-images/85f04/85f04cab98793a884cfef10953a2df3c171c1378" alt=""
9. Select Read.All, Directory.Read.All, Group.ReadWrite.All, Directory.ReadWrite.All permission and click Add permissions.
10. Click Grant admin consent
data:image/s3,"s3://crabby-images/c9823/c9823d06434a1eb776c9e4865e87f1382268f1c7" alt=""
data:image/s3,"s3://crabby-images/275b3/275b3cc924110914455bed3f006baddc2433c483" alt=""
11. In the left navigation, click Overview. Copy the App (Client) ID and Directory (tenant) ID values. These values will be used in the console application for authentication.
data:image/s3,"s3://crabby-images/006ae/006aeaf748467d917e88e615cd780a55302bf789" alt=""
12. In the left navigation, click Certificates & Secrets. Click New Client Secret.
data:image/s3,"s3://crabby-images/c2801/c28018f5b4d880bf2748fd5642bb0ef124ae9984" alt=""
13. Enter the description and click Add.
data:image/s3,"s3://crabby-images/21e3f/21e3f97981908a88de6180020782ceae94ccaede" alt=""
14. Copy the secret value which will be used in console application for authentication.
Create and run the Console Application
- Open Visual Studio 2019 and create a Console Application (.Net Framework).
- Install the following NuGet Packages either using Package Manager UI in Visual Studio or the Package Manager Console.
Install-Package Microsoft.Graph
Install-Package Microsoft.Graph.Auth -IncludePrerelease
3. Open Program.cs and add the following code:
using Microsoft.Graph;
using Microsoft.Graph.Auth;
using Microsoft.Identity.Client;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace GraphAPIConsole
{
class Program
{
static void Main(string[] args)
{
try
{
getUsersAsync().GetAwaiter().GetResult();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
Console.ReadLine();
}
public async static Task getUsersAsync()
{
var clientId = "91110348-f503-477f-acad-73fdcf2ec370";
var tenantId = "1cb1e777-67af-48e4-88cb-e3865bb7085b";
var clientSecret = "b7qqTV0.0PceiCC0~5.Nr39joWbe.nOV.d";
IConfidentialClientApplication confidentialClientApplication = ConfidentialClientApplicationBuilder
.Create(clientId)
.WithTenantId(tenantId)
.WithClientSecret(clientSecret)
.Build();
ClientCredentialProvider authProvider = new ClientCredentialProvider(confidentialClientApplication);
GraphServiceClient graphClient = new GraphServiceClient(authProvider);
var groups = await graphClient.Groups.Request().Select(x => new { x.Id, x.DisplayName }).GetAsync();
foreach (var group in groups)
{
Console.WriteLine($"{group.DisplayName}, {group.Id}");
}
}
}
}
4. Press F5 and check the console.
That’s it!