Process incoming mail using an outlook Addin

A customer raised an incident to Microsoft wanting to know how they can create an addin in Outlook to watch all incoming mail....and then do something with it.

So I figured if it's a call to Microsoft that needed this and I see a few people asking how to do this on the Microsoft forums, well it's worth a quick blog post about it.

 

Here are the steps to get you going:

- Start up your Visual Studio 2010 environment

- Choose File | New | Project... this dialog will appear, i've chosen my target environment Office 2010

- Create a name for your addin (WatchIncomingMailAddin)

 - Let Visual Studio create the default template for the outlook addin

- After it has done this, you will see this code

 

- Select all that code and replace it with the text below

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml.Linq;
using Outlook = Microsoft.Office.Interop.Outlook;
using Office = Microsoft.Office.Core;

namespace WatchIncomingMailAddin
{
    public partial class ThisAddIn
    {
        private void ThisAddIn_Startup(object sender, System.EventArgs e)
        {
            Outlook.MAPIFolder inbox = Application.Session.GetDefaultFolder(Outlook.OlDefaultFolders.olFolderInbox);    
           inbox.Items.ItemAdd += new Outlook.ItemsEvents_ItemAddEventHandler(InboxFolderItemAdded); }
        private void InboxFolderItemAdded(object Item)
        {
            if (Item is Outlook.MailItem)
            {
                // New mail item in inbox folder
                MessageBox.Show("you got mail");
            }
        }

        private void ThisAddIn_Shutdown(object sender, System.EventArgs e)
        {
        }

        #region VSTO generated code

        /// <summary>
        /// Required method for Designer support - do not modify
        /// the contents of this method with the code editor.
        /// </summary>
        private void InternalStartup()
        {
            this.Startup += new System.EventHandler(ThisAddIn_Startup);
            this.Shutdown += new System.EventHandler(ThisAddIn_Shutdown);
        }
        #endregion
    }
}

The code above :

 - sets up namespace to allow us to use the message box (system.windows.forms)

 - set up a session to determine the correct folder that we want to process (inbox)

 - set up an event handler to fire when a new item arrives in the inbox (InboxFolderItemAdded)

 - In our event handler we set up a message box in the event to alert us

 

Make sure the outlook process is shut down before running this code as visual studio will process it will automatically at runtime by registering it and tehn fire up outlook

- Run the Addin

- wait for a new mail (or send yourself one)

- You should now see the message fire "You got mail"

 

As it's an outlook.mailitem, you can do lots of things to this, here are a list of members that the mailitem exposes

https://msdn.microsoft.com/en-us/library/microsoft.office.interop.outlook.mailitem_members.aspx

 

Hope thats been helpful, here are some links for reference worth noting to help you with your Outlook office development

Outlook Solutions with Visual Studio
https://msdn.microsoft.com/en-gb/office/hh128768.aspx

Walkthrough: Creating Your First Application-Level Add-in for Outlook
https://msdn.microsoft.com/en-us/library/cc668191.aspx

What's New for Developers in Outlook 2010
https://msdn.microsoft.com/en-us/library/ee692174.aspx

Office Development with Visual Studio (VSTO)
https://msdn.microsoft.com/en-us/office/hh133430

Comments

  • Anonymous
    October 14, 2013
    The comment has been removed
  • Anonymous
    May 14, 2015
    It's not the cleanest piece of code, but the concept is there. Make sure you declare the MAPIFolder and inbox.Items variables outside of the ThisAddIn_Startup() method or at some point your events will stop firing as these variables are currently locally scoped. You should also then clear these variables during ThisAddIn_Shutdown()