Extension to listen to document open and save events
LogExtension.cs
// Copyright 2012 ESRI
// 
// All rights reserved under the copyright laws of the United States
// and applicable international laws, treaties, and conventions.
// 
// You may freely redistribute and use this sample code, with or
// without modification, provided you include the original copyright
// notice and use restrictions.
// 
// See the use restrictions.
// 

using System;
using System.Collections.Generic;
using System.Text;
using System.Runtime.InteropServices;
using ESRI.ArcGIS.ADF.CATIDs;
using ESRI.ArcGIS.esriSystem;
using ESRI.ArcGIS.Framework;
using ESRI.ArcGIS.ArcMapUI;

namespace OpenSaveLogExtensionCS
{
    /// <summary>
    /// Simple extension that logs message when document is opened and saved
    /// </summary>
    [Guid("7d868fd7-f986-4347-bc93-b79751e12def")]
    [ClassInterface(ClassInterfaceType.None)]
    [ProgId("OpenSaveLogExtensionCS.LogExtension")]
    public class LogExtension : IExtension, IPersistVariant
    {
        #region COM Registration Function(s)
        [ComRegisterFunction()]
        [ComVisible(false)]
        static void RegisterFunction(Type registerType)
        {
            // Required for ArcGIS Component Category Registrar support
            ArcGISCategoryRegistration(registerType);

            //
            // TODO: Add any COM registration code here
            //
        }

        [ComUnregisterFunction()]
        [ComVisible(false)]
        static void UnregisterFunction(Type registerType)
        {
            // Required for ArcGIS Component Category Registrar support
            ArcGISCategoryUnregistration(registerType);

            //
            // TODO: Add any COM unregistration code here
            //
        }

        #region ArcGIS Component Category Registrar generated code
        /// <summary>
        /// Required method for ArcGIS Component Category registration -
        /// Do not modify the contents of this method with the code editor.
        /// </summary>
        private static void ArcGISCategoryRegistration(Type registerType)
        {
            string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);
            MxExtension.Register(regKey);
            GMxExtensions.Register(regKey);
            SxExtensions.Register(regKey);

        }
        /// <summary>
        /// Required method for ArcGIS Component Category unregistration -
        /// Do not modify the contents of this method with the code editor.
        /// </summary>
        private static void ArcGISCategoryUnregistration(Type registerType)
        {
            string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);
            MxExtension.Unregister(regKey);
            GMxExtensions.Unregister(regKey);
            SxExtensions.Unregister(regKey);

        }

        #endregion
        #endregion
        private IApplication m_application;

        #region "Add Event Wiring for Open Documents"
        // Event member variables
        private IDocumentEvents_Event m_docEvents;

        // Wiring
        private void SetUpDocumentEvent(IDocument myDocument)
        {
            m_docEvents = myDocument as IDocumentEvents_Event;
            m_docEvents.OpenDocument += new IDocumentEvents_OpenDocumentEventHandler(OnOpenDocument); 

            //Optional, new and close document events
            m_docEvents.NewDocument += new IDocumentEvents_NewDocumentEventHandler(OnNewDocument);
            m_docEvents.CloseDocument += new IDocumentEvents_CloseDocumentEventHandler(OnCloseDocument);
        }

        void OnOpenDocument()
        {
            System.Diagnostics.Debug.WriteLine("Open Document", "Sample Extension (C#)");
            string logText = "Document '" + m_application.Document.Title + "'"
                            + " opened by " + Environment.UserName
                            + " at " + DateTime.Now.ToLongTimeString();

            LogMessage(logText);
        }

        void OnCloseDocument()
        {
            System.Diagnostics.Debug.WriteLine("Close Document", "Sample Extension (C#)");
        }
        void OnNewDocument()
        {
            System.Diagnostics.Debug.WriteLine("New Document", "Sample Extension (C#)");
        }
        #endregion

        #region "IExtension Implementations"
        public string Name
        {
            get
            {
                return "OpenSaveLogExtensionCS";
            }
        }

        public void Shutdown()
        {
            m_docEvents = null;
            m_application = null;
        }

        public void Startup(ref object initializationData)
        {
            m_application = initializationData as IApplication;
            SetUpDocumentEvent(m_application.Document);
        }
        #endregion

        #region "IPersistVariant Implementations"
        public UID ID
        {
            get
            {
                UID extUID = new UIDClass();
                extUID.Value = GetType().GUID.ToString("B");
                return extUID;
            }
        }

        public void Load(IVariantStream Stream)
        {
            Marshal.ReleaseComObject(Stream);
        }

        public void Save(IVariantStream Stream)
        {
            System.Diagnostics.Debug.WriteLine("Save Document", "Sample Extension (C#)");
            LogMessage("Document '" + m_application.Document.Title + "'"
                            + " saved by " + Environment.UserName
                            + " at " + DateTime.Now.ToLongTimeString());

            Marshal.ReleaseComObject(Stream);
        }
        #endregion

        private void LogMessage(string message)
        {
            m_application.StatusBar.set_Message(0, message);
        }
    }
}