windows-nt/Source/XPSP1/NT/admin/pchealth/upload/server/isapi/uploadserver.cpp

196 lines
4.3 KiB
C++
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/******************************************************************************
Copyright (c) 2000 Microsoft Corporation
Module Name:
UploadServer.cpp
Abstract:
This file contains the implementation of the stubs needed
by an ISAPI extension.
Revision History:
Davide Massarenti (Dmassare) 04/20/99
created
******************************************************************************/
#include "stdafx.h"
#include <initguid.h>
#include "UploadServerCustom_i.c"
////////////////////////////////////////////////////////////////////////////////
CComModule _Module;
BEGIN_OBJECT_MAP(ObjectMap)
END_OBJECT_MAP()
////////////////////////////////////////////////////////////////////////////////
HANDLE g_Heap;
CISAPIconfig g_Config;
MPC::NTEvent g_NTEvents;
static CRITICAL_SECTION g_CritSec;
static BOOL g_Initialized;
static WCHAR g_AppName [] = L"UploadServer";
static WCHAR g_RegistryBase[] = L"SOFTWARE\\Microsoft\\UploadLibrary\\Settings";
BOOL WINAPI DllMain( HINSTANCE hinstDLL ,
DWORD fdwReason ,
LPVOID lpvReserved )
{
switch( fdwReason )
{
case DLL_PROCESS_ATTACH:
g_Heap = HeapCreate( 0, 0, 0 ); if(g_Heap == NULL) return FALSE;
InitializeCriticalSection( &g_CritSec );
g_Initialized = false;
_Module.Init( ObjectMap, hinstDLL );
break;
case DLL_PROCESS_DETACH:
_Module.Term();
if(g_Initialized)
{
;
}
DeleteCriticalSection( &g_CritSec );
HeapDestroy( g_Heap );
break;
}
return TRUE;
}
DWORD WINAPI HttpExtensionProc( LPEXTENSION_CONTROL_BLOCK pECB )
{
__ULT_FUNC_ENTRY("HttpExtensionProc");
DWORD dwRes;
if(pECB->lpszQueryString)
{
//
// Exit if there's a query string beginning with DEBUG
//
if(!strncmp( pECB->lpszQueryString, "DEBUG", 5 ))
{
return HSE_STATUS_ERROR;
}
}
//
// Process the request.
//
try
{
MPCHttpContext* ptr = new MPCHttpContext();
dwRes = ptr->Init( pECB );
}
catch(...)
{
__ULT_TRACE_ERROR( UPLOADLIBID, "Upload Server raised an exception. Gracefully exiting..." );
(void)g_NTEvents.LogEvent( EVENTLOG_ERROR_TYPE, PCHUL_ERR_EXCEPTION,
L"" , // %1 = SERVER
L"HttpExtensionProc", // %2 = CLIENT
NULL );
dwRes = HSE_STATUS_ERROR;
}
return dwRes;
}
BOOL WINAPI GetExtensionVersion( HSE_VERSION_INFO* pVer )
{
BOOL fRes = TRUE;
// Create the extension version string, and
// copy string to HSE_VERSION_INFO structure
pVer->dwExtensionVersion = MAKELONG( HSE_VERSION_MINOR, HSE_VERSION_MAJOR );
// Copy description string into HSE_VERSION_INFO structure
strcpy( pVer->lpszExtensionDesc, "My ISAPI Extension" );
//
// Load config settings if it's the first time we are invoked.
//
if(g_Initialized == FALSE)
{
EnterCriticalSection( &g_CritSec );
if(g_Initialized == FALSE)
{
g_Initialized = TRUE;
__MPC_TRACE_INIT();
(void)g_NTEvents.Init ( g_AppName );
(void)g_Config .SetRoot( g_RegistryBase );
if(FAILED(g_Config.Load()))
{
(void)g_NTEvents.LogEvent( EVENTLOG_ERROR_TYPE, PCHUL_ERR_NOCONFIG, NULL );
fRes = FALSE;
}
}
LeaveCriticalSection( &g_CritSec );
}
(void)g_NTEvents.LogEvent( EVENTLOG_INFORMATION_TYPE, PCHUL_SUCCESS_STARTED, NULL );
return fRes;
}
BOOL WINAPI TerminateExtension( DWORD dwFlags )
{
(void)g_NTEvents.LogEvent( EVENTLOG_INFORMATION_TYPE, PCHUL_SUCCESS_STOPPED, NULL );
__MPC_TRACE_TERM();
return TRUE;
}
/////////////////////////////////////////////////////////////////////////////
void WINAPI PurgeEngine(void)
{
__MPC_TRACE_INIT();
(void)g_NTEvents.Init ( g_AppName );
(void)g_Config .SetRoot( g_RegistryBase );
if(FAILED(g_Config.Load()))
{
(void)g_NTEvents.LogEvent( EVENTLOG_ERROR_TYPE, PCHUL_ERR_NOCONFIG, NULL );
}
else
{
MPCPurgeEngine mpcpe;
mpcpe.Process();
}
__MPC_TRACE_TERM();
}