56 lines
1.8 KiB
C#
56 lines
1.8 KiB
C#
|
using Azure.Identity;
|
|||
|
using Microsoft.Extensions.Configuration;
|
|||
|
using Microsoft.Graph;
|
|||
|
using Microsoft.Identity.Client;
|
|||
|
using O365Clinic.Function.Webhooks.Models;
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.Linq;
|
|||
|
using System.Text;
|
|||
|
using System.Threading.Tasks;
|
|||
|
|
|||
|
namespace O365Clinic.Function.Webhooks.Helpers
|
|||
|
{
|
|||
|
public class GraphAuthenticationManager
|
|||
|
{
|
|||
|
|
|||
|
public static GraphServiceClient GetAuthenticatedGraphClient(AzureFunctionSettings config)
|
|||
|
{
|
|||
|
|
|||
|
try
|
|||
|
{
|
|||
|
// The client credentials flow requires that you request the
|
|||
|
// /.default scope, and pre-configure your permissions on the
|
|||
|
// app registration in Azure. An administrator must grant consent
|
|||
|
// to those permissions beforehand.
|
|||
|
var scopes = new[] { "https://graph.microsoft.com/.default" };
|
|||
|
|
|||
|
// Values from app registration
|
|||
|
var clientId = config.ClientId;
|
|||
|
var tenantId = config.TenantId;
|
|||
|
var clientSecret = config.ClientSecret;
|
|||
|
|
|||
|
// using Azure.Identity;
|
|||
|
var options = new ClientSecretCredentialOptions
|
|||
|
{
|
|||
|
AuthorityHost = AzureAuthorityHosts.AzurePublicCloud,
|
|||
|
};
|
|||
|
|
|||
|
// https://learn.microsoft.com/dotnet/api/azure.identity.clientsecretcredential
|
|||
|
var clientSecretCredential = new ClientSecretCredential(
|
|||
|
tenantId, clientId, clientSecret, options);
|
|||
|
|
|||
|
var graphClient = new GraphServiceClient(clientSecretCredential, scopes);
|
|||
|
|
|||
|
return graphClient;
|
|||
|
}
|
|||
|
catch (Exception)
|
|||
|
{
|
|||
|
|
|||
|
throw;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
}
|