windows-nt/Source/XPSP1/NT/net/rras/ras/ppp/eaptls/ceapcfg.cpp
2020-09-26 16:20:57 +08:00

429 lines
9.6 KiB
C++

/*
Copyright (c) 1997, Microsoft Corporation, all rights reserved
Description:
History:
*/
#include <nt.h> // Required by windows.h
#include <ntrtl.h> // Required by windows.h
#include <nturtl.h> // Required by windows.h
#include <windows.h> // Win32 base API's
#include <schannel.h>
#define SECURITY_WIN32
#include <sspi.h> // For CredHandle
#include <wincrypt.h> // Required by sclogon.h
#include <eaptypeid.h>
#include <rasauth.h> // Required by raseapif.h
#include <eaptypeid.h>
#include <raseapif.h>
#include <rasman.h> // For EAPLOGONINFO
#include "eaptls.h"
#include "ceapcfg.h"
extern "C"
DWORD
InvokeServerConfigUI(
IN HWND hWnd,
IN WCHAR* pwszMachineName
);
extern "C"
DWORD
WINAPI PeapInvokeServerConfigUI ( IN HWND hWnd,
IN WCHAR * pwszMachineName
);
extern "C"
DWORD
EapTlsInvokeIdentityUI(
IN BOOL fServer,
IN BOOL fRouterConfig,
IN DWORD dwFlags,
IN WCHAR* pszStoreName,
IN const WCHAR* pwszPhonebook,
IN const WCHAR* pwszEntry,
IN HWND hwndParent,
IN BYTE* pConnectionDataIn,
IN DWORD dwSizeOfConnectionDataIn,
IN BYTE* pUserDataIn,
IN DWORD dwSizeOfUserDataIn,
OUT BYTE** ppUserDataOut,
OUT DWORD* pdwSizeOfUserDataOut,
OUT WCHAR** ppwszIdentity
);
extern "C"
DWORD
RasEapInvokeConfigUI(
IN DWORD dwEapTypeId,
IN HWND hwndParent,
IN DWORD dwFlags,
IN BYTE* pConnectionDataIn,
IN DWORD dwSizeOfConnectionDataIn,
OUT BYTE** ppConnectionDataOut,
OUT DWORD* pdwSizeOfConnectionDataOut
);
extern "C"
DWORD
RasEapFreeMemory(
IN BYTE* pMemory
);
/*
Returns:
Notes:
Implementation of IEAPProviderConfig::Initialize
*/
STDMETHODIMP
CEapCfg::Initialize(
LPCOLESTR pwszMachineName,
DWORD dwEapTypeId,
ULONG_PTR* puConnectionParam
)
{
size_t size;
WCHAR* pwsz = NULL;
DWORD dwErr = NO_ERROR;
*puConnectionParam = NULL;
if (dwEapTypeId != PPP_EAP_TLS && dwEapTypeId != PPP_EAP_PEAP)
{
dwErr = ERROR_NOT_SUPPORTED;
goto LDone;
}
size = wcslen(pwszMachineName);
pwsz = (WCHAR*) LocalAlloc(LPTR, (size + 1)*sizeof(WCHAR));
if (NULL == pwsz)
{
dwErr = GetLastError();
goto LDone;
}
CopyMemory(pwsz, pwszMachineName, (size + 1)*sizeof(WCHAR));
*puConnectionParam = (ULONG_PTR)pwsz;
pwsz = NULL;
LDone:
LocalFree(pwsz);
return(HRESULT_FROM_WIN32(dwErr));
}
/*
Returns:
Notes:
Implementation of IEAPProviderConfig::Uninitialize
*/
STDMETHODIMP
CEapCfg::Uninitialize(
DWORD dwEapTypeId,
ULONG_PTR uConnectionParam
)
{
LocalFree((VOID*)uConnectionParam);
return(HRESULT_FROM_WIN32(NO_ERROR));
}
/*
Returns:
Notes:
Implementation of IEAPProviderConfig::ServerInvokeConfigUI
hWnd - handle to the parent window
dwRes1 - reserved parameter (ignore)
dwRes2 - reserved parameter (ignore)
*/
STDMETHODIMP
CEapCfg::ServerInvokeConfigUI(
DWORD dwEapTypeId,
ULONG_PTR uConnectionParam,
HWND hWnd,
DWORD_PTR dwRes1,
DWORD_PTR dwRes2
)
{
WCHAR* pwszMachineName;
HRESULT hr;
DWORD dwErr;
if (dwEapTypeId != PPP_EAP_TLS
#ifdef IMPL_PEAP
&& dwEapTypeId != PPP_EAP_PEAP
#endif
)
{
dwErr = ERROR_NOT_SUPPORTED;
goto LDone;
}
pwszMachineName = (WCHAR*)uConnectionParam;
if (NULL == pwszMachineName)
{
dwErr = E_FAIL;
}
else
{
if ( dwEapTypeId == PPP_EAP_TLS )
{
dwErr = InvokeServerConfigUI(hWnd, pwszMachineName);
}
#ifdef IMPL_PEAP
else
{
dwErr = PeapInvokeServerConfigUI(hWnd, pwszMachineName);
}
#endif
}
LDone:
hr = HRESULT_FROM_WIN32(dwErr);
return(hr);
}
/*
Returns:
Notes:
Implementation of IEAPProviderConfig::RouterInvokeConfigUI
*/
STDMETHODIMP
CEapCfg::RouterInvokeConfigUI(
DWORD dwEapTypeId,
ULONG_PTR uConnectionParam,
HWND hwndParent,
DWORD dwFlags,
BYTE* pConnectionDataIn,
DWORD dwSizeOfConnectionDataIn,
BYTE** ppConnectionDataOut,
DWORD* pdwSizeOfConnectionDataOut
)
{
DWORD dwErr = NO_ERROR;
BYTE* pConnectionDataOut = NULL;
DWORD dwSizeOfConnectionDataOut = 0;
*ppConnectionDataOut = NULL;
*pdwSizeOfConnectionDataOut = 0;
if (dwEapTypeId != PPP_EAP_TLS )
{
dwErr = ERROR_NOT_SUPPORTED;
goto LDone;
}
dwErr = RasEapInvokeConfigUI(
dwEapTypeId,
hwndParent,
dwFlags,
pConnectionDataIn,
dwSizeOfConnectionDataIn,
&pConnectionDataOut,
&dwSizeOfConnectionDataOut);
if ( (NO_ERROR == dwErr)
&& (0 != dwSizeOfConnectionDataOut))
{
*ppConnectionDataOut = (BYTE*)CoTaskMemAlloc(dwSizeOfConnectionDataOut);
if (NULL == *ppConnectionDataOut)
{
dwErr = ERROR_NOT_ENOUGH_MEMORY;
goto LDone;
}
CopyMemory(*ppConnectionDataOut, pConnectionDataOut,
dwSizeOfConnectionDataOut);
*pdwSizeOfConnectionDataOut = dwSizeOfConnectionDataOut;
}
LDone:
RasEapFreeMemory(pConnectionDataOut);
return(HRESULT_FROM_WIN32(dwErr));
}
/*
Returns:
Notes:
Implementation of IEAPProviderConfig::RouterInvokeCredentialsUI
*/
STDMETHODIMP
CEapCfg::RouterInvokeCredentialsUI(
DWORD dwEapTypeId,
ULONG_PTR uConnectionParam,
HWND hwndParent,
DWORD dwFlags,
BYTE* pConnectionDataIn,
DWORD dwSizeOfConnectionDataIn,
BYTE* pUserDataIn,
DWORD dwSizeOfUserDataIn,
BYTE** ppUserDataOut,
DWORD* pdwSizeOfUserDataOut
)
{
#define MAX_STORE_NAME_LENGTH MAX_COMPUTERNAME_LENGTH + 20
WCHAR awszStoreName[MAX_STORE_NAME_LENGTH + 1];
DWORD dwErr;
DWORD dwSizeOfUserDataOut;
BYTE* pUserDataOut = NULL;
WCHAR* pwszIdentityOut = NULL;
WCHAR* pwszMachineName;
BOOL fLocal = FALSE;
*ppUserDataOut = NULL;
*pdwSizeOfUserDataOut = 0;
if (dwEapTypeId != PPP_EAP_TLS )
{
dwErr = ERROR_NOT_SUPPORTED;
goto LDone;
}
pwszMachineName = (WCHAR*)uConnectionParam;
if (0 == *pwszMachineName)
{
fLocal = TRUE;
}
wcscpy(awszStoreName, L"\\\\");
wcsncat(awszStoreName, pwszMachineName, MAX_COMPUTERNAME_LENGTH);
wcsncat(awszStoreName, L"\\MY", wcslen(L"\\MY"));
if ( dwEapTypeId == PPP_EAP_TLS )
{
dwErr = EapTlsInvokeIdentityUI(
FALSE /* fServer */,
TRUE /* fRouterConfig */,
dwFlags,
fLocal ? L"MY" : awszStoreName,
L"",
L"",
hwndParent,
pConnectionDataIn,
dwSizeOfConnectionDataIn,
pUserDataIn,
dwSizeOfUserDataIn,
&pUserDataOut,
&dwSizeOfUserDataOut,
&pwszIdentityOut);
if ( (NO_ERROR == dwErr)
&& (0 != dwSizeOfUserDataOut))
{
*ppUserDataOut = (BYTE*)CoTaskMemAlloc(dwSizeOfUserDataOut);
if (NULL == *ppUserDataOut)
{
dwErr = ERROR_NOT_ENOUGH_MEMORY;
goto LDone;
}
CopyMemory(*ppUserDataOut, pUserDataOut, dwSizeOfUserDataOut);
*pdwSizeOfUserDataOut = dwSizeOfUserDataOut;
}
}
else
{
//Show PEAP dialog to get identity for router...
}
LDone:
RasEapFreeMemory(pUserDataOut);
RasEapFreeMemory((BYTE*)pwszIdentityOut);
return(HRESULT_FROM_WIN32(dwErr));
}
extern "C"
{
//utility function kept here so that we dont have to get the COM junk in other files
DWORD PeapEapInfoInvokeServerConfigUI ( HWND hWndParent,
LPWSTR lpwszMachineName,
PPEAP_EAP_INFO pEapInfo
)
{
DWORD dwRetCode = NO_ERROR;
GUID guid;
HRESULT hr = S_OK;
ULONG_PTR uConnection = 0;
CComPtr<IEAPProviderConfig> spEAPConfig;
hr = CLSIDFromString(pEapInfo->lpwszConfigClsId, &guid);
if (FAILED(hr)) goto L_ERR;
// Create the EAP provider object
// ----------------------------------------------------------------
hr = CoCreateInstance( guid,
NULL,
CLSCTX_INPROC_SERVER,
__uuidof(IEAPProviderConfig),
(LPVOID *) &spEAPConfig);
if (FAILED(hr )) goto L_ERR;
// Configure this EAP provider
// ----------------------------------------------------------------
// EAP configure displays its own error message, so no hr is kept
if ( !FAILED(spEAPConfig->Initialize(lpwszMachineName, pEapInfo->dwTypeId, &uConnection)) )
{
spEAPConfig->ServerInvokeConfigUI(pEapInfo->dwTypeId, uConnection, hWndParent, 0, 0);
spEAPConfig->Uninitialize(pEapInfo->dwTypeId, uConnection);
}
if ( hr == E_NOTIMPL )
hr = S_OK;
L_ERR:
if ( FAILED(hr) )
{
dwRetCode = hr;
}
return dwRetCode;
}
}