Есть ли способ удалить сообщение с помощью клиентской библиотеки Microsoft-Graph C #? - PullRequest
0 голосов
/ 29 сентября 2018

Я использую клиент Microsoft Graph в своем проекте C # .net, и я заметил, что элемент сообщения не предоставляет какой-либо метод для удаления сообщения.

Я пытался

client.Me.Messages[mail.Id].Delete()

ИЯ вижу, что метода Delete нет.

Что мне делать?

Ответы [ 3 ]

0 голосов
/ 29 сентября 2018

Я использовал это:

public static async Task DeleteEmail(string emailId)
        {
            TokenCache tokens = TokenCacheHelper.GetUserCache();
            PublicClientApplication clientApp = new PublicClientApplication(secret, RootAuthUri, tokens);

            using (HttpClient c = new HttpClient())
            {
                string requestURI = RootUri + "/me/messages/" + emailId;

                HttpRequestMessage request = new HttpRequestMessage(HttpMethod.Delete, requestURI);
                //Authentication token
                request.Headers.Authorization = new AuthenticationHeaderValue("Bearer", await GetTokenAsync(clientApp));

                HttpResponseMessage response = await c.SendAsync(request);
                string responseString = await response.Content.ReadAsStringAsync();
            }

        }


private static async Task<string> GetTokenAsync(PublicClientApplication app)
        {
            AuthenticationResult result = null;
            string[] scopes = { "User.Read", "Mail.ReadWrite" };
            try
            {

                // Get the token from the cache.
                result = await app.AcquireTokenSilentAsync(scopes, (await app.GetAccountsAsync()).FirstOrDefault());
                return result.AccessToken;
            }
            catch (MsalUiRequiredException ex)
            {
                // A MsalUiRequiredException happened on AcquireTokenSilentAsync. 
                // This indicates you need to call AcquireTokenAsync to acquire a token
                Debug.WriteLine($"MsalUiRequiredException: {ex.Message}");

                try
                {
                    // Dialog opens for user.
                    result = await app.AcquireTokenAsync(scopes);
                    return result.AccessToken;
                }
                catch (MsalException msalex)
                {
                    Debug.WriteLine($"Error Acquiring Token:{System.Environment.NewLine}{msalex}");
                    return null;
                }
            }
            catch (Exception ex)
            {
                Debug.WriteLine($"Error Acquiring Token Silently:{System.Environment.NewLine}{ex}");
                return null;
            }
        }

static class TokenCacheHelper
    {

        /// <summary>
        /// Get the user token cache
        /// </summary>
        /// <returns></returns>
        public static TokenCache GetUserCache()
        {
            if (usertokenCache == null)
            {
                usertokenCache = new TokenCache();
                usertokenCache.SetBeforeAccess(BeforeAccessNotification);
                usertokenCache.SetAfterAccess(AfterAccessNotification);
            }
            return usertokenCache;
        }

        static TokenCache usertokenCache;

        /// <summary>
        /// Path to the token cache
        /// </summary>
        public static readonly string CacheFilePath = System.Reflection.Assembly.GetExecutingAssembly().Location + ".msalcache.bin";

        private static readonly object FileLock = new object();

        public static void BeforeAccessNotification(TokenCacheNotificationArgs args)
        {

            lock (FileLock)
            {
                args.TokenCache.Deserialize(File.Exists(CacheFilePath)
                    ? ProtectedData.Unprotect(File.ReadAllBytes(CacheFilePath),
                                              null,
                                              DataProtectionScope.CurrentUser)
                    : null);
            }
        }

        public static void AfterAccessNotification(TokenCacheNotificationArgs args)
        {
            // if the access operation resulted in a cache update
            if (args.TokenCache.HasStateChanged)
            {
                lock (FileLock)
                {
                    // reflect changesgs in the persistent store
                    File.WriteAllBytes(CacheFilePath,
                                       ProtectedData.Protect(args.TokenCache.Serialize(),
                                                             null,
                                                             DataProtectionScope.CurrentUser)
                                      );
                    // once the write operationtakes place restore the HasStateChanged bit to filse
                    args.TokenCache.HasStateChanged = false;
                }
            }
        }
    }
0 голосов
/ 30 сентября 2018

Вам необходимо создать объект Request, который содержит метод DeleteAsync():

graphServiceClient
    .Me
    .Messages["your message id"]
    .Request()
    .DeleteAsync();

На основе собственного кода:

await client
  .Me
  .Messages[mail.Id]
  .Request()
  .DeleteAsync();
0 голосов
/ 29 сентября 2018

Я не использовал эту клиентскую библиотеку, но я посмотрел на ее репозиторий Github .Из документов хранилища не очень ясно, как удалить сообщение, но документы для MS Graph указывают, что есть способ удалить сообщение через его API:

https://developer.microsoft.com/en-us/graph/docs/api-reference/v1.0/api/message_delete

На основев клиентском репо, похоже, вам просто нужно создать MessageRequest и вызвать его метод DeleteAsync().

Класс MessageRequest принимает URL-адрес запроса, который предположительно будет URL-адресом сообщения (что-то вроде /me/messages/{id}).

...