Loading
Enhance Salesforce with Code
Table of Contents
Select Filters

          No results
          No results
          Here are some search tips

          Check the spelling of your keywords.
          Use more general search terms.
          Select fewer filters to broaden your search.

          Search all of Salesforce Help
          The InboundEmail Object

          The InboundEmail Object

          For every email the Apex email service domain receives, Salesforce creates a separate InboundEmail object that contains the contents and attachments of that email. You can use Apex classes that implement the Messaging.InboundEmailHandler interface to handle an inbound email message. Using the handleInboundEmail method in that class, you can access an InboundEmail object to retrieve the contents, headers, and attachments of inbound email messages, as well as perform many functions.

          Required Editions

          Available in: Salesforce Classic (not available in all orgs)
          Available in: Enterprise, Performance, Unlimited, and Developer Editions
          Note
          Note For information on the Apex email service, see Email Services.

          Example 1: Create Tasks for Contacts

          The following is an example of how you can look up a contact based on the inbound email address and create a new task.

          public with sharing class CreateTaskEmailExample implements Messaging.InboundEmailHandler {
           
            public Messaging.InboundEmailResult handleInboundEmail(Messaging.inboundEmail email, 
                                                                 Messaging.InboundEnvelope env){
           
              // Create an InboundEmailResult object for returning the result of the 
              // Apex Email Service
              Messaging.InboundEmailResult result = new Messaging.InboundEmailResult();
            
              String myPlainText= '';
              
              // Add the email plain text into the local variable 
              myPlainText = email.plainTextBody;
             
              // New Task object to be created
              Task[] newTask = new Task[0];
             
              // Try to look up any contacts based on the email from address
              // If there is more than one contact with the same email address,
              // an exception will be thrown and the catch statement will be called.
              try {
                Contact vCon = [SELECT Id, Name, Email
                  FROM Contact
                  WHERE Email = :email.fromAddress
                  WITH USER_MODE
                  LIMIT 1 ];
                
                // Add a new Task to the contact record we just found above.
                newTask.add(new Task(Description =  myPlainText,
                     Priority = 'Normal',
                     Status = 'Inbound Email',
                     Subject = email.subject,
                     IsReminderSet = true,
                     ReminderDateTime = System.now()+1,
                     WhoId =  vCon.Id));
               
               // Insert the new Task 
               insert as user newTask;    
               
               System.debug('New Task Object: ' + newTask );   
              }
              // If an exception occurs when the query accesses 
              // the contact record, a QueryException is called.
              // The exception is written to the Apex debug log.
             catch (QueryException e) {
                 System.debug('Query Issue: ' + e);
             }
             
             // Set the result to true. No need to send an email back to the user 
             // with an error message
             result.success = true;
             
             // Return the result for the Apex Email Service
             return result;
            }
          }

          Example 2: Handle Unsubscribe Email

          Companies that send marketing email to their customers and prospects need to provide a way to let the recipients unsubscribe. The following is an example of how an email service can process unsubscribe requests. The code searches the subject line of inbound email for the word “unsubscribe.” If the word is found, the code finds all contacts and leads that match the From email address and sets the Email Opt Out field (HasOptedOutOfEmail) to True.

          public with sharing class unsubscribe implements Messaging.inboundEmailHandler{
          
              public Messaging.InboundEmailResult handleInboundEmail(Messaging.InboundEmail email, 
                                   Messaging.InboundEnvelope env ) {
              
                  // Create an inboundEmailResult object for returning 
                  // the result of the email service.
                  Messaging.InboundEmailResult result = new Messaging.InboundEmailResult();
                   
                  // Create contact and lead lists to hold all the updated records.
                  List<Contact> lc = new List <contact>();
                  List<Lead> ll = new List <lead>();
                   
                  // Convert the subject line to lower case so the program can match on lower case.
                  String mySubject = email.subject.toLowerCase();
                  // The search string used in the subject line.
                  String s = 'unsubscribe';
                   
                  // Check the variable to see if the word "unsubscribe" was found in the subject line. 
                  Boolean unsubMe;
                  // Look for the word "unsubcribe" in the subject line. 
                  // If it is found, return true; otherwise, return false.
                  unsubMe = mySubject.contains(s);
                   
                   // If unsubscribe is found in the subject line, enter the IF statement.
                   
                  if (unsubMe == true) {
                      
                      try {
                         
                      // Look up all contacts with a matching email address.
                         
                      for (Contact c : [SELECT Id, Name, Email, HasOptedOutOfEmail
                                    FROM Contact
                                    WHERE Email = :env.fromAddress
                                    AND hasOptedOutOfEmail = false
                                    LIMIT 100]) {
                                    
                          // Add all the matching contacts into the list.   
                          c.hasOptedOutOfEmail = true;
                          lc.add(c);
                      }
                      // Update all of the contact records.
                      update as user lc;
                  }
                  catch (System.QueryException e) {
                      System.debug('Contact Query Issue: ' + e);
                  }   
                  
                  try {
                      // Look up all leads matching the email address.
                      for (Lead l : [SELECT Id, Name, Email, HasOptedOutOfEmail
                               FROM Lead
                               WHERE Email = :env.fromAddress
                               AND isConverted = false
                               AND hasOptedOutOfEmail = false
                               LIMIT 100]) {
                          // Add all the leads to the list.       
                          l.hasOptedOutOfEmail = true;
                          ll.add(l);
                             
                          System.debug('Lead Object: ' + l);   
                      } 
                      // Update all lead records in the query.
                      update as user ll;
                  }
                  
                  catch (System.QueryException e) {
                      System.debug('Lead Query Issue: ' + e);
                  }   
                  
                  System.debug('Found the unsubscribe word in the subject line.');
                   } 
                   else {
                      System.debug('No Unsuscribe word found in the subject line.' );
                   }
                  // Return True and exit.
                  // True confirms program is complete and no emails 
                  // should be sent to the sender of the unsubscribe request. 
                  result.success = true;
                  return result;
              }   
          }
          @isTest
          private class unsubscribeTest {
              // The following test methods provide adequate code coverage 
              // for the unsubscribe email class.
              // There are two methods, one that does the testing
              // with a valid "unsubcribe" in the subject line
              // and one the does not contain "unsubscribe" in the
              // subject line.        
              static testMethod void testUnsubscribe() {
              
                 // Create a new email and envelope object.
                 Messaging.InboundEmail email = new Messaging.InboundEmail() ;
                 Messaging.InboundEnvelope env    = new Messaging.InboundEnvelope();
              
                 // Create a new test lead and insert it in the test method.
                 Lead l = new lead(firstName='John', 
                          lastName='Smith',
                          Company='Salesforce', 
                          Email='user@acme.com', 
                          HasOptedOutOfEmail=false);
                 insert l;
              
                 // Create a new test contact and insert it in the test method.
                 Contact c = new Contact(firstName='john', 
                              lastName='smith', 
                              Email='user@acme.com', 
                              HasOptedOutOfEmail=false);
                 insert c;
                 
                 // Test with the subject that matches the unsubscribe statement.
                 email.subject = 'test unsubscribe test';
                 env.fromAddress = 'user@acme.com';
                 
                 // Call the class and test it with the data in the testMethod.
                 unsubscribe unsubscribeObj = new unsubscribe();
                 unsubscribeObj.handleInboundEmail(email, env );
                                      
              }
               
              static testMethod void testUnsubscribe2() {
              
                 // Create a new email and envelope object.
                 Messaging.InboundEmail email = new Messaging.InboundEmail();
                 Messaging.InboundEnvelope env = new Messaging.InboundEnvelope();
              
                 // Create a new test lead and insert it in the test method.        
                 Lead l = new lead(firstName='john', 
                          lastName='smith',
                          Company='Salesforce', 
                          Email='user@acme.com', 
                          HasOptedOutOfEmail=false);
                 insert l;
              
                 // Create a new test contact and insert it in the test method.    
                 Contact c = new Contact(firstName='john', 
                              lastName='smith', 
                              Email='user@acme.com', 
                              HasOptedOutOfEmail=false);
                 insert c;
                 
                 // Test with a subject that does not contain "unsubscribe."
                 email.subject = 'test';
                 env.fromAddress = 'user@acme.com';
              
                 // Call the class and test it with the data in the test method.
                 unsubscribe unsubscribeObj = new unsubscribe();
                 unsubscribeObj.handleInboundEmail(email, env );                      
              }     
          }

          InboundEmail Object

          An InboundEmail object has the following fields.

          Name Type Description
          binaryAttachments InboundEmail.BinaryAttachment[]

          A list of binary attachments received with the email, if any.

          Examples of binary attachments include image, audio, application, and video files.

          ccAddresses String[] A list of carbon copy (CC) addresses, if any.
          fromAddress String The email address that appears in the From field.
          fromName String The name that appears in the From field, if any.
          headers InboundEmail.Header[]

          A list of the RFC 2822 headers in the email, including:

          • Received from
          • Custom headers
          • Message-ID
          • Date
          htmlBody String The HTML version of the email, if specified by the sender.
          htmlBodyIsTruncated Boolean Indicates whether the HTML body text is truncated (true) or not (false.)
          inReplyTo String The In-Reply-To field of the incoming email. Identifies the email or emails to which this one is a reply (parent emails). Contains the parent email or emails' message-IDs.
          messageId String The Message-ID—the incoming email's unique identifier.
          plainTextBody String The plain text version of the email, if specified by the sender.
          plainTextBodyIsTruncated Boolean Indicates whether the plain body text is truncated (true) or not (false.)
          references String [] The References field of the incoming email. Identifies an email thread. Contains a list of the parent emails' References and message IDs, and possibly the In-Reply-To fields.
          replyTo String

          The email address that appears in the reply-to header.

          If there is no reply-to header, this field is identical to the fromAddress field.

          subject String The subject line of the email, if any.
          textAttachments InboundEmail.TextAttachment[]

          A list of text attachments received with the email, if any.

          The text attachments can be any of the following:

          • Attachments with a Multipurpose Internet Mail Extension (MIME) type of text
          • Attachments with a MIME type of application/octet-stream and a file name that ends with either a .vcf or .vcs extension. These are saved as text/x-vcard and text/calendar MIME types, respectively.
          toAddresses String[] The email address that appears in the To field.

          InboundEmail.Header Object

          An InboundEmail object stores RFC 2822 email header information in an InboundEmail.Header object with the following fields.

          Name Type Description
          name String The name of the header parameter, such as Date or Message-ID.
          value String The value of the header.

          InboundEmail.BinaryAttachment Object

          An InboundEmail object stores binary attachments in an InboundEmail.BinaryAttachment object.

          Examples of binary attachments include image, audio, application, and video files.

          An InboundEmail.BinaryAttachment object has the following fields.

          Name Type Description
          body Blob The body of the attachment.
          fileName String The name of the attached file.
          mimeTypeSubType String The primary and sub MIME-type.

          InboundEmail.TextAttachment Object

          An InboundEmail object stores text attachments in an InboundEmail.TextAttachment object.

          The text attachments can be any of the following:

          • Attachments with a Multipurpose Internet Mail Extension (MIME) type of text
          • Attachments with a MIME type of application/octet-stream and a file name that ends with either a .vcf or .vcs extension. These are saved as text/x-vcard and text/calendar MIME types, respectively.

          An InboundEmail.TextAttachment object has the following fields.

          Name Type Description
          body String The body of the attachment.
          bodyIsTruncated Boolean Indicates whether the attachment body text is truncated (true) or not (false.)
          charset String The original character set of the body field. The body is re-encoded as UTF-8 as input to the Apex method.
          fileName String The name of the attached file.
          mimeTypeSubType String The primary and sub MIME-type.

          InboundEmailResult Object

          The InboundEmailResult object is used to return the result of the email service. If this object is null, the result is assumed to be successful. The InboundEmailResult object has the following fields.

          Name Type Description
          success Boolean

          A value that indicates whether the email was successfully processed.

          If false, Salesforce rejects the inbound email and sends a reply email to the original sender containing the message specified in the Message field.

          message String A message that Salesforce returns in the body of a reply email. This field can be populated with text irrespective of the value returned by the Success field.

          InboundEnvelope Object

          The InboundEnvelope object stores the envelope information associated with the inbound email, and has the following fields.

          Name Type Description
          toAddress String The name that appears in the To field of the envelope, if any.
          fromAddress String The name that appears in the From field of the envelope, if any.
           
          Loading
          Salesforce Help | Article