Sample code for 30+ languages & platforms
Android™

Move Selected Emails to another Mailbox Folder

See more IMAP Examples

Downloads emails one by one in a selected mailbox, decides which emails are to be moved, and then moves the set of messages to another mailbox folder.

Chilkat Android™ Downloads

Android™
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;

import android.app.Activity;
import com.chilkatsoft.*;

import android.widget.TextView;
import android.os.Bundle;

public class SimpleActivity extends Activity {

  private static final String TAG = "Chilkat";

  // Called when the activity is first created.
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    boolean success = false;

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkImap imap = new CkImap();

    // Connect to an IMAP server.
    // Use TLS
    imap.put_Ssl(true);
    imap.put_Port(993);
    success = imap.Connect("imap.example.com");
    if (success == false) {
        Log.i(TAG, imap.lastErrorText());
        return;
        }

    // Login
    success = imap.Login("myLogin","myPassword");
    if (success == false) {
        Log.i(TAG, imap.lastErrorText());
        return;
        }

    // Select an IMAP mailbox
    success = imap.SelectMailbox("Inbox");
    if (success == false) {
        Log.i(TAG, imap.lastErrorText());
        return;
        }

    // Normally, when an email is downloaded, its "Seen" flag is automatically set.
    // We don't want our program to be interfering with the "Seen" flags.
    // To do this, set the PeekMode to true.
    imap.put_PeekMode(true);

    // After selecting the mailbox, the NumMessages property
    // will contain the number of emails in the mailbox.
    // When sequence numbers (not UIDs) are used to reference emails,
    // they range from 1 to N, where N is the number of messages in the mailbox.
    // This example will download the headers by sequence numbers.
    int numEmails = imap.get_NumMessages();

    CkMessageSet mset = new CkMessageSet();

    // Indicate that mset contains sequence numbers, not UIDs.
    mset.put_HasUids(false);

    // Fetch each email and decide for each if it is to be moved
    // to a particular other mailbox.  If so, we'll add the sequence number to
    // the mset, and then move all emails in the mset to the other mailbox.
    CkEmail email = new CkEmail();
    int i = 0;
    while (i < numEmails) {
        // Fetch the email by sequence number.
        success = imap.FetchEmail(false,i + 1,false,email);
        if (success == false) {
            Log.i(TAG, imap.lastErrorText());
            return;
            }

        // If it is decided to move the email, add the sequence number to mset, like this:
        mset.InsertId(i + 1);

        }

    // If there are emails in mset to be moved, then do it..
    if (mset.get_Count() > 0) {
        String destFolder = "Inbox/SomeOtherFolder";
        // Assuming your IMAP server supports the feature that allows for messages to be moved to another folder...
        success = imap.MoveMessages(mset,destFolder);
        if (success == false) {
            Log.i(TAG, imap.lastErrorText());
            return;
            }

        }

    // Disconnect from the IMAP server.
    success = imap.Disconnect();

  }

  static {
      System.loadLibrary("chilkat");

      // Note: If the incorrect library name is passed to System.loadLibrary,
      // then you will see the following error message at application startup:
      //"The application <your-application-name> has stopped unexpectedly. Please try again."
  }
}