windows-nt/Source/XPSP1/NT/inetsrv/iis/iisrearc/iisplus/ulw3/handlerequest.cxx

245 lines
4.5 KiB
C++
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/*++
Copyright (c) 1999 Microsoft Corporation
Module Name :
handlerequest.cxx
Abstract:
Handle request state
Author:
Bilal Alam (balam) 10-Jan-2000
Environment:
Win32 - User Mode
Project:
ULW3.DLL
--*/
#include "precomp.hxx"
#include "staticfile.hxx"
#include "isapi_handler.h"
#include "cgi_handler.h"
#include "trace_handler.h"
#include "dav_handler.h"
#include "generalhandler.hxx"
W3_STATE_HANDLE_REQUEST::W3_STATE_HANDLE_REQUEST()
{
BOOL fStaticInit = FALSE;
BOOL fCGIInit = FALSE;
BOOL fTraceInit = FALSE;
BOOL fISAPIInit = FALSE;
BOOL fDAVInit = FALSE;
BOOL fGeneralInit = FALSE;
//
// Initialize static file handler
//
_hr = W3_STATIC_FILE_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fStaticInit = TRUE;
//
// Initialize ISAPI handler
//
_hr = W3_ISAPI_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fISAPIInit = TRUE;
//
// Initialize CGI handler
//
_hr = W3_CGI_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fCGIInit = TRUE;
//
// Initialize Trace handler
//
_hr = W3_TRACE_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fTraceInit = TRUE;
//
// Initialize DAV handler
//
_hr = W3_DAV_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fDAVInit = TRUE;
//
// Initialize general handler
//
_hr = W3_GENERAL_HANDLER::Initialize();
if ( FAILED( _hr ) )
{
goto Failure;
}
fGeneralInit = TRUE;
return;
Failure:
if ( fGeneralInit )
{
W3_GENERAL_HANDLER::Terminate();
}
if ( fDAVInit )
{
W3_DAV_HANDLER::Terminate();
}
if ( fCGIInit )
{
W3_CGI_HANDLER::Terminate();
}
if ( fISAPIInit )
{
W3_ISAPI_HANDLER::Terminate();
}
if ( fStaticInit )
{
W3_STATIC_FILE_HANDLER::Terminate();
}
}
W3_STATE_HANDLE_REQUEST::~W3_STATE_HANDLE_REQUEST()
{
if ( FAILED( _hr ) )
{
return;
}
W3_STATIC_FILE_HANDLER::Terminate();
W3_ISAPI_HANDLER::Terminate();
W3_CGI_HANDLER::Terminate();
W3_DAV_HANDLER::Terminate();
W3_GENERAL_HANDLER::Terminate();
}
CONTEXT_STATUS
W3_STATE_HANDLE_REQUEST::DoWork(
W3_MAIN_CONTEXT * pMainContext,
DWORD cbCompletion,
DWORD dwCompletionStatus
)
/*++
Routine Description:
Handle the request.
This routine should determine and invoke the appropriate request
handler.
Arguments:
pMainContext - Mainline context
cbCompletion - Bytes of completion
dwCompletionStatus - Completion status
Return Value:
CONTEXT_STATUS_PENDING if async pending, else CONTEXT_STATUS_CONTINUE
--*/
{
HRESULT hr = NO_ERROR;
BOOL fImmediateFinish = FALSE;
//
// We must NOT allow any handlers to store state with the context
// (that would screw up child execution)
//
DBG_ASSERT( pMainContext->QueryContextState() == NULL );
//
// We must have a user by now!
//
DBG_ASSERT( pMainContext->QueryUserContext() != NULL );
//
// What handler should handle this request?
//
hr = pMainContext->DetermineHandler( TRUE );
if ( FAILED( hr ) )
{
goto Failure;
}
//
// If we were successful, but no handler was set, then there must
// be an error for us to send
//
if ( pMainContext->QueryHandler() == NULL )
{
DBG_ASSERT( pMainContext->QueryResponse()->QueryStatusCode() != 200 );
hr = pMainContext->SendResponse( W3_FLAG_ASYNC );
}
else
{
hr = pMainContext->ExecuteHandler( W3_FLAG_ASYNC,
&fImmediateFinish );
}
//
// If the execution succeeded, then we expect a completion so bail
//
if ( SUCCEEDED( hr ) )
{
if ( fImmediateFinish )
{
return CONTEXT_STATUS_CONTINUE;
}
else
{
return CONTEXT_STATUS_PENDING;
}
}
Failure:
pMainContext->SetErrorStatus( hr );
pMainContext->QueryResponse()->SetStatus( HttpStatusServerError );
pMainContext->SetFinishedResponse();
return CONTEXT_STATUS_CONTINUE;
}