Windows2003-3790/inetsrv/iis/svcs/smtp/adminsso/smtpadm.cpp
2020-09-30 16:53:55 +02:00

113 lines
3.3 KiB
C++

// 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;
}