Правильный способ создания ConfidentialClientApplication, позволяющий повторить попытку для службы Windows - PullRequest
1 голос
/ 08 апреля 2019

Я пытаюсь создать службу Windows, которая позволит мне отправлять электронные письма от имени определенных пользователей.

Поздняя версия Graph Client позволяет указывать повторные попытки с использованием WithMaxRetry.К сожалению, нет хороших примеров, показывающих "лучшие практики" при создании ConfidentialClientApplication.

. В настоящее время я использую приведенный ниже код для отправки электронной почты без запроса логина и пароля:

const string clientId = "foo...99a0";
const string clientSecret = "#6A...cx#$a";
const string tenant = "1c...7";
const string azureAdInstance = "https://login.microsoftonline.com/{0}";
var authority = string.Format(CultureInfo.InvariantCulture, azureAdInstance, tenant);
string[] scopes = { "https://graph.microsoft.com/.default" };

var clientCredentials = new ClientCredential(clientSecret);
var confidentialClientApplication =
    new ConfidentialClientApplication(
        clientId,
        authority,
        "https://daemon",
        clientCredentials,
        null,
        new TokenCache());

var graphClient =
    new GraphServiceClient("https://graph.microsoft.com/v1.0", 
    new DelegateAuthenticationProvider(
        async(requestMessage) =>
        {
            var result = await confidentialClientApplication
                .AcquireTokenForClientAsync(scopes);
            requestMessage.Headers.Authorization = 
                new AuthenticationHeaderValue("bearer", result.AccessToken);
        }));

var recipients = new List<Recipient>
{
    new Recipient
    {
        EmailAddress = new Microsoft.Graph.EmailAddress
        {
            Address = "test@example.com"
        }
    }
};

var email = new Message
{
    Body = new ItemBody
    {
        Content = "Works fine!",
        ContentType = BodyType.Html,
    },
    Subject = "Test",
    ToRecipients = recipients
};

await graphClient
    .Users["sender@example.onmicrosoft.com"]
    .SendMail(email, true)
    .Request()
    .PostAsync();

но я не могу понять, как создать ConfidentialClientApplication на основе недавних изменений из Контекст запроса с опциями промежуточного программного обеспечения .

Поскольку я не смог найти пример обновленияу меня вопрос, как мне создать GraphServiceClient, чтобы иметь возможность отправлять электронные письма из Windows Service?

Это код сверху PR:

HttpProvider httpProvider = new HttpProvider();

var graphClient = new GraphServiceClient(appOnlyProvider, httpProvider);
graphClient.PerRequestAuthProvider = () => CreateDelegatedProvider();

var me = await graphClient.Me.Request()
    .WithScopes(string[] { "User.Read" }) // adds auth scopes
    .WithMaxRetry(5) // specifies maximum number of retries
    .WithPerRequestAuthProvider()
    .GetAsync();

Как мне принять его для моеготребование?Я новичок в Graph, поэтому хочу избежать плохого кода.

1 Ответ

1 голос
/ 10 апреля 2019

Одна из частей головоломки, которую, как мне кажется, вам не хватает, - это новая библиотека провайдеров аутентификации, которая находится здесь https://www.nuget.org/packages/Microsoft.Graph.Auth/0.1.0-preview, и здесь есть несколько примеров использования этих провайдеров аутентификации https://github.com/microsoftgraph/msgraph-sdk-dotnet-auth

Эта библиотека предоставляет набор поставщиков авторизации на основе желаемого потока OAuth2. В вашем случае вы должны использовать ClientCredentialsProvider вместо DelegateProvider.

Вам не нужно использовать PerRequestAuthProvider. Это необходимо только для сценариев, в которых вы хотите переключаться между разными потоками или разными приложениями в каждом вызове.

...