windows-nt/Source/XPSP1/NT/ds/security/protocols/schannel/spbase/debug.c

434 lines
13 KiB
C
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995.
//
// File: debug.c
//
// Contents:
//
// Classes:
//
// Functions:
//
// History:
//
//----------------------------------------------------------------------------
#include <spbase.h>
#include <alloca.h>
HANDLE g_hfLogFile = NULL;
#if DBG /* NOTE: This file not compiled for retail builds */
#include <stdio.h>
#include <stdarg.h>
#define WINDEBUG
#ifndef min
#define min(x,y) ((x)<(y)?(x):(y))
#endif
DWORD g_dwInfoLevel = 0;
DWORD g_dwDebugBreak = 0;
DWORD PctTraceIndent = 0;
#define MAX_DEBUG_BUFFER 2048
void
BuildDebugHeader(
DWORD Mask,
PSTR pszHeader,
PDWORD pcbHeader);
void
SPDebugOutput(char *szOutString)
{
DWORD dwWritten;
if (NULL != g_hfLogFile)
{
WriteFile(
g_hfLogFile,
szOutString,
lstrlen(szOutString),
&dwWritten,
NULL);
}
OutputDebugStringA(szOutString);
}
void
DbgDumpHexString(const unsigned char *String, DWORD cbString)
{
DWORD i,count;
CHAR digits[]="0123456789abcdef";
CHAR pbLine[MAX_PATH];
DWORD cbLine, cbHeader;
DWORD_PTR address;
BuildDebugHeader(DEB_BUFFERS, pbLine, &cbHeader);
if(String == NULL && cbString != 0)
{
strcat(pbLine, "<null> buffer!!!\n");
SPDebugOutput(pbLine);
return;
}
for(; cbString ; cbString -= count, String += count)
{
count = (cbString > 16) ? 16:cbString;
cbLine = cbHeader;
address = (DWORD_PTR)String;
#if defined(_WIN64)
pbLine[cbLine++] = digits[(address >> 0x3c) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x38) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x34) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x30) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x2c) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x28) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x24) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x20) & 0x0f];
#endif
pbLine[cbLine++] = digits[(address >> 0x1c) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x18) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x14) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x10) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x0c) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x08) & 0x0f];
pbLine[cbLine++] = digits[(address >> 0x04) & 0x0f];
pbLine[cbLine++] = digits[(address ) & 0x0f];
pbLine[cbLine++] = ' ';
pbLine[cbLine++] = ' ';
for(i = 0; i < count; i++)
{
pbLine[cbLine++] = digits[String[i]>>4];
pbLine[cbLine++] = digits[String[i]&0x0f];
if(i == 7)
{
pbLine[cbLine++] = ':';
}
else
{
pbLine[cbLine++] = ' ';
}
}
#if 1
for(; i < 16; i++)
{
pbLine[cbLine++] = ' ';
pbLine[cbLine++] = ' ';
pbLine[cbLine++] = ' ';
}
pbLine[cbLine++] = ' ';
for(i = 0; i < count; i++)
{
if(String[i] < 32 || String[i] > 126)
{
pbLine[cbLine++] = '.';
}
else
{
pbLine[cbLine++] = String[i];
}
}
#endif
pbLine[cbLine++] = '\n';
pbLine[cbLine++] = 0;
SPDebugOutput(pbLine);
}
}
char *aszSPDebugLevel[] = {
"Error ",
"Warning",
"Trace ",
"Mem ",
"Result "
};
void
BuildDebugHeader(
DWORD Mask,
PSTR pszHeader,
PDWORD pcbHeader)
{
SYSTEMTIME stTime;
DWORD Level = 0;
ULONG ClientProcess;
ULONG ClientThread;
GetLocalTime(&stTime);
Level = 0;
while (!(Mask & 1))
{
Level++;
Mask >>= 1;
}
if (Level >= sizeof(aszSPDebugLevel) / sizeof(char *))
{
Level = sizeof(aszSPDebugLevel) / sizeof(char *) - 1;
}
SslGetClientProcess(&ClientProcess);
SslGetClientThread(&ClientThread);
*pcbHeader = 0;
if(g_dwInfoLevel & SP_LOG_TIMESTAMP)
{
*pcbHeader = wsprintf(
pszHeader,
"[%2d/%2d %02d:%02d:%02d.%03d] %d.%d> %s: ",
stTime.wMonth, stTime.wDay,
stTime.wHour, stTime.wMinute, stTime.wSecond,
stTime.wMilliseconds,
ClientProcess, ClientThread,
aszSPDebugLevel[Level]);
}
else
{
*pcbHeader = wsprintf(
pszHeader,
"%d.%d> %s: ",
ClientProcess, ClientThread,
aszSPDebugLevel[Level]);
}
}
void
SPDebugLog(long Mask, const char *Format, ...)
{
va_list ArgList;
int PrefixSize = 0;
int iOut;
char szOutString[MAX_DEBUG_BUFFER];
long OriginalMask = Mask;
if (Mask & g_dwInfoLevel)
{
BuildDebugHeader(Mask, szOutString, &iOut);
PrefixSize = min(60, PctTraceIndent * 3);
FillMemory(szOutString+iOut, PrefixSize, ' ');
PrefixSize += iOut;
szOutString[PrefixSize] = '\0';
va_start(ArgList, Format);
if (wvsprintf(&szOutString[PrefixSize], Format, ArgList) < 0)
{
static char szOverFlow[] = "\n<256 byte OVERFLOW!>\n";
// Less than zero indicates that the string would not fit into the
// buffer. Output a special message indicating overflow.
lstrcpy(
&szOutString[sizeof(szOutString) - sizeof(szOverFlow)],
szOverFlow);
}
va_end(ArgList);
SPDebugOutput(szOutString);
}
}
void
SPLogDistinguishedName(
DWORD LogLevel,
LPSTR pszLabel,
PBYTE pbName,
DWORD cbName)
{
CERT_NAME_BLOB Name;
LPSTR pszName;
DWORD cchName;
Name.pbData = pbName;
Name.cbData = cbName;
cchName = CertNameToStr(CRYPT_ASN_ENCODING,
&Name,
CERT_X500_NAME_STR | CERT_NAME_STR_NO_PLUS_FLAG,
NULL,
0);
if(cchName == 0)
{
return;
}
SafeAllocaAllocate(pszName, cchName);
if(pszName == NULL)
{
return;
}
cchName = CertNameToStr(CRYPT_ASN_ENCODING,
&Name,
CERT_X500_NAME_STR | CERT_NAME_STR_NO_PLUS_FLAG,
pszName,
cchName);
if(cchName == 0)
{
SafeAllocaFree(pszName);
return;
}
DebugLog((LogLevel, pszLabel, pszName));
SafeAllocaFree(pszName);
}
long
SPLogErrorCode(
long err,
const char *szFile,
long lLine)
{
char *szName = "Unknown";
switch(err)
{
case PCT_ERR_OK: szName = "PCT_ERR_OK"; break;
case PCT_ERR_BAD_CERTIFICATE: szName = "PCT_ERR_BAD_CERTIFICATE"; break;
case PCT_ERR_CLIENT_AUTH_FAILED: szName = "PCT_ERR_CLIENT_AUTH_FAILED"; break;
case PCT_ERR_ILLEGAL_MESSAGE: szName = "PCT_ERR_ILLEGAL_MESSAGE"; break;
case PCT_ERR_INTEGRITY_CHECK_FAILED: szName = "PCT_ERR_INTEGRITY_CHECK_FAILED"; break;
case PCT_ERR_SERVER_AUTH_FAILED: szName = "PCT_ERR_SERVER_AUTH_FAILED"; break;
case PCT_ERR_SPECS_MISMATCH: szName = "PCT_ERR_SPECS_MISMATCH"; break;
case PCT_ERR_SSL_STYLE_MSG: szName = "PCT_ERR_SSL_STYLE_MSG"; break;
case PCT_ERR_RENEGOTIATE: szName = "PCT_ERR_RENEGOTIATE"; break;
case PCT_ERR_UNKNOWN_CREDENTIAL: szName = "PCT_ERR_UNKNOWN_CREDENTIAL"; break;
case PCT_INT_BUFF_TOO_SMALL: szName = "PCT_INT_BUFF_TOO_SMALL"; break;
case PCT_INT_INCOMPLETE_MSG: szName = "PCT_INT_INCOMPLETE_MSG"; break;
case PCT_INT_DROP_CONNECTION: szName = "PCT_INT_DROP_CONNECTION"; break;
case PCT_INT_BAD_CERT: szName = "PCT_INT_BAD_CERT"; break;
case PCT_INT_CLI_AUTH: szName = "PCT_INT_CLI_AUTH"; break;
case PCT_INT_ILLEGAL_MSG: szName = "PCT_INT_ILLEGAL_MSG"; break;
case PCT_INT_MSG_ALTERED: szName = "PCT_INT_MSG_ALTERED"; break;
case PCT_INT_INTERNAL_ERROR: szName = "PCT_INT_INTERNAL_ERROR"; break;
case PCT_INT_DATA_OVERFLOW: szName = "PCT_INT_DATA_OVERFLOW"; break;
case PCT_INT_SPECS_MISMATCH: szName = "PCT_INT_SPECS_MISMATCH"; break;
case PCT_INT_RENEGOTIATE: szName = "PCT_INT_RENEGOTIATE"; break;
case PCT_INT_UNKNOWN_CREDENTIAL: szName = "PCT_INT_UNKNOWN_CREDENTIAL"; break;
case SEC_E_INSUFFICIENT_MEMORY: szName = "SEC_E_INSUFFICIENT_MEMORY"; break;
case SEC_E_INVALID_HANDLE: szName = "SEC_E_INVALID_HANDLE"; break;
case SEC_E_UNSUPPORTED_FUNCTION: szName = "SEC_E_UNSUPPORTED_FUNCTION"; break;
case SEC_E_TARGET_UNKNOWN: szName = "SEC_E_TARGET_UNKNOWN"; break;
case SEC_E_INTERNAL_ERROR: szName = "SEC_E_INTERNAL_ERROR"; break;
case SEC_E_SECPKG_NOT_FOUND: szName = "SEC_E_SECPKG_NOT_FOUND"; break;
case SEC_E_NOT_OWNER: szName = "SEC_E_NOT_OWNER"; break;
case SEC_E_CANNOT_INSTALL: szName = "SEC_E_CANNOT_INSTALL"; break;
case SEC_E_INVALID_TOKEN: szName = "SEC_E_INVALID_TOKEN"; break;
case SEC_E_CANNOT_PACK: szName = "SEC_E_CANNOT_PACK"; break;
case SEC_E_QOP_NOT_SUPPORTED: szName = "SEC_E_QOP_NOT_SUPPORTED"; break;
case SEC_E_NO_IMPERSONATION: szName = "SEC_E_NO_IMPERSONATION"; break;
case SEC_E_LOGON_DENIED: szName = "SEC_E_LOGON_DENIED"; break;
case SEC_E_UNKNOWN_CREDENTIALS: szName = "SEC_E_UNKNOWN_CREDENTIALS"; break;
case SEC_E_NO_CREDENTIALS: szName = "SEC_E_NO_CREDENTIALS"; break;
case SEC_E_MESSAGE_ALTERED: szName = "SEC_E_MESSAGE_ALTERED"; break;
case SEC_E_OUT_OF_SEQUENCE: szName = "SEC_E_OUT_OF_SEQUENCE"; break;
case SEC_E_NO_AUTHENTICATING_AUTHORITY: szName = "SEC_E_NO_AUTHENTICATING_AUTHORITY"; break;
case SEC_I_CONTINUE_NEEDED: szName = "SEC_I_CONTINUE_NEEDED"; break;
case SEC_I_COMPLETE_NEEDED: szName = "SEC_I_COMPLETE_NEEDED"; break;
case SEC_I_COMPLETE_AND_CONTINUE: szName = "SEC_I_COMPLETE_AND_CONTINUE"; break;
case SEC_I_LOCAL_LOGON: szName = "SEC_I_LOCAL_LOGON"; break;
case SEC_E_BAD_PKGID: szName = "SEC_E_BAD_PKGID"; break;
case SEC_E_CONTEXT_EXPIRED: szName = "SEC_E_CONTEXT_EXPIRED"; break;
case SEC_E_INCOMPLETE_MESSAGE: szName = "SEC_E_INCOMPLETE_MESSAGE"; break;
case SEC_E_INCOMPLETE_CREDENTIALS: szName = "SEC_E_INCOMPLETE_CREDENTIALS"; break;
case SEC_E_BUFFER_TOO_SMALL: szName = "SEC_E_BUFFER_TOO_SMALL"; break;
case SEC_I_INCOMPLETE_CREDENTIALS: szName = "SEC_I_INCOMPLETE_CREDENTIALS"; break;
case SEC_I_RENEGOTIATE: szName = "SEC_I_RENEGOTIATE"; break;
case SEC_E_WRONG_PRINCIPAL: szName = "SEC_E_WRONG_PRINCIPAL"; break;
case SEC_I_NO_LSA_CONTEXT: szName = "SEC_I_NO_LSA_CONTEXT"; break;
case CERT_E_EXPIRED: szName = "CERT_E_EXPIRED"; break;
case CERT_E_UNTRUSTEDROOT: szName = "CERT_E_UNTRUSTEDROOT"; break;
case CRYPT_E_REVOKED: szName = "CRYPT_E_REVOKED"; break;
case CRYPT_E_NO_REVOCATION_CHECK: szName = "CRYPT_E_NO_REVOCATION_CHECK"; break;
case CRYPT_E_REVOCATION_OFFLINE: szName = "CRYPT_E_REVOCATION_OFFLINE"; break;
}
SPDebugLog(SP_LOG_RES, "Result: %s (0x%lx) - %s, Line %d\n", szName, err, szFile, lLine);
return err;
}
#pragma warning(disable:4206) /* Disable the empty translation unit */
/* warning/error */
void
SPAssert(
void * FailedAssertion,
void * FileName,
unsigned long LineNumber,
char * Message)
{
SPDebugLog(SP_LOG_ERROR,
"Assertion FAILED, %s, %s : %d\n",
FailedAssertion,
FileName,
LineNumber);
DebugBreak();
}
VOID *
DBGAllocMem(DWORD cb, LPSTR szFile, DWORD iLine)
{
VOID *pv;
DWORD cbTotal = cb;
pv = LocalAlloc(LMEM_FIXED | LMEM_ZEROINIT, cbTotal);
if(pv == NULL)
{
SPDebugLog(SP_LOG_ERROR,
"Local Alloc Failed: %s, %d\n",
szFile,
iLine);
DebugBreak();
}
return(pv);
}
VOID
DBGFreeMem(VOID *pv, LPSTR szFile, DWORD iLine)
{
PVOID pvLocal = pv;
LocalFree(pvLocal);
}
#endif /* DBG */ /* NOTE: This file not compiled for retail builds */