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.
396 lines
9.8 KiB
396 lines
9.8 KiB
|
|
|
|
#include "precomp.h"
|
|
|
|
|
|
#define MAX_AUDIT_BUFFER 4096
|
|
|
|
#define MAX_MSG_BUFFER 2048
|
|
|
|
WCHAR gszAuditBuffer[MAX_AUDIT_BUFFER];
|
|
|
|
WCHAR * gpszAuditBuffer = gszAuditBuffer;
|
|
|
|
WCHAR gszAuditMsgBuffer[MAX_MSG_BUFFER];
|
|
|
|
WCHAR * gpszAuditMsgBuffer = gszAuditMsgBuffer;
|
|
|
|
wchar_t * SecStrCpyW(
|
|
wchar_t * strDest, // Destination
|
|
const wchar_t * strSource, // Source
|
|
SIZE_T destSize // Total size of Destination in characters.
|
|
)
|
|
{
|
|
strDest[destSize-1] = L'\0';
|
|
return wcsncpy(strDest, strSource, destSize-1);
|
|
}
|
|
|
|
|
|
wchar_t * SecStrCatW(
|
|
wchar_t * strDest, // Destination
|
|
const wchar_t * strSource, // Source
|
|
SIZE_T destSize // Total size of Destination in characters.
|
|
)
|
|
{
|
|
SSIZE_T spaceLeft = 0;
|
|
|
|
spaceLeft = destSize - wcslen(strDest);
|
|
if (spaceLeft > 0) {
|
|
strDest[destSize-1] = L'\0';
|
|
return wcsncat(strDest, strSource, spaceLeft-1);
|
|
}
|
|
else {
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
|
|
DWORD
|
|
PerformAudit(
|
|
DWORD dwCategoryId,
|
|
DWORD dwAuditId,
|
|
PSID pSid,
|
|
DWORD dwParamCnt,
|
|
LPWSTR * ppszArgArray,
|
|
BOOL bSuccess,
|
|
BOOL bDoAudit
|
|
)
|
|
{
|
|
SE_ADT_PARAMETER_ARRAY * pParArray = NULL;
|
|
NTSTATUS ntStatus = STATUS_SUCCESS;
|
|
DWORD dwStrSize = 0;
|
|
DWORD i = 0;
|
|
DWORD dwAllocSize = 0;
|
|
BYTE * pbyteCurAddr = NULL;
|
|
DWORD dwSidLength = RtlLengthSid(pSid);
|
|
UNICODE_STRING * pusStrArray = NULL;
|
|
WCHAR * pszModuleName = L"IPSec Server";
|
|
|
|
|
|
//
|
|
// dwCategoryId should be equal to SE_CATEGID_POLICY_CHANGE.
|
|
//
|
|
|
|
dwCategoryId = SE_CATEGID_POLICY_CHANGE;
|
|
|
|
for (i = 0; i < dwParamCnt; i++) {
|
|
dwStrSize += (wcslen(ppszArgArray[i]) + 1) * sizeof(WCHAR);
|
|
}
|
|
|
|
dwStrSize += (wcslen(pszModuleName) + 1) * sizeof(WCHAR);
|
|
|
|
dwAllocSize = sizeof(SE_ADT_PARAMETER_ARRAY) +
|
|
dwParamCnt * sizeof(UNICODE_STRING) + dwStrSize;
|
|
dwAllocSize += PtrAlignSize(dwSidLength);
|
|
|
|
if (dwAllocSize > MAX_AUDIT_BUFFER) {
|
|
return (ERROR_BUFFER_OVERFLOW);
|
|
}
|
|
|
|
pParArray = (SE_ADT_PARAMETER_ARRAY *) gpszAuditBuffer;
|
|
|
|
pParArray->CategoryId = dwCategoryId;
|
|
pParArray->AuditId = dwAuditId;
|
|
pParArray->ParameterCount = dwParamCnt + 2;
|
|
pParArray->Length = dwAllocSize;
|
|
pParArray->Flags = 0;
|
|
|
|
if (bSuccess) {
|
|
pParArray->Type = EVENTLOG_AUDIT_SUCCESS;
|
|
}
|
|
else {
|
|
pParArray->Type = EVENTLOG_AUDIT_FAILURE;
|
|
}
|
|
|
|
pbyteCurAddr = (BYTE *) (pParArray + 1);
|
|
|
|
pParArray->Parameters[0].Type = SeAdtParmTypeSid;
|
|
pParArray->Parameters[0].Length = dwSidLength;
|
|
pParArray->Parameters[0].Data[0] = 0;
|
|
pParArray->Parameters[0].Data[1] = 0;
|
|
pParArray->Parameters[0].Address = pSid;
|
|
|
|
memcpy((BYTE *) pbyteCurAddr, (BYTE *) pSid, dwSidLength);
|
|
|
|
pbyteCurAddr = (BYTE *) pbyteCurAddr + PtrAlignSize(dwSidLength);
|
|
|
|
pusStrArray = (UNICODE_STRING *) pbyteCurAddr;
|
|
|
|
pusStrArray[0].Length = wcslen(pszModuleName) * sizeof(WCHAR);
|
|
pusStrArray[0].MaximumLength = pusStrArray[0].Length + sizeof(WCHAR);
|
|
pusStrArray[0].Buffer = (LPWSTR) pszModuleName;
|
|
|
|
pParArray->Parameters[1].Type = SeAdtParmTypeString;
|
|
pParArray->Parameters[1].Length = sizeof(UNICODE_STRING) +
|
|
pusStrArray[0].MaximumLength;
|
|
pParArray->Parameters[1].Data[0] = 0;
|
|
pParArray->Parameters[1].Data[1] = 0;
|
|
pParArray->Parameters[1].Address = (PVOID) &pusStrArray[0];
|
|
|
|
for (i = 0; i < dwParamCnt; i++) {
|
|
|
|
pusStrArray[i+1].Length = wcslen(ppszArgArray[i]) * sizeof(WCHAR);
|
|
pusStrArray[i+1].MaximumLength = pusStrArray[i+1].Length + sizeof(WCHAR);
|
|
pusStrArray[i+1].Buffer = (LPWSTR) ppszArgArray[i];
|
|
|
|
pParArray->Parameters[i+2].Type = SeAdtParmTypeString;
|
|
pParArray->Parameters[i+2].Length = sizeof(UNICODE_STRING) +
|
|
pusStrArray[i+1].MaximumLength;
|
|
pParArray->Parameters[i+2].Data[0] = 0;
|
|
pParArray->Parameters[i+2].Data[1] = 0;
|
|
pParArray->Parameters[i+2].Address = (PVOID) &pusStrArray[i+1];
|
|
|
|
}
|
|
|
|
if (bDoAudit) {
|
|
ntStatus = LsaIWriteAuditEvent(pParArray, 0);
|
|
}
|
|
|
|
return (ERROR_SUCCESS);
|
|
}
|
|
|
|
|
|
VOID
|
|
AuditEvent(
|
|
DWORD dwCategoryId,
|
|
DWORD dwAuditId,
|
|
DWORD dwStrId,
|
|
LPWSTR * ppszArguments,
|
|
BOOL bSuccess,
|
|
BOOL bDoAudit
|
|
)
|
|
{
|
|
DWORD dwError = 0;
|
|
LPWSTR pszArgArray[3];
|
|
DWORD dwParamCnt = 0;
|
|
|
|
|
|
EnterCriticalSection(&gcSPDAuditSection);
|
|
|
|
dwError = FormatMessage(
|
|
FORMAT_MESSAGE_FROM_HMODULE |
|
|
FORMAT_MESSAGE_ARGUMENT_ARRAY,
|
|
ghIpsecServerModule,
|
|
dwStrId,
|
|
LANG_NEUTRAL,
|
|
gpszAuditMsgBuffer,
|
|
MAX_MSG_BUFFER,
|
|
(va_list *) ppszArguments
|
|
);
|
|
if (dwError == 0) {
|
|
wsprintf(
|
|
gpszAuditMsgBuffer,
|
|
L"IPSec Services encountered an error while auditing event ID 0x%x",
|
|
dwStrId
|
|
);
|
|
}
|
|
|
|
gpszAuditMsgBuffer[MAX_MSG_BUFFER - 1] = 0;
|
|
|
|
if (dwError != 0) {
|
|
|
|
switch (dwAuditId) {
|
|
|
|
case SE_AUDITID_IPSEC_POLICY_CHANGED:
|
|
dwParamCnt = 1;
|
|
pszArgArray[0] = (LPWSTR) gpszAuditMsgBuffer;
|
|
break;
|
|
|
|
default:
|
|
LeaveCriticalSection(&gcSPDAuditSection);
|
|
return;
|
|
|
|
}
|
|
|
|
(VOID) PerformAudit(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
gpIpsecServerSid,
|
|
dwParamCnt,
|
|
(LPWSTR *) pszArgArray,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
|
|
}
|
|
|
|
LeaveCriticalSection(&gcSPDAuditSection);
|
|
return;
|
|
}
|
|
|
|
|
|
VOID
|
|
AuditOneArgErrorEvent(
|
|
DWORD dwCategoryId,
|
|
DWORD dwAuditId,
|
|
DWORD dwStrId,
|
|
DWORD dwErrorCode,
|
|
BOOL bSuccess,
|
|
BOOL bDoAudit
|
|
)
|
|
{
|
|
DWORD dwError = 0;
|
|
LPVOID lpvMsgBuf = NULL;
|
|
WCHAR szAuditLocalMsgBuffer[MAX_PATH];
|
|
WCHAR * pszAuditLocalMsgBuffer = szAuditLocalMsgBuffer;
|
|
|
|
|
|
szAuditLocalMsgBuffer[0] = L'\0';
|
|
|
|
dwError = FormatMessage(
|
|
FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_FROM_SYSTEM |
|
|
FORMAT_MESSAGE_IGNORE_INSERTS,
|
|
NULL,
|
|
dwErrorCode,
|
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
|
|
(LPWSTR) &lpvMsgBuf,
|
|
0,
|
|
NULL
|
|
);
|
|
if (!dwError) {
|
|
wsprintf(
|
|
pszAuditLocalMsgBuffer,
|
|
L"0x%x",
|
|
dwErrorCode
|
|
);
|
|
AuditEvent(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
dwStrId,
|
|
(LPWSTR *) &pszAuditLocalMsgBuffer,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
return;
|
|
}
|
|
|
|
AuditEvent(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
dwStrId,
|
|
(LPWSTR *) &lpvMsgBuf,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
|
|
if (lpvMsgBuf) {
|
|
LocalFree(lpvMsgBuf);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
VOID
|
|
AuditIPSecPolicyEvent(
|
|
DWORD dwCategoryId,
|
|
DWORD dwAuditId,
|
|
DWORD dwStrId,
|
|
LPWSTR pszPolicyName,
|
|
BOOL bSuccess,
|
|
BOOL bDoAudit
|
|
)
|
|
{
|
|
WCHAR szAuditLocalMsgBuffer[MAX_PATH];
|
|
WCHAR * pszAuditLocalMsgBuffer = szAuditLocalMsgBuffer;
|
|
|
|
|
|
szAuditLocalMsgBuffer[0] = L'\0';
|
|
if (pszPolicyName) {
|
|
SecStrCpyW(pszAuditLocalMsgBuffer, pszPolicyName, MAX_PATH);
|
|
} else {
|
|
SecStrCpyW(pszAuditLocalMsgBuffer, UKNOWN_POLICY_NAME, MAX_PATH);
|
|
}
|
|
|
|
AuditEvent(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
dwStrId,
|
|
(LPWSTR *) &pszAuditLocalMsgBuffer,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
VOID
|
|
AuditIPSecPolicyErrorEvent(
|
|
DWORD dwCategoryId,
|
|
DWORD dwAuditId,
|
|
DWORD dwStrId,
|
|
LPWSTR pszPolicyName,
|
|
DWORD dwErrorCode,
|
|
BOOL bSuccess,
|
|
BOOL bDoAudit
|
|
)
|
|
{
|
|
DWORD dwError = 0;
|
|
WCHAR szAuditPolicyMsgBuffer[MAX_PATH];
|
|
WCHAR * pszAuditPolicyMsgBuffer = szAuditPolicyMsgBuffer;
|
|
WCHAR szAuditErrorMsgBuffer[MAX_PATH];
|
|
WCHAR * pszAuditErrorMsgBuffer = szAuditErrorMsgBuffer;
|
|
LPWSTR pszArgArray[2];
|
|
LPWSTR * ppszArgArray = pszArgArray;
|
|
LPVOID lpvMsgBuf = NULL;
|
|
|
|
|
|
szAuditPolicyMsgBuffer[0] = L'\0';
|
|
szAuditErrorMsgBuffer[0] = L'\0';
|
|
|
|
if (pszPolicyName) {
|
|
SecStrCpyW(pszAuditPolicyMsgBuffer, pszPolicyName, MAX_PATH);
|
|
} else {
|
|
SecStrCpyW(pszAuditPolicyMsgBuffer, UKNOWN_POLICY_NAME, MAX_PATH);
|
|
}
|
|
|
|
dwError = FormatMessage(
|
|
FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_FROM_SYSTEM |
|
|
FORMAT_MESSAGE_IGNORE_INSERTS,
|
|
NULL,
|
|
dwErrorCode,
|
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
|
|
(LPWSTR) &lpvMsgBuf,
|
|
0,
|
|
NULL
|
|
);
|
|
if (!dwError) {
|
|
wsprintf(
|
|
pszAuditErrorMsgBuffer,
|
|
L"0x%x",
|
|
dwErrorCode
|
|
);
|
|
pszArgArray[0] = pszAuditPolicyMsgBuffer;
|
|
pszArgArray[1] = pszAuditErrorMsgBuffer;
|
|
AuditEvent(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
dwStrId,
|
|
(LPWSTR *) ppszArgArray,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
return;
|
|
}
|
|
|
|
pszArgArray[0] = pszAuditPolicyMsgBuffer;
|
|
pszArgArray[1] = (LPWSTR) lpvMsgBuf;
|
|
AuditEvent(
|
|
dwCategoryId,
|
|
dwAuditId,
|
|
dwStrId,
|
|
(LPWSTR *) ppszArgArray,
|
|
bSuccess,
|
|
bDoAudit
|
|
);
|
|
|
|
if (lpvMsgBuf) {
|
|
LocalFree(lpvMsgBuf);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|