/// <summary> /// Releases the unmanaged resources used by the <see cref="MailService"/> and /// optionally releases the managed resources. /// </summary> /// <remarks> /// Releases the unmanaged resources used by the <see cref="MailService"/> and /// optionally releases the managed resources. /// </remarks> /// <param name="disposing"><c>true</c> to release both managed and unmanaged resources; /// <c>false</c> to release only the unmanaged resources.</param> protected virtual void Dispose(bool disposing) { if (disposing) { ProtocolLogger.Dispose(); } }
public static void Main(string[] args) { var logger = new ProtocolLogger (Console.OpenStandardError ()); using (var client = new ImapClient (logger)) { var credentials = new NetworkCredential ("*****@*****.**", "password"); var uri = new Uri ("imaps://imap.gmail.com"); client.Connect (uri); // Remove the XOAUTH2 authentication mechanism since we don't have an OAuth2 token. client.AuthenticationMechanisms.Remove ("XOAUTH2"); client.Authenticate (credentials); client.Inbox.Open (FolderAccess.ReadOnly); // keep track of the messages var messages = client.Inbox.Fetch (0, -1, MessageSummaryItems.Full | MessageSummaryItems.UniqueId).ToList (); // connect to some events... client.Inbox.MessagesArrived += (sender, e) => { // Note: the CountChanged event will fire when new messages arrive in the folder. var folder = (ImapFolder) sender; // New messages have arrived in the folder. Console.WriteLine ("{0}: {1} new messages have arrived.", folder, e.Count); // Note: your first instict may be to fetch these new messages now, but you cannot do // that in an event handler (the ImapFolder is not re-entrant). }; client.Inbox.MessageExpunged += (sender, e) => { var folder = (ImapFolder) sender; if (e.Index < messages.Count) { var message = messages[e.Index]; Console.WriteLine ("{0}: expunged message {1}: Subject: {2}", folder, e.Index, message.Envelope.Subject); // Note: If you are keeping a local cache of message information // (e.g. MessageSummary data) for the folder, then you'll need // to remove the message at e.Index. messages.RemoveAt (e.Index); } else { Console.WriteLine ("{0}: expunged message {1}: Unknown message.", folder, e.Index); } }; client.Inbox.MessageFlagsChanged += (sender, e) => { var folder = (ImapFolder) sender; Console.WriteLine ("{0}: flags for message {1} have changed to: {2}.", folder, e.Index, e.Flags); }; Console.WriteLine ("Hit any key to end the IDLE loop."); using (var done = new CancellationTokenSource ()) { var thread = new Thread (IdleLoop); thread.Start (new IdleState (client, done.Token)); Console.ReadKey (); done.Cancel (); thread.Join (); } if (client.Inbox.Count > messages.Count) { Console.WriteLine ("The new messages that arrived during IDLE are:"); foreach (var message in client.Inbox.Fetch (messages.Count, -1, MessageSummaryItems.Full | MessageSummaryItems.UniqueId)) Console.WriteLine ("Subject: {0}", message.Envelope.Subject); } client.Disconnect (true); } }
public void TestArgumentExceptions () { var enumeratedRights = new [] { AccessRight.OpenFolder, AccessRight.CreateFolder }; Assert.Throws<ArgumentNullException> (() => new AccessControl (null)); Assert.Throws<ArgumentNullException> (() => new AccessControl (null, "rk")); Assert.Throws<ArgumentNullException> (() => new AccessControl (null, enumeratedRights)); Assert.Throws<ArgumentNullException> (() => new AccessControl ("name", (string) null)); Assert.Throws<ArgumentNullException> (() => new AccessControl ("name", (IEnumerable<AccessRight>) null)); Assert.Throws<ArgumentNullException> (() => new AccessControlList (null)); Assert.Throws<ArgumentNullException> (() => new AccessRights ((IEnumerable<AccessRight>) null)); Assert.Throws<ArgumentNullException> (() => new AccessRights ((string) null)); var rights = new AccessRights (); Assert.Throws<ArgumentNullException> (() => rights.AddRange ((string) null)); Assert.Throws<ArgumentNullException> (() => rights.AddRange ((IEnumerable<AccessRight>) null)); Assert.Throws<ArgumentNullException> (() => new AlertEventArgs (null)); Assert.Throws<ArgumentNullException> (() => new FolderNamespace ('.', null)); var namespaces = new FolderNamespaceCollection (); FolderNamespace ns; Assert.Throws<ArgumentNullException> (() => namespaces.Add (null)); Assert.Throws<ArgumentNullException> (() => namespaces.Contains (null)); Assert.Throws<ArgumentNullException> (() => namespaces.Remove (null)); Assert.Throws<ArgumentOutOfRangeException> (() => ns = namespaces[-1]); Assert.Throws<ArgumentOutOfRangeException> (() => namespaces[-1] = new FolderNamespace ('.', "")); namespaces.Add (new FolderNamespace ('.', "")); Assert.Throws<ArgumentNullException> (() => namespaces[0] = null); Assert.Throws<ArgumentNullException> (() => new FolderNotFoundException (null)); Assert.Throws<ArgumentNullException> (() => new FolderNotFoundException ("message", null)); Assert.Throws<ArgumentNullException> (() => new FolderNotFoundException ("message", null, new Exception ("message"))); Assert.Throws<ArgumentNullException> (() => new FolderNotOpenException (null, FolderAccess.ReadOnly)); Assert.Throws<ArgumentNullException> (() => new FolderNotOpenException (null, FolderAccess.ReadOnly, "message")); Assert.Throws<ArgumentNullException> (() => new FolderNotOpenException (null, FolderAccess.ReadOnly, "message", new Exception ("message"))); Assert.Throws<ArgumentNullException> (() => new FolderRenamedEventArgs (null, "name")); Assert.Throws<ArgumentNullException> (() => new FolderRenamedEventArgs ("name", null)); Assert.Throws<ArgumentOutOfRangeException> (() => new MessageEventArgs (-1)); Assert.Throws<ArgumentNullException> (() => new MessageFlagsChangedEventArgs (0, MessageFlags.Answered, null)); Assert.Throws<ArgumentNullException> (() => new MessageFlagsChangedEventArgs (0, MessageFlags.Answered, null, 1)); Assert.Throws<ArgumentNullException> (() => new MessageFlagsChangedEventArgs (0, UniqueId.MinValue, MessageFlags.Answered, null)); Assert.Throws<ArgumentNullException> (() => new MessageFlagsChangedEventArgs (0, UniqueId.MinValue, MessageFlags.Answered, null, 1)); Assert.Throws<ArgumentNullException> (() => new MessageLabelsChangedEventArgs (0, null)); Assert.Throws<ArgumentNullException> (() => new MessageLabelsChangedEventArgs (0, null, 1)); Assert.Throws<ArgumentNullException> (() => new MessageLabelsChangedEventArgs (0, UniqueId.MinValue, null)); Assert.Throws<ArgumentNullException> (() => new MessageLabelsChangedEventArgs (0, UniqueId.MinValue, null, 1)); Assert.Throws<ArgumentNullException> (() => new MessageSentEventArgs (null, "response")); Assert.Throws<ArgumentNullException> (() => new MessageSentEventArgs (new MimeMessage (), null)); Assert.Throws<ArgumentNullException> (() => new MessageSummaryFetchedEventArgs (null)); Assert.Throws<ArgumentNullException> (() => new MessagesVanishedEventArgs (null, false)); Assert.Throws<ArgumentNullException> (() => new MetadataCollection (null)); var metadataOptions = new MetadataOptions (); Assert.Throws<ArgumentOutOfRangeException> (() => metadataOptions.Depth = 500); Assert.Throws<ArgumentOutOfRangeException> (() => new ModSeqChangedEventArgs (-1)); Assert.Throws<ArgumentOutOfRangeException> (() => new ModSeqChangedEventArgs (-1, 1)); Assert.Throws<ArgumentOutOfRangeException> (() => new ModSeqChangedEventArgs (-1, UniqueId.MinValue, 1)); Assert.Throws<ArgumentOutOfRangeException> (() => new OrderBy (OrderByType.To, SortOrder.None)); Assert.Throws<ArgumentNullException> (() => new ProtocolLogger ((string) null)); Assert.Throws<ArgumentNullException> (() => new ProtocolLogger ((Stream) null)); using (var logger = new ProtocolLogger (new MemoryStream ())) { var buffer = new byte[1024]; Assert.Throws<ArgumentNullException> (() => logger.LogConnect (null)); Assert.Throws<ArgumentNullException> (() => logger.LogClient (null, 0, 0)); Assert.Throws<ArgumentNullException> (() => logger.LogServer (null, 0, 0)); Assert.Throws<ArgumentOutOfRangeException> (() => logger.LogClient (buffer, -1, 0)); Assert.Throws<ArgumentOutOfRangeException> (() => logger.LogServer (buffer, -1, 0)); Assert.Throws<ArgumentOutOfRangeException> (() => logger.LogClient (buffer, 0, -1)); Assert.Throws<ArgumentOutOfRangeException> (() => logger.LogServer (buffer, 0, -1)); } Assert.Throws<ArgumentNullException> (() => new UniqueIdMap (null, new [] { UniqueId.MinValue })); Assert.Throws<ArgumentNullException> (() => new UniqueIdMap (new [] { UniqueId.MinValue }, null)); }