diff --git a/source/MailKitSimplified.Receiver/Extensions/MessageSummaryExtensions.cs b/source/MailKitSimplified.Receiver/Extensions/MessageSummaryExtensions.cs index 0d839c0..9e6c299 100644 --- a/source/MailKitSimplified.Receiver/Extensions/MessageSummaryExtensions.cs +++ b/source/MailKitSimplified.Receiver/Extensions/MessageSummaryExtensions.cs @@ -408,7 +408,7 @@ public static async Task AddFlagsAsync(this IMessageSummary messageSummary, Mess bool peekSourceFolder = !messageSummary.Folder.IsOpen; if (peekSourceFolder || messageSummary.Folder.Access != FolderAccess.ReadWrite) _ = await messageSummary.Folder.OpenAsync(FolderAccess.ReadWrite, cancellationToken).ConfigureAwait(false); - resultUid = await messageSummary.Folder.MoveToAsync(messageSummary.UniqueId, destination, cancellationToken).ConfigureAwait(false); + resultUid = await messageSummary.Folder.MoveToAsync(messageSummary.UniqueId, destination, CancellationToken.None).ConfigureAwait(false); if (peekSourceFolder) await messageSummary.Folder.CloseAsync(expunge: false, cancellationToken).ConfigureAwait(false); } diff --git a/source/MailKitSimplified.Receiver/Services/MailFolderClient.cs b/source/MailKitSimplified.Receiver/Services/MailFolderClient.cs index 41a485e..121c246 100644 --- a/source/MailKitSimplified.Receiver/Services/MailFolderClient.cs +++ b/source/MailKitSimplified.Receiver/Services/MailFolderClient.cs @@ -324,7 +324,7 @@ public async Task DeleteMessagesAsync(TimeSpan relativeOffset, SearchQuery bool peekSourceFolder = !source.IsOpen; // Beware, source must be opened after destination to keep it open _ = await OpenAsync(source, enableWrite: move, cancellationToken).ConfigureAwait(false); - resultUid = await source.MoveToAsync(messageUid, destination, cancellationToken).ConfigureAwait(false); + resultUid = await source.MoveToAsync(messageUid, destination, CancellationToken.None).ConfigureAwait(false); _logger.LogTrace("{0} {1} {2} to {3} in {4}.", _imapReceiver, messageUid, verb, resultUid, destination.FullName); if (peekSourceFolder && source.IsOpen) await source.CloseAsync(expunge: false, cancellationToken).ConfigureAwait(false); diff --git a/source/MailKitSimplified.Receiver/Services/MailFolderMonitor.cs b/source/MailKitSimplified.Receiver/Services/MailFolderMonitor.cs index 867dbcc..a4be835 100644 --- a/source/MailKitSimplified.Receiver/Services/MailFolderMonitor.cs +++ b/source/MailKitSimplified.Receiver/Services/MailFolderMonitor.cs @@ -48,12 +48,12 @@ public MailFolderMonitor(IImapReceiver imapReceiver, IOptions { - _logger.Log($"{_imapReceiver} message #{m.UniqueId} arrival processed."); + _logger.Log($"{_imapReceiver} message #{m.UniqueId} arrival processed.", LogLevel.Debug); return _completedTask; }; _messageDepartureMethod = (m) => { - _logger.Log($"{_imapReceiver} message #{m.UniqueId} departure processed."); + _logger.Log($"{_imapReceiver} message #{m.UniqueId} departure processed.", LogLevel.Debug); return _completedTask; }; } @@ -224,7 +224,7 @@ private async Task IdleStartAsync(CancellationToken cancellationToken = default) _mailFolder = await _imapReceiver.ConnectMailFolderAsync(cancellationToken).ConfigureAwait(false); _ = await _mailFolder.OpenAsync(FolderAccess.ReadOnly, cancellationToken).ConfigureAwait(false); var connectOption = _folderMonitorOptions.IgnoreExistingMailOnConnect ? "ignoring" : "fetching"; - _logger.Log($"{_imapReceiver} ({_mailFolder.Count}) idle monitor started, {connectOption} existing emails."); + _logger.Log($"{_imapReceiver} ({_mailFolder.Count}) idle monitor started, {connectOption} existing emails.", LogLevel.Information); _mailFolder.CountChanged += OnCountChanged; _mailFolder.MessageExpunged += OnMessageExpunged; @@ -297,19 +297,30 @@ private async ValueTask ReconnectAsync(CancellationToken cancellationToken = def { await LogDelayAsync(ex, "IMAP protocol exception").ConfigureAwait(false); } + catch (ImapCommandException ex) + { + await LogDelayAsync(ex, "IMAP command exception").ConfigureAwait(false); + } catch (SocketException ex) { await LogDelayAsync(ex, "IMAP socket exception").ConfigureAwait(false); } - - async Task LogDelayAsync(Exception exception, string exceptionType) + catch (IOException ex) { - var message = $"{exceptionType} during connection attempt #{++attemptCount}, backing off for {_folderMonitorOptions.EmptyQueueMaxDelayMs}ms. {_imapReceiver}."; + await LogDelayAsync(ex, "IMAP I/O exception").ConfigureAwait(false); + } + + async ValueTask LogDelayAsync(Exception exception, string exceptionType) + { + bool isBackoff = attemptCount > 0; + var backoff = isBackoff ? $", backing off for {_folderMonitorOptions.EmptyQueueMaxDelayMs}ms" : string.Empty; + var message = $"{exceptionType} during connection attempt #{++attemptCount}{backoff}. {_imapReceiver}."; if (attemptCount < _folderMonitorOptions.MaxRetries) - _logger.Log(exceptionType, LogLevel.Warning); + _logger.Log(message, LogLevel.Information); else - _logger.Log(exception, exceptionType, LogLevel.Error); - await Task.Delay(_folderMonitorOptions.EmptyQueueMaxDelayMs, cancellationToken).ConfigureAwait(false); + _logger.Log(exception, message, LogLevel.Error); + if (isBackoff) + await Task.Delay(_folderMonitorOptions.EmptyQueueMaxDelayMs, cancellationToken).ConfigureAwait(false); } } } @@ -345,7 +356,8 @@ private async ValueTask WaitForNewMessagesAsync(CancellationToken cancellationTo } catch (ImapProtocolException ex) { - var message = $"{ex.Message} Reconnecting and trying again."; + string error = ex.Message.TrimEnd(new char[] { ' ', '.' }); + var message = $"{error}. IMAP protocol exception, reconnecting and trying again."; if (ex.Message.StartsWith("Idle timeout")) _logger.Log(message, LogLevel.Debug); else