Créer un client Microsoft Graph

Le client Microsoft Graph est conçu pour simplifier les appels à Microsoft Graph. Vous pouvez utiliser une seule instance de client pour la durée de vie de l’application. Pour plus d’informations sur l’ajout et l’installation du package client Microsoft Graph dans votre projet, consultez Installer le Kit de développement logiciel (SDK).

Les exemples de code suivants montrent comment créer une instance d’un client Microsoft Graph avec un fournisseur d’authentification dans les langues prises en charge. Le fournisseur d’authentification gère l’acquisition de jetons d’accès pour l’application. De nombreux fournisseurs d’authentification différents sont disponibles pour chaque langue et plateforme. Les différents fournisseurs d’authentification prennent en charge différents scénarios clients. Pour plus d’informations sur le fournisseur et les options appropriés pour votre scénario, consultez Choisir un fournisseur d’authentification.

var scopes = new[] { "User.Read" };

// Multi-tenant apps can use "common",
// single-tenant apps must use the tenant ID from the Azure portal
var tenantId = "common";

// Value from app registration
var clientId = "YOUR_CLIENT_ID";

// using Azure.Identity;
var options = new TokenCredentialOptions
{
    AuthorityHost = AzureAuthorityHosts.AzurePublicCloud
};

// Callback function that receives the user prompt
// Prompt contains the generated device code that use must
// enter during the auth process in the browser
Func<DeviceCodeInfo, CancellationToken, Task> callback = (code, cancellation) => {
    Console.WriteLine(code.Message);
    return Task.FromResult(0);
};

// https://docs.microsoft.com/dotnet/api/azure.identity.devicecodecredential
var deviceCodeCredential = new DeviceCodeCredential(
    callback, tenantId, clientId, options);

var graphClient = new GraphServiceClient(deviceCodeCredential, scopes);