Criei um código em C# para ler o e-mail de uma pasta no meu servidor IMAP (local/NAS). O código não está pronto, mas no final eu gostaria de ter uma lista de todos os assuntos do e-mail.
A resposta do código abaixo é:
Total messages: 93
MessageError 0: The IMAP server has unexpectedly disconnected.
Esta pergunta: "O servidor IMAP desconectou-se inesperadamente" usando a porta 993 e o MailKit não resolveu o problema, porque também tive isso ao acessar pela porta 993, e agora pela porta 143 continuo com o mesmo problema.
Ao verificar essa pasta usando o Thunderbird, vejo essas 93 mensagens (e consigo lê-las).
Qualquer ajuda seria apreciada para poder ler essas mensagens.
public static void CheckIMAP()
{
using (var client = new ImapClient(new ProtocolLogger(@"d:\temp\imap.log")))
{
//client.Connect(mailserver, 993, true);
client.Connect(mailserver, 993, SecureSocketOptions.SslOnConnect);
//client.Connect(mailserver, 143, SecureSocketOptions.None);
client.Authenticate(username, password);
IMailFolder folder = client.GetFolder("INBOX.subfolder");
var fo = folder.Open(FolderAccess.ReadOnly);
Console.WriteLine ("Total messages: {0}", folder.Count);
for (int i = 0; i < folder.Count; i++)
{
try
{
var message = folder.GetMessage(i);
Console.WriteLine("Message: {0}", message.Subject);
}
catch (Exception ex)
{
System.Console.WriteLine($"MessageError {i}: {ex.Message}");
break;
}
}
System.Console.WriteLine();
client.Disconnect(true);
}
}
O resultado final deste programa deve ser quase (porque a data da mensagem também deve estar no resultado, mas essa não é a questão agora) o mesmo deste comando Linux em execução no meu NAS:
$ grep '^Subject:' ~/.Maildir/.INBOX.subfolder/cur/*
Versões:
Mailkit: 4.10.0; Dotnet: 9.0.200
Desenvolvendo no Windows 11, quando concluído deve rodar no Linux (no meu Synology NAS)
EDITAR:
O conteúdo do imap.log
:
Connected to imaps://example.com:993/
S: * OK [CAPABILITY IMAP4rev1 SASL-IR LOGIN-REFERRALS ID ENABLE IDLE LITERAL+ AUTH=PLAIN] Dovecot ready.
C: A00000000 AUTHENTICATE PLAIN ********
S: A00000000 OK [CAPABILITY IMAP4rev1 SASL-IR LOGIN-REFERRALS ID ENABLE IDLE SORT SORT=DISPLAY THREAD=REFERENCES THREAD=REFS THREAD=ORDEREDSUBJECT MULTIAPPEND URL-PARTIAL CATENATE UNSELECT CHILDREN NAMESPACE UIDPLUS LIST-EXTENDED I18NLEVEL=1 CONDSTORE QRESYNC ESEARCH ESORT SEARCHRES WITHIN CONTEXT=SEARCH LIST-STATUS BINARY MOVE SNIPPET=FUZZY PREVIEW=FUZZY PREVIEW STATUS=SIZE SAVEDATE LITERAL+ NOTIFY SPECIAL-USE] Logged in
C: A00000001 NAMESPACE
S: * NAMESPACE (("" ".")) NIL NIL
S: A00000001 OK Namespace completed (0.001 + 0.000 secs).
C: A00000002 LIST "" "INBOX" RETURN (SUBSCRIBED CHILDREN)
S: * LIST (\Subscribed \HasChildren) "." INBOX
S: A00000002 OK List completed (0.076 + 0.000 + 0.075 secs).
C: A00000003 LIST (SPECIAL-USE) "" "*" RETURN (SUBSCRIBED CHILDREN)
S: * LIST (\Subscribed \HasNoChildren \UnMarked \Drafts) "." Drafts
S: * LIST (\Subscribed \HasNoChildren \Sent) "." Sent
S: * LIST (\Subscribed \HasNoChildren \UnMarked \Junk) "." Junk
S: * LIST (\Subscribed \HasNoChildren \UnMarked \Trash) "." Trash
S: A00000003 OK List completed (0.007 + 0.000 + 0.006 secs).
C: A00000004 LIST "" INBOX.subfolder RETURN (SUBSCRIBED CHILDREN)
S: * LIST (\Subscribed \HasNoChildren) "." INBOX.subfolder
S: A00000004 OK List completed (0.007 + 0.000 + 0.006 secs).
C: A00000005 EXAMINE INBOX.subfolder (CONDSTORE)
S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft)
S: * OK [PERMANENTFLAGS ()] Read-only mailbox.
S: * 93 EXISTS
S: * 0 RECENT
S: * OK [UIDVALIDITY 1516544306] UIDs valid
S: * OK [UIDNEXT 103] Predicted next UID
S: * OK [HIGHESTMODSEQ 158] Highest
S: A00000005 OK [READ-ONLY] Examine completed (0.005 + 0.000 + 0.004 secs).
C: A00000006 FETCH 1 (BODY.PEEK[])
S: * 1 FETCH (BODY[] {950}
S: Return-Path: <[email protected]>
S: X-Original-To: [email protected]
S: Delivered-To: [email protected]
S: Received: from <obfuscated>
S: (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)
S: key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256)
S: (No client certificate requested)
S: by example.com (Postfix) with ESMTPSA id BB6801EF0A5
S: for <[email protected]>; Thu, 11 Apr 2024 20:14:49 +0200 (CEST)
S: X-Is-Generated-Message-Id: true
S: MIME-Version: 1.0
S: Content-Transfer-Encoding: quoted-printable
S: Content-Type: text/plain;
S: charset=UTF-8
S: Subject: <obfuscated>
S: From: Luuk <[email protected]>
S: Date: Thu, 9 Apr 2024 20:14:48 +0200
S: To: [email protected]
S: Message-ID: <[email protected]>
S: X-MailScanner-ID: BB6801EF0A5.A5150
S: X-MailScanner: Found to be clean
S: X-MailScanner-From: [email protected]
S: X-Spam-Status: No
S:
S: