// nntpadm.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 nntpadmps.mak in the project directory. #include "stdafx.h" #include "nntpcmn.h" #include "admin.h" #include "expire.h" #include "feeds.h" #include "groups.h" #include "rebuild.h" #include "sessions.h" #include "server.h" #include "vroots.h" /* #include "propcach.h" #include "service.h" #include "virsrv.h" */ #include "regmacro.h" CComModule _Module; BEGIN_OBJECT_MAP(ObjectMap) OBJECT_ENTRY(CLSID_CNntpAdmin, CNntpAdmin) OBJECT_ENTRY(CLSID_CNntpVirtualServer, CNntpVirtualServer) OBJECT_ENTRY(CLSID_CNntpAdminFeeds, CNntpAdminFeeds) OBJECT_ENTRY(CLSID_CNntpAdminExpiration, CNntpAdminExpiration) OBJECT_ENTRY(CLSID_CNntpAdminGroups, CNntpAdminGroups) OBJECT_ENTRY(CLSID_CNntpAdminSessions, CNntpAdminSessions) OBJECT_ENTRY(CLSID_CNntpAdminRebuild, CNntpAdminRebuild) OBJECT_ENTRY(CLSID_CNntpVirtualRoot, CNntpVirtualRoot) OBJECT_ENTRY(CLSID_CNntpFeed, CNntpFeed) OBJECT_ENTRY(CLSID_CNntpOneWayFeed, CNntpOneWayFeed) // OBJECT_ENTRY(CLSID_CNntpService, CNntpAdminService) // OBJECT_ENTRY(CLSID_CAdsNntpVirtualServer, CAdsNntpVirtualServer) END_OBJECT_MAP() BEGIN_EXTENSION_REGISTRATION_MAP EXTENSION_REGISTRATION_MAP_ENTRY(IIsNntpExpires, NntpAdminExpiration) EXTENSION_REGISTRATION_MAP_ENTRY(IIsNntpFeeds, NntpAdminFeeds) EXTENSION_REGISTRATION_MAP_ENTRY(IIsNntpGroups, NntpAdminGroups) EXTENSION_REGISTRATION_MAP_ENTRY(IIsNntpRebuild, NntpAdminRebuild) EXTENSION_REGISTRATION_MAP_ENTRY(IIsNntpSessions, NntpAdminSessions) 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; }