MailCore 2 provides a simple and asynchronous Objective-C API to work with the e-mail protocols IMAP, POP and SMTP. The API has been redesigned from the ground up. It features:
- POP, IMAP and SMTP support
- RFC822 parser and generator
- Asynchronous APIs
- HTML rendering of messages
- iOS and Mac support
Read instructions for iOS/OSX.
Read instructions for Android.
Read instructions for Windows.
Read instructions for Linux.
Using MailCore 2 is just a little more complex conceptually than the original MailCore. All fetch requests in MailCore 2 are made asynchronously through a queue. What does this mean? Well, let's take a look at a simple example:
MCOIMAPSession *session = [[MCOIMAPSession alloc] init];
[session setHostname:@"imap.gmail.com"];
[session setPort:993];
[session setUsername:@"[email protected]"];
[session setPassword:@"123456"];
[session setConnectionType:MCOConnectionTypeTLS];
MCOIMAPMessagesRequestKind requestKind = MCOIMAPMessagesRequestKindHeaders;
NSString *folder = @"INBOX";
MCOIndexSet *uids = [MCOIndexSet indexSetWithRange:MCORangeMake(1, UINT64_MAX)];
MCOIMAPFetchMessagesOperation *fetchOperation = [session fetchMessagesOperationWithFolder:folder requestKind:requestKind uids:uids];
[fetchOperation start:^(NSError * error, NSArray * fetchedMessages, MCOIndexSet * vanishedMessages) {
//We've finished downloading the messages!
//Let's check if there was an error:
if(error) {
NSLog(@"Error downloading message headers:%@", error);
}
//And, let's print out the messages...
NSLog(@"The post man delivereth:%@", fetchedMessages);
}];
In this sample, we retrieved and printed a list of email headers from an IMAP server. In order to execute the fetch, we request an asynchronous operation object from the MCOIMAPSession
instance with our parameters (more on this later). This operation object is able to initiate a connection to Gmail when we call the start
method. Now here's where things get a little tricky. We call the start
function with an Objective-C block, which is executed on the main thread when the fetch operation completes. The actual fetching from IMAP is done on a background thread, leaving your UI and other processing free to use the main thread.
MailCore 2 is BSD-Licensed.
compile libetpan and mailcore2
- install homebrew.
- brew install automake
- brew install ibtool*
- enter libetpan folder, cd build-android,./build.sh
- copy libetpan-android-6.zip and dependencies/cyrus-sasl/cyrus-sasl-android-4.zip to mailcore2/build-android/third-party. unzip these files.
- enter mailcore2 folder, cd build-android, ./build.sh
- finished.
debug mailcore and libetpan
- enter troin source folder.
- modify build.gradle and mailcore2's android_All_libetpan.mk. Add your NDK PATH and your Target CPU.
- debug android programe by android studio.