Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

170 lines
4.7 KiB

/*++
Copyright (c) 2000 Microsoft Corporation
Module Name :
headerhash.cxx
Abstract:
Header hash goo
Author:
Bilal Alam (balam) 20-Feb-2000
Environment:
Win32 - User Mode
Project:
ULW3.DLL
--*/
#include "precomp.hxx"
REQUEST_HEADER_HASH *REQUEST_HEADER_HASH::sm_pRequestHash;
HEADER_RECORD REQUEST_HEADER_HASH::sm_rgHeaders[] =
{
//
// The only consumer of this data is W3_REQUEST::GetHeader
// GetServerVariable is handled by SERVER_VARIABLE_HASH, so we do
// not need to store the HTTP_'ed and capitalized names here
//
{ HttpHeaderCacheControl , HEADER("Cache-Control") },
{ HttpHeaderConnection , HEADER("Connection") },
{ HttpHeaderDate , HEADER("Date") },
{ HttpHeaderKeepAlive , HEADER("Keep-Alive") },
{ HttpHeaderPragma , HEADER("Pragma") },
{ HttpHeaderTrailer , HEADER("Trailer") },
{ HttpHeaderTransferEncoding , HEADER("Transfer-Encoding") },
{ HttpHeaderUpgrade , HEADER("Upgrade") },
{ HttpHeaderVia , HEADER("Via") },
{ HttpHeaderWarning , HEADER("Warning") },
{ HttpHeaderAllow , HEADER("Allow") },
{ HttpHeaderContentLength , HEADER("Content-Length") },
{ HttpHeaderContentType , HEADER("Content-Type") },
{ HttpHeaderContentEncoding , HEADER("Content-Encoding") },
{ HttpHeaderContentLanguage , HEADER("Content-Language") },
{ HttpHeaderContentLocation , HEADER("Content-Location") },
{ HttpHeaderContentMd5 , HEADER("Content-MD5") },
{ HttpHeaderContentRange , HEADER("Content-Range") },
{ HttpHeaderExpires , HEADER("Expires") },
{ HttpHeaderLastModified , HEADER("Last-Modified") },
{ HttpHeaderAccept , HEADER("Accept") },
{ HttpHeaderAcceptCharset , HEADER("Accept-Charset") },
{ HttpHeaderAcceptEncoding , HEADER("Accept-Encoding") },
{ HttpHeaderAcceptLanguage , HEADER("Accept-Language") },
{ HttpHeaderAuthorization , HEADER("Authorization") },
{ HttpHeaderCookie , HEADER("Cookie") },
{ HttpHeaderExpect , HEADER("Expect") },
{ HttpHeaderFrom , HEADER("From") },
{ HttpHeaderHost , HEADER("Host") },
{ HttpHeaderIfMatch , HEADER("If-Match") },
{ HttpHeaderIfModifiedSince , HEADER("If-Modified-Since") },
{ HttpHeaderIfNoneMatch , HEADER("If-None-Match") },
{ HttpHeaderIfRange , HEADER("If-Range") },
{ HttpHeaderIfUnmodifiedSince , HEADER("If-Unmodified-Since") },
{ HttpHeaderMaxForwards , HEADER("Max-Forwards") },
{ HttpHeaderProxyAuthorization , HEADER("Proxy-Authorization") },
{ HttpHeaderReferer , HEADER("Referer") },
{ HttpHeaderRange , HEADER("Range") },
{ HttpHeaderTe , HEADER("TE") },
{ HttpHeaderTranslate , HEADER("Translate") },
{ HttpHeaderUserAgent , HEADER("User-Agent") }
};
//static
HRESULT
REQUEST_HEADER_HASH::Initialize(
VOID
)
/*++
Routine Description:
Initialize global header hash table
Arguments:
None
Return Value:
HRESULT
--*/
{
HEADER_RECORD * pRecord;
LK_RETCODE lkrc = LK_SUCCESS;
DWORD dwNumRecords;
//
// Add header index/name to hash table
//
sm_pRequestHash = new REQUEST_HEADER_HASH();
if ( sm_pRequestHash == NULL )
{
return HRESULT_FROM_WIN32( ERROR_NOT_ENOUGH_MEMORY );
}
//
// Add every string->routine mapping
//
dwNumRecords = sizeof( sm_rgHeaders ) / sizeof( HEADER_RECORD );
for ( DWORD i = 0; i < dwNumRecords; i++ )
{
pRecord = &(sm_rgHeaders[ i ]);
lkrc = sm_pRequestHash->InsertRecord( pRecord );
if ( lkrc != LK_SUCCESS )
{
break;
}
}
//
// If any insert failed, then fail initialization
//
if ( lkrc != LK_SUCCESS )
{
delete sm_pRequestHash;
sm_pRequestHash = NULL;
return HRESULT_FROM_WIN32( lkrc ); // BUGBUG
}
else
{
return NO_ERROR;
}
}
//static
VOID
REQUEST_HEADER_HASH::Terminate(
VOID
)
/*++
Routine Description:
Global cleanup of header hash table
Arguments:
None
Return Value:
None
--*/
{
if ( sm_pRequestHash != NULL )
{
delete sm_pRequestHash;
sm_pRequestHash = NULL;
}
}