|
|
// smtpadm.cpp : Implementation of DLL Exports.
// You will need the NT SUR Beta 2 SDK or VC 4.2 in order to build this
// project. This is because you will need MIDL 3.00.15 or higher and new
// headers and libs. If you have VC 4.2 installed, then everything should
// already be configured correctly.
// Note: Proxy/Stub Information
// To build a separate proxy/stub DLL,
// run nmake -f smtpadmps.mak in the project directory.
#include "stdafx.h"
#include "resource.h"
#include "adsiid.h"
#include "smtpadm.h"
#include "admin.h"
#include "service.h"
#include "virsvr.h"
#include "sessions.h"
#include "vdir.h"
#include "alias.h"
#include "user.h"
#include "dl.h"
#include "domain.h"
#include "regmacro.h"
CComModule _Module;
BEGIN_OBJECT_MAP(ObjectMap) OBJECT_ENTRY(CLSID_CSmtpAdmin, CSmtpAdmin) OBJECT_ENTRY(CLSID_CSmtpAdminService, CSmtpAdminService) OBJECT_ENTRY(CLSID_CSmtpAdminVirtualServer, CSmtpAdminVirtualServer) OBJECT_ENTRY(CLSID_CSmtpAdminSessions, CSmtpAdminSessions) OBJECT_ENTRY(CLSID_CSmtpAdminVirtualDirectory, CSmtpAdminVirtualDirectory) OBJECT_ENTRY(CLSID_CSmtpAdminAlias, CSmtpAdminAlias) OBJECT_ENTRY(CLSID_CSmtpAdminUser, CSmtpAdminUser) OBJECT_ENTRY(CLSID_CSmtpAdminDL, CSmtpAdminDL) OBJECT_ENTRY(CLSID_CSmtpAdminDomain, CSmtpAdminDomain) END_OBJECT_MAP()
BEGIN_EXTENSION_REGISTRATION_MAP EXTENSION_REGISTRATION_MAP_ENTRY(IIsSmtpAlias, SmtpAdminAlias) EXTENSION_REGISTRATION_MAP_ENTRY(IIsSmtpDomain, SmtpAdminDomain) EXTENSION_REGISTRATION_MAP_ENTRY(IIsSmtpDL, SmtpAdminDL) EXTENSION_REGISTRATION_MAP_ENTRY(IIsSmtpSessions, SmtpAdminSessions) EXTENSION_REGISTRATION_MAP_ENTRY(IIsSmtpUser, SmtpAdminUser) END_EXTENSION_REGISTRATION_MAP
/////////////////////////////////////////////////////////////////////////////
// DLL Entry Point
extern "C" BOOL WINAPI DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID /*lpReserved*/) { if (dwReason == DLL_PROCESS_ATTACH) { // InitAsyncTrace ();
_Module.Init(ObjectMap, hInstance); DisableThreadLibraryCalls(hInstance); } else if (dwReason == DLL_PROCESS_DETACH) { // TermAsyncTrace ();
_Module.Term(); } return TRUE; // ok
}
/////////////////////////////////////////////////////////////////////////////
// Used to determine whether the DLL can be unloaded by OLE
STDAPI DllCanUnloadNow(void) { return (_Module.GetLockCount()==0) ? S_OK : S_FALSE; }
/////////////////////////////////////////////////////////////////////////////
// Returns a class factory to create an object of the requested type
STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv) { return _Module.GetClassObject(rclsid, riid, ppv); }
/////////////////////////////////////////////////////////////////////////////
// DllRegisterServer - Adds entries to the system registry
STDAPI DllRegisterServer(void) { // register extensions
RegisterExtensions();
// registers object, typelib and all interfaces in typelib
return(_Module.RegisterServer(TRUE)); }
/////////////////////////////////////////////////////////////////////////////
// DllUnregisterServer - Removes entries from the system registry
STDAPI DllUnregisterServer(void) { // register extensions
UnregisterExtensions();
_Module.UnregisterServer(); return S_OK; }
|