Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles
(untagged)

ICopyHook implementation

0.00/5 (No votes)
18 May 2010 1  
Implementing ICopyHook Windows extension

Introduction

Lately, I had to implement ICopyHook extension for my project. But, I could not get it working like other normal extensions. I tried searching for sample source code on the web/CodeProject with no success. So, I had no choice but to dig down to get it working. And success was not too far away.

Introduction to ICopyHook Interface

ICopyHook handler is a shell extension that determines if a folder or a printer can be moved/copied/renamed or deleted. It works with folder only and not with individual files. ICopyHook should only approve or deny the operation by returning the appropriate value.

ICopyHook interface has one method, CopyCallback, that we need to implement as per our liking. ICopyHook is really not the name of the interface, it is defined as follows:

#ifdef UNICODE
#define ICopyHook ICopyHookW
#else
#define ICopyHook ICopyHookA
#endif

CopyCallback method in ICopyHookA is defined as:

STDMETHOD_(UINT,CopyCallback) (THIS_ HWND hwnd, UINT wFunc, UINT wFlags, 
   LPCSTR pszSrcFile, DWORD dwSrcAttribs, 
   LPCSTR pszDestFile, DWORD dwDestAttribs) PURE;

and CopyCallback method in ICopyHookW is defined as:

STDMETHOD_(UINT,CopyCallback) (THIS_ HWND hwnd, UINT wFunc, UINT wFlags, 
  LPCWSTR pszSrcFile, DWORD dwSrcAttribs, 
  LPCWSTR pszDestFile, DWORD dwDestAttribs) PURE;

So you see, you need to implement the right CopyCallback method for your type of compilation, i.e., for UNICODE or non-UNICODE.

Implementing ICopyHook

  1. Create an ATL DLL project. I have named it as CopyHook.
  2. Add a new ATL Object from the Insert menu.
  3. From the category, select Objects, and select Simple Object from the Objects list.
  4. Give a name (I have given it as MyHook). In the Properties, select Threading Model as 'Apartment', and interface as 'Dual'.
  5. Add ICopyHook in the list of derivations of the class.
    class ATL_NO_VTABLE CMyHook : public ComObjectRootEx<CComSingleThreadModel>,
      public CComCoClass<CMyHook, &CLSID_MyHook>,
      public ICopyHook,  // ICopyHook interface.
      public IDispatchImpl<IMyHook, &IID_IMyHook, &LIBID_COPYHOOKLib>
  6. Add the following in the COM Map:
    BEGIN_COM_MAP(CMyHook)
      COM_INTERFACE_ENTRY(IMyHook)
      COM_INTERFACE_ENTRY(IDispatch)
      COM_INTERFACE_ENTRY_IID(IID_IShellCopyHook , CMyHook)
    END_COM_MAP()
  7. Add the appropriate CopyCallBack method to the class and implement it. My implementation of the CopyCallBack is just to popup dialog.
  8. And of course, include shlobj.h.

Registration

These are the two places where we need to put our entries.

  1. HKEY_CLASSES_ROOT\Directory\ShellEx\CopyHookHandlers
  2. HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Shell Extensions\Approved

You can find these entries in MyHook.rgs file too in the sample project.

Note From the Author

  1. I have tested this under Win2K Prof and VC6, don't know about other operating systems but other Visual Studio versions should not be a problem.
  2. In the sample, I have implemented Unicode version of CopyCallBack, and ANSI version has been implemented but commented.
  3. For further help on ICopyHook, refer to MSDN.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here