|
|
/*++
Copyright (c) 1999 Microsoft Corporation
Module Name:
mmauth.c
Abstract:
Author:
abhishev 06-January-2000
Environment: User Mode
Revision History:
--*/
#include "precomp.h"
#ifdef TRACE_ON
#include "mmauth.tmh"
#endif
DWORD WINAPI IntAddMMAuthMethods( LPWSTR pServerName, DWORD dwVersion, DWORD dwFlags, DWORD dwSource, PINT_MM_AUTH_METHODS pMMAuthMethods, LPVOID pvReserved ) /*++
Routine Description:
This function adds main mode auths to the SPD.
Arguments:
pServerName - Server on which the main mode auths are to be added.
pMMAuthMethods - Main mode auths to be added.
Return Value:
ERROR_SUCCESS - Success.
Win32 Error - Failure.
--*/ { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
//
// Validate the main mode auth methods.
//
dwError = IntValidateMMAuthMethods( pMMAuthMethods ); BAIL_ON_WIN32_ERROR(dwError);
ENTER_SPD_SECTION();
dwError = ValidateSecurity( SPD_OBJECT_SERVER, SERVER_ACCESS_ADMINISTER, NULL, NULL ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods = FindMMAuthMethods( gpIniMMAuthMethods, pMMAuthMethods->gMMAuthID ); if (pIniMMAuthMethods) { dwError = ERROR_IPSEC_MM_AUTH_EXISTS; BAIL_ON_LOCK_ERROR(dwError); }
dwError = CreateIniMMAuthMethods( pMMAuthMethods, &pIniMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods->dwSource = dwSource;
pIniMMAuthMethods->pNext = gpIniMMAuthMethods; gpIniMMAuthMethods = pIniMMAuthMethods;
if ((pIniMMAuthMethods->dwFlags) & IPSEC_MM_AUTH_DEFAULT_AUTH) { gpIniDefaultMMAuthMethods = pIniMMAuthMethods; TRACE( TRC_INFORMATION, (L"Set default MM auth methods to %!guid!", &pIniMMAuthMethods->gMMAuthID) ); }
LEAVE_SPD_SECTION();
TRACE( TRC_INFORMATION, (L"Added MM auth methods %!guid!", &pIniMMAuthMethods->gMMAuthID) ); return (dwError);
lock:
LEAVE_SPD_SECTION();
error: #ifdef TRACE_ON
if (pMMAuthMethods) { TRACE( TRC_ERROR, (L"Failed to add MM auth methods %!guid!: %!winerr!", &pMMAuthMethods->gMMAuthID, dwError) ); } else { TRACE( TRC_ERROR, (L"Failed to add MM auth methods. Details unvailable since pMMAuthMethods is null: %!winerr!", dwError) ); } #endif
return (dwError); }
DWORD IntValidateMMAuthMethods( PINT_MM_AUTH_METHODS pMMAuthMethods ) { DWORD dwError = 0; DWORD i = 0; PINT_IPSEC_MM_AUTH_INFO pTemp = NULL; DWORD dwNumAuthInfos = 0; PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo = NULL; BOOL bSSPI = FALSE; BOOL bPresharedKey = FALSE;
if (!pMMAuthMethods) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); }
dwNumAuthInfos = pMMAuthMethods->dwNumAuthInfos; pAuthenticationInfo = pMMAuthMethods->pAuthenticationInfo;
if (!dwNumAuthInfos || !pAuthenticationInfo) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); }
//
// Need to catch the exception when the number of auth infos
// specified is more than the actual number of auth infos.
//
pTemp = pAuthenticationInfo;
for (i = 0; i < dwNumAuthInfos; i++) {
if ((pTemp->AuthMethod != IKE_PRESHARED_KEY) && (pTemp->AuthMethod != IKE_RSA_SIGNATURE) && (pTemp->AuthMethod != IKE_SSPI)) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); }
if (pTemp->AuthMethod != IKE_SSPI) { if (!(pTemp->dwAuthInfoSize) || !(pTemp->pAuthInfo)) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); } }
if (pTemp->AuthMethod == IKE_SSPI) { if (bSSPI) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); } bSSPI = TRUE; }
if (pTemp->AuthMethod == IKE_PRESHARED_KEY) { if (bPresharedKey) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); } bPresharedKey = TRUE; }
pTemp++;
}
error: #ifdef TRACE_ON
if (dwError) { if (pMMAuthMethods) { TRACE( TRC_ERROR, (L"Failed MM Auth method validation %!guid!: %!winerr!", &pMMAuthMethods->gMMAuthID, dwError) ); } else { TRACE( TRC_ERROR, (L"Failed MM Auth method validation. No details available since pMMAuthMethods is null : %!winerr!", dwError) ); } } #endif
return (dwError); }
PINIMMAUTHMETHODS FindMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods, GUID gMMAuthID ) { DWORD dwError = 0; PINIMMAUTHMETHODS pTemp = NULL;
pTemp = pIniMMAuthMethods;
while (pTemp) {
if (!memcmp(&(pTemp->gMMAuthID), &gMMAuthID, sizeof(GUID))) { return (pTemp); } pTemp = pTemp->pNext;
}
return (NULL); }
DWORD CreateIniMMAuthMethods( PINT_MM_AUTH_METHODS pMMAuthMethods, PINIMMAUTHMETHODS * ppIniMMAuthMethods ) { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
dwError = AllocateSPDMemory( sizeof(INIMMAUTHMETHODS), &pIniMMAuthMethods ); BAIL_ON_WIN32_ERROR(dwError);
memcpy( &(pIniMMAuthMethods->gMMAuthID), &(pMMAuthMethods->gMMAuthID), sizeof(GUID) );
pIniMMAuthMethods->dwFlags = pMMAuthMethods->dwFlags; pIniMMAuthMethods->cRef = 0; pIniMMAuthMethods->dwSource = 0; pIniMMAuthMethods->pNext = NULL;
dwError = CreateIniMMAuthInfos( pMMAuthMethods->dwNumAuthInfos, pMMAuthMethods->pAuthenticationInfo, &(pIniMMAuthMethods->dwNumAuthInfos), &(pIniMMAuthMethods->pAuthenticationInfo) ); BAIL_ON_WIN32_ERROR(dwError);
*ppIniMMAuthMethods = pIniMMAuthMethods; return (dwError);
error: TRACE( TRC_ERROR, ("Failed to create MM auth method node %!guid!: %!winerr!", &pMMAuthMethods->gMMAuthID, dwError) ); if (pIniMMAuthMethods) { FreeIniMMAuthMethods( pIniMMAuthMethods ); }
*ppIniMMAuthMethods = NULL; return (dwError); }
DWORD CreateIniMMAuthInfos( DWORD dwInNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO pInAuthenticationInfo, PDWORD pdwNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO * ppAuthenticationInfo ) { DWORD dwError = 0; PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo = NULL; PINT_IPSEC_MM_AUTH_INFO pTemp = NULL; PINT_IPSEC_MM_AUTH_INFO pInTemp = NULL; DWORD i = 0;
//
// Number of auth infos and the auth infos themselves
// have already been validated.
//
dwError = AllocateSPDMemory( sizeof(INT_IPSEC_MM_AUTH_INFO) * dwInNumAuthInfos, &(pAuthenticationInfo) ); BAIL_ON_WIN32_ERROR(dwError);
pTemp = pAuthenticationInfo; pInTemp = pInAuthenticationInfo;
for (i = 0; i < dwInNumAuthInfos; i++) {
pTemp->AuthMethod = pInTemp->AuthMethod; pTemp->dwAuthFlags = pInTemp->dwAuthFlags;
if (pInTemp->AuthMethod == IKE_SSPI) {
pTemp->dwAuthInfoSize = 0; pTemp->pAuthInfo = NULL;
} else {
if (!(pInTemp->dwAuthInfoSize) || !(pInTemp->pAuthInfo)) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_WIN32_ERROR(dwError); }
dwError = AllocateSPDMemory( pInTemp->dwAuthInfoSize, &(pTemp->pAuthInfo) ); BAIL_ON_WIN32_ERROR(dwError);
pTemp->dwAuthInfoSize = pInTemp->dwAuthInfoSize;
//
// Need to catch the exception when the size of auth info
// specified is more than the actual size. This can
// not be checked earlier in the validation routine.
//
//
memcpy( pTemp->pAuthInfo, pInTemp->pAuthInfo, pInTemp->dwAuthInfoSize );
}
pInTemp++; pTemp++;
}
*pdwNumAuthInfos = dwInNumAuthInfos; *ppAuthenticationInfo = pAuthenticationInfo; return (dwError);
error: TRACE(TRC_ERROR, ("Failed to create MM auth infos node: %!winerr!", dwError)); if (pAuthenticationInfo) { FreeIniMMAuthInfos( i, pAuthenticationInfo ); }
*pdwNumAuthInfos = 0; *ppAuthenticationInfo = NULL; return (dwError); }
VOID FreeIniMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods ) { if (pIniMMAuthMethods) {
FreeIniMMAuthInfos( pIniMMAuthMethods->dwNumAuthInfos, pIniMMAuthMethods->pAuthenticationInfo );
FreeSPDMemory(pIniMMAuthMethods);
} }
VOID FreeIniMMAuthInfos( DWORD dwNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo ) { DWORD i = 0; PINT_IPSEC_MM_AUTH_INFO pTemp = NULL;
if (pAuthenticationInfo) {
pTemp = pAuthenticationInfo;
for (i = 0; i < dwNumAuthInfos; i++) { if (pTemp->pAuthInfo) { FreeSPDMemory(pTemp->pAuthInfo); } pTemp++; }
FreeSPDMemory(pAuthenticationInfo);
} }
DWORD WINAPI DeleteMMAuthMethods( LPWSTR pServerName, DWORD dwVersion, GUID gMMAuthID, LPVOID pvReserved ) /*++
Routine Description:
This function deletes main mode auth methods from the SPD.
Arguments:
pServerName - Server on which the main mode auth methods are to be deleted.
gMMAuthID - Main mode methods to be deleted.
Return Value:
ERROR_SUCCESS - Success.
Win32 Error - Failure.
--*/ { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
ENTER_SPD_SECTION();
dwError = ValidateSecurity( SPD_OBJECT_SERVER, SERVER_ACCESS_ADMINISTER, NULL, NULL ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods = FindMMAuthMethods( gpIniMMAuthMethods, gMMAuthID ); if (!pIniMMAuthMethods) { dwError = ERROR_IPSEC_MM_AUTH_NOT_FOUND; BAIL_ON_LOCK_ERROR(dwError); }
if (pIniMMAuthMethods->cRef) { dwError = ERROR_IPSEC_MM_AUTH_IN_USE; BAIL_ON_LOCK_ERROR(dwError); }
dwError = DeleteIniMMAuthMethods( pIniMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
LEAVE_SPD_SECTION();
if (gbIKENotify) { (VOID) IKENotifyPolicyChange( &(gMMAuthID), POLICY_GUID_AUTH ); }
TRACE( TRC_INFORMATION, (L"Deleted MM auth methods %!guid!", &gMMAuthID) ); return (dwError);
lock: TRACE( TRC_ERROR, (L"Failed to delete MM auth methods %!guid!: %!winerr!", &gMMAuthID, dwError) );
LEAVE_SPD_SECTION();
return (dwError); }
DWORD DeleteIniMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods ) { DWORD dwError = 0; PINIMMAUTHMETHODS * ppTemp = NULL;
ppTemp = &gpIniMMAuthMethods;
while (*ppTemp) {
if (*ppTemp == pIniMMAuthMethods) { break; } ppTemp = &((*ppTemp)->pNext);
}
if (*ppTemp) { *ppTemp = pIniMMAuthMethods->pNext; }
if ((pIniMMAuthMethods->dwFlags) & IPSEC_MM_AUTH_DEFAULT_AUTH) { gpIniDefaultMMAuthMethods = NULL; TRACE( TRC_INFORMATION, (L"Cleared default MM auth methods") ); }
FreeIniMMAuthMethods(pIniMMAuthMethods);
return (dwError); }
DWORD WINAPI IntEnumMMAuthMethods( LPWSTR pServerName, DWORD dwVersion, PINT_MM_AUTH_METHODS pMMTemplateAuthMethods, DWORD dwFlags, DWORD dwPreferredNumEntries, PINT_MM_AUTH_METHODS * ppMMAuthMethods, LPDWORD pdwNumAuthMethods, LPDWORD pdwResumeHandle, LPVOID pvReserved ) /*++
Routine Description:
This function enumerates main mode auth methods from the SPD.
Arguments:
pServerName - Server on which the main mode auth methods are to be enumerated.
ppMMAuthMethods - Enumerated main mode auth methods returned to the caller.
dwPreferredNumEntries - Preferred number of enumeration entries.
pdwNumAuthMethods - Number of main mode auth methods actually enumerated.
pdwResumeHandle - Handle to the location in the main mode auth methods list from which to resume enumeration.
Return Value:
ERROR_SUCCESS - Success.
Win32 Error - Failure.
--*/ { DWORD dwError = 0; DWORD dwResumeHandle = 0; DWORD dwNumToEnum = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL; DWORD i = 0; PINIMMAUTHMETHODS pTemp = NULL; DWORD dwNumAuthMethods = 0; PINT_MM_AUTH_METHODS pMMAuthMethods = NULL; PINT_MM_AUTH_METHODS pTempMMAuthMethods = NULL;
dwResumeHandle = *pdwResumeHandle;
if (!dwPreferredNumEntries || (dwPreferredNumEntries > MAX_MMAUTH_ENUM_COUNT)) { dwNumToEnum = MAX_MMAUTH_ENUM_COUNT; } else { dwNumToEnum = dwPreferredNumEntries; }
ENTER_SPD_SECTION();
dwError = ValidateSecurity( SPD_OBJECT_SERVER, SERVER_ACCESS_ADMINISTER, NULL, NULL ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods = gpIniMMAuthMethods;
for (i = 0; (i < dwResumeHandle) && (pIniMMAuthMethods != NULL); i++) { pIniMMAuthMethods = pIniMMAuthMethods->pNext; }
if (!pIniMMAuthMethods) { dwError = ERROR_NO_DATA; BAIL_ON_LOCK_ERROR(dwError); }
pTemp = pIniMMAuthMethods;
while (pTemp && (dwNumAuthMethods < dwNumToEnum)) { dwNumAuthMethods++; pTemp = pTemp->pNext; }
dwError = SPDApiBufferAllocate( sizeof(INT_MM_AUTH_METHODS)*dwNumAuthMethods, &pMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
pTemp = pIniMMAuthMethods; pTempMMAuthMethods = pMMAuthMethods;
for (i = 0; i < dwNumAuthMethods; i++) {
dwError = CopyMMAuthMethods( pTemp, pTempMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
pTemp = pTemp->pNext; pTempMMAuthMethods++;
}
*ppMMAuthMethods = pMMAuthMethods; *pdwResumeHandle = dwResumeHandle + dwNumAuthMethods; *pdwNumAuthMethods = dwNumAuthMethods;
LEAVE_SPD_SECTION();
TRACE(TRC_INFORMATION, (L"Enumerated MM auth methods")); return (dwError);
lock: TRACE(TRC_ERROR, (L"Failed to enumerate MM auth methods: %!winerr!", dwError));
LEAVE_SPD_SECTION();
if (pMMAuthMethods) { FreeMMAuthMethods( i, pMMAuthMethods ); }
*ppMMAuthMethods = NULL; *pdwResumeHandle = dwResumeHandle; *pdwNumAuthMethods = 0;
return (dwError); }
DWORD WINAPI IntSetMMAuthMethods( LPWSTR pServerName, DWORD dwVersion, GUID gMMAuthID, PINT_MM_AUTH_METHODS pMMAuthMethods, LPVOID pvReserved ) /*++
Routine Description:
This function updates main mode auth methods in the SPD.
Arguments:
pServerName - Server on which the main mode auth methods are to be updated.
gMMAuthID - Guid of the main mode auth methods to be updated.
pMMAuthMethods - New main mode auth methods which will replace the existing methods.
Return Value:
ERROR_SUCCESS - Success.
Win32 Error - Failure.
--*/ { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
//
// Validate main mode auth methods.
//
dwError = IntValidateMMAuthMethods( pMMAuthMethods ); BAIL_ON_WIN32_ERROR(dwError);
ENTER_SPD_SECTION();
dwError = ValidateSecurity( SPD_OBJECT_SERVER, SERVER_ACCESS_ADMINISTER, NULL, NULL ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods = FindMMAuthMethods( gpIniMMAuthMethods, gMMAuthID ); if (!pIniMMAuthMethods) { dwError = ERROR_IPSEC_MM_AUTH_NOT_FOUND; BAIL_ON_LOCK_ERROR(dwError); }
if (memcmp( &(pIniMMAuthMethods->gMMAuthID), &(pMMAuthMethods->gMMAuthID), sizeof(GUID))) { dwError = ERROR_INVALID_PARAMETER; BAIL_ON_LOCK_ERROR(dwError); }
dwError = SetIniMMAuthMethods( pIniMMAuthMethods, pMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
LEAVE_SPD_SECTION();
(VOID) IKENotifyPolicyChange( &(pMMAuthMethods->gMMAuthID), POLICY_GUID_AUTH );
TRACE( TRC_INFORMATION, (L"Changed MM auth methods %!guid!", &pMMAuthMethods->gMMAuthID) ); return (dwError);
lock:
LEAVE_SPD_SECTION();
error: TRACE( TRC_ERROR, (L"Failed to change MM auth method %!guid!: %!winerr!", &gMMAuthID, dwError) );
return (dwError); }
DWORD SetIniMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods, PINT_MM_AUTH_METHODS pMMAuthMethods ) { DWORD dwError = 0; DWORD dwNumAuthInfos = 0; PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo = NULL;
dwError = CreateIniMMAuthInfos( pMMAuthMethods->dwNumAuthInfos, pMMAuthMethods->pAuthenticationInfo, &dwNumAuthInfos, &pAuthenticationInfo ); BAIL_ON_WIN32_ERROR(dwError);
FreeIniMMAuthInfos( pIniMMAuthMethods->dwNumAuthInfos, pIniMMAuthMethods->pAuthenticationInfo ); if ((pIniMMAuthMethods->dwFlags) & IPSEC_MM_AUTH_DEFAULT_AUTH) { gpIniDefaultMMAuthMethods = NULL; TRACE(TRC_INFORMATION, (L"Cleared default MM auth methods")); }
pIniMMAuthMethods->dwFlags = pMMAuthMethods->dwFlags; pIniMMAuthMethods->dwNumAuthInfos = dwNumAuthInfos; pIniMMAuthMethods->pAuthenticationInfo = pAuthenticationInfo;
if ((pIniMMAuthMethods->dwFlags) & IPSEC_MM_AUTH_DEFAULT_AUTH) { gpIniDefaultMMAuthMethods = pIniMMAuthMethods; TRACE( TRC_INFORMATION, (L"Set default MM auth methods to %!guid!", &pIniMMAuthMethods->gMMAuthID) ); }
error:
return (dwError); }
DWORD WINAPI IntGetMMAuthMethods( LPWSTR pServerName, DWORD dwVersion, GUID gMMAuthID, PINT_MM_AUTH_METHODS * ppMMAuthMethods, LPVOID pvReserved ) /*++
Routine Description:
This function gets main mode auth methods from the SPD.
Arguments:
pServerName - Server from which to get the main mode auth methods.
gMMAuthID - Guid of the main mode auth methods to get.
ppMMAuthMethods - Main mode auth methods found returned to the caller.
Return Value:
ERROR_SUCCESS - Success.
Win32 Error - Failure.
--*/ { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL; PINT_MM_AUTH_METHODS pMMAuthMethods = NULL;
ENTER_SPD_SECTION();
dwError = ValidateSecurity( SPD_OBJECT_SERVER, SERVER_ACCESS_ADMINISTER, NULL, NULL ); BAIL_ON_LOCK_ERROR(dwError);
pIniMMAuthMethods = FindMMAuthMethods( gpIniMMAuthMethods, gMMAuthID ); if (!pIniMMAuthMethods) { dwError = ERROR_IPSEC_MM_AUTH_NOT_FOUND; BAIL_ON_LOCK_ERROR(dwError); }
dwError = GetIniMMAuthMethods( pIniMMAuthMethods, &pMMAuthMethods ); BAIL_ON_LOCK_ERROR(dwError);
*ppMMAuthMethods = pMMAuthMethods;
LEAVE_SPD_SECTION(); return (dwError);
lock:
LEAVE_SPD_SECTION();
*ppMMAuthMethods = NULL; return (dwError); }
DWORD GetIniMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods, PINT_MM_AUTH_METHODS * ppMMAuthMethods ) { DWORD dwError = 0; PINT_MM_AUTH_METHODS pMMAuthMethods = NULL;
dwError = SPDApiBufferAllocate( sizeof(INT_MM_AUTH_METHODS), &pMMAuthMethods ); BAIL_ON_WIN32_ERROR(dwError);
dwError = CopyMMAuthMethods( pIniMMAuthMethods, pMMAuthMethods ); BAIL_ON_WIN32_ERROR(dwError);
*ppMMAuthMethods = pMMAuthMethods; return (dwError);
error:
if (pMMAuthMethods) { SPDApiBufferFree(pMMAuthMethods); }
*ppMMAuthMethods = NULL; return (dwError); }
DWORD CopyMMAuthMethods( PINIMMAUTHMETHODS pIniMMAuthMethods, PINT_MM_AUTH_METHODS pMMAuthMethods ) { DWORD dwError = 0;
memcpy( &(pMMAuthMethods->gMMAuthID), &(pIniMMAuthMethods->gMMAuthID), sizeof(GUID) );
pMMAuthMethods->dwFlags = pIniMMAuthMethods->dwFlags;
dwError = CreateMMAuthInfos( pIniMMAuthMethods->dwNumAuthInfos, pIniMMAuthMethods->pAuthenticationInfo, &(pMMAuthMethods->dwNumAuthInfos), &(pMMAuthMethods->pAuthenticationInfo) ); BAIL_ON_WIN32_ERROR(dwError);
error:
return (dwError); }
DWORD CreateMMAuthInfos( DWORD dwInNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO pInAuthenticationInfo, PDWORD pdwNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO * ppAuthenticationInfo ) { DWORD dwError = 0; PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo = NULL; PINT_IPSEC_MM_AUTH_INFO pTemp = NULL; PINT_IPSEC_MM_AUTH_INFO pInTemp = NULL; DWORD i = 0;
//
// Number of auth infos and the auth infos themselves
// have already been validated.
//
dwError = SPDApiBufferAllocate( sizeof(INT_IPSEC_MM_AUTH_INFO) * dwInNumAuthInfos, &(pAuthenticationInfo) ); BAIL_ON_WIN32_ERROR(dwError);
pTemp = pAuthenticationInfo; pInTemp = pInAuthenticationInfo;
for (i = 0; i < dwInNumAuthInfos; i++) {
pTemp->AuthMethod = pInTemp->AuthMethod; pTemp->dwAuthFlags = pInTemp->dwAuthFlags;
//
// Auth info size and the auth info have already
// been validated.
//
if (pInTemp->AuthMethod == IKE_SSPI) {
pTemp->dwAuthInfoSize = 0; pTemp->pAuthInfo = NULL;
} else {
dwError = SPDApiBufferAllocate( pInTemp->dwAuthInfoSize, &(pTemp->pAuthInfo) ); BAIL_ON_WIN32_ERROR(dwError);
pTemp->dwAuthInfoSize = pInTemp->dwAuthInfoSize;
//
// Need to catch the exception when the size of auth info
// specified is more than the actual size. This can
// not be checked earlier in the validation routine.
//
//
memcpy( pTemp->pAuthInfo, pInTemp->pAuthInfo, pInTemp->dwAuthInfoSize );
}
pInTemp++; pTemp++;
}
*pdwNumAuthInfos = dwInNumAuthInfos; *ppAuthenticationInfo = pAuthenticationInfo; return (dwError);
error:
if (pAuthenticationInfo) { FreeMMAuthInfos( i, pAuthenticationInfo ); }
*pdwNumAuthInfos = 0; *ppAuthenticationInfo = NULL; return (dwError); }
VOID FreeMMAuthInfos( DWORD dwNumAuthInfos, PINT_IPSEC_MM_AUTH_INFO pAuthenticationInfo ) { DWORD i = 0; PINT_IPSEC_MM_AUTH_INFO pTemp = NULL;
if (pAuthenticationInfo) {
pTemp = pAuthenticationInfo;
for (i = 0; i < dwNumAuthInfos; i++) { if (pTemp->pAuthInfo) { SPDApiBufferFree(pTemp->pAuthInfo); } pTemp++; }
SPDApiBufferFree(pAuthenticationInfo);
} }
VOID FreeIniMMAuthMethodsList( PINIMMAUTHMETHODS pIniMMAuthMethodsList ) { PINIMMAUTHMETHODS pTemp = NULL; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
pTemp = pIniMMAuthMethodsList;
while (pTemp) {
pIniMMAuthMethods = pTemp; pTemp = pTemp->pNext;
FreeIniMMAuthMethods(pIniMMAuthMethods);
} }
VOID FreeMMAuthMethods( DWORD dwNumAuthMethods, PINT_MM_AUTH_METHODS pMMAuthMethods ) { DWORD i = 0;
if (pMMAuthMethods) {
for (i = 0; i < dwNumAuthMethods; i++) {
FreeMMAuthInfos( pMMAuthMethods[i].dwNumAuthInfos, pMMAuthMethods[i].pAuthenticationInfo );
}
SPDApiBufferFree(pMMAuthMethods);
} }
DWORD LocateMMAuthMethods( PMM_FILTER pMMFilter, PINIMMAUTHMETHODS * ppIniMMAuthMethods ) { DWORD dwError = 0; PINIMMAUTHMETHODS pIniMMAuthMethods = NULL;
if ((pMMFilter->dwFlags) & IPSEC_MM_AUTH_DEFAULT_AUTH) {
if (!gpIniDefaultMMAuthMethods) { dwError = ERROR_IPSEC_DEFAULT_MM_AUTH_NOT_FOUND; BAIL_ON_WIN32_ERROR(dwError); } pIniMMAuthMethods = gpIniDefaultMMAuthMethods;
} else {
pIniMMAuthMethods = FindMMAuthMethods( gpIniMMAuthMethods, pMMFilter->gMMAuthID ); if (!pIniMMAuthMethods) { dwError = ERROR_IPSEC_MM_AUTH_NOT_FOUND; BAIL_ON_WIN32_ERROR(dwError); }
}
*ppIniMMAuthMethods = pIniMMAuthMethods; return (dwError);
error:
*ppIniMMAuthMethods = NULL; return (dwError); }
|