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.
394 lines
13 KiB
394 lines
13 KiB
#include "pch.h"
|
|
#pragma hdrstop
|
|
#include "connutil.h"
|
|
#include "ncnetcon.h"
|
|
#include "ncperms.h"
|
|
#include "ncui.h"
|
|
#include "lanui.h"
|
|
#include "eapolui.h"
|
|
#include "util.h"
|
|
#include "lanhelp.h"
|
|
#include "wzcprops.h"
|
|
#include "wzcpage.h"
|
|
#include "wzcui.h"
|
|
#include "wzcsapi.h"
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////
|
|
// CEapolConfig related stuff
|
|
//
|
|
//+---------------------------------------------------------------------------
|
|
// constructor
|
|
CEapolConfig::CEapolConfig()
|
|
{
|
|
m_dwCtlFlags = 0;
|
|
ZeroMemory(&m_EapolIntfParams, sizeof(EAPOL_INTF_PARAMS));
|
|
m_pListEapcfgs = NULL;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
// destructor
|
|
CEapolConfig::~CEapolConfig()
|
|
{
|
|
ZeroMemory(&m_EapolIntfParams, sizeof(EAPOL_INTF_PARAMS));
|
|
if (m_pListEapcfgs)
|
|
{
|
|
DtlDestroyList (m_pListEapcfgs, DestroyEapcfgNode);
|
|
}
|
|
m_pListEapcfgs = NULL;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
DWORD CEapolConfig::CopyEapolConfig(CEapolConfig *pEapolConfig)
|
|
{
|
|
DTLLIST *pListEapcfgs = NULL;
|
|
DTLNODE *pCopyNode = NULL, *pInNode = NULL;
|
|
DWORD dwRetCode = ERROR_SUCCESS;
|
|
|
|
if (pEapolConfig)
|
|
{
|
|
pListEapcfgs = ::ReadEapcfgList (EAPOL_MUTUAL_AUTH_EAP_ONLY);
|
|
if (pListEapcfgs)
|
|
{
|
|
for (pCopyNode = DtlGetFirstNode(pListEapcfgs);
|
|
pCopyNode;
|
|
pCopyNode = DtlGetNextNode(pCopyNode))
|
|
{
|
|
EAPCFG* pCopyEapcfg = (EAPCFG* )DtlGetData(pCopyNode);
|
|
for (pInNode = DtlGetFirstNode(pEapolConfig->m_pListEapcfgs);
|
|
pInNode;
|
|
pInNode = DtlGetNextNode(pInNode))
|
|
{
|
|
EAPCFG* pInEapcfg = (EAPCFG* )DtlGetData(pInNode);
|
|
if (pCopyEapcfg->dwKey == pInEapcfg->dwKey)
|
|
{
|
|
if ((pCopyEapcfg->pData = (PBYTE) MALLOC (pInEapcfg->cbData)) == NULL)
|
|
{
|
|
dwRetCode = ERROR_NOT_ENOUGH_MEMORY;
|
|
break;
|
|
}
|
|
memcpy (pCopyEapcfg->pData, pInEapcfg->pData, pInEapcfg->cbData);
|
|
pCopyEapcfg->cbData = pInEapcfg->cbData;
|
|
break;
|
|
}
|
|
}
|
|
if (dwRetCode != NO_ERROR)
|
|
{
|
|
goto LExit;
|
|
}
|
|
}
|
|
}
|
|
m_pListEapcfgs = pListEapcfgs;
|
|
memcpy (&m_EapolIntfParams, &pEapolConfig->m_EapolIntfParams, sizeof(EAPOL_INTF_PARAMS));
|
|
}
|
|
else
|
|
{
|
|
dwRetCode = ERROR_INVALID_DATA;
|
|
}
|
|
|
|
LExit:
|
|
if (dwRetCode != ERROR_SUCCESS)
|
|
{
|
|
if (pListEapcfgs)
|
|
{
|
|
DtlDestroyList (pListEapcfgs, DestroyEapcfgNode);
|
|
}
|
|
}
|
|
|
|
return dwRetCode;
|
|
}
|
|
|
|
|
|
|
|
//+---------------------------------------------------------------------------
|
|
LRESULT CEapolConfig::LoadEapolConfig(LPWSTR wszIntfGuid, PNDIS_802_11_SSID pndSsid)
|
|
{
|
|
BYTE *pbData = NULL;
|
|
DWORD cbData = 0;
|
|
EAPOL_INTF_PARAMS EapolIntfParams;
|
|
DTLLIST *pListEapcfgs = NULL;
|
|
HRESULT hr = S_OK;
|
|
|
|
// Initialize EAP package list
|
|
// Read the EAPCFG information from the registry and find the node
|
|
// selected in the entry, or the default, if none.
|
|
|
|
do
|
|
{
|
|
DTLNODE* pNode = NULL;
|
|
|
|
// Read the EAPCFG information from the registry and find the node
|
|
// selected in the entry, or the default, if none.
|
|
|
|
pListEapcfgs = ::ReadEapcfgList (EAPOL_MUTUAL_AUTH_EAP_ONLY);
|
|
|
|
if (pListEapcfgs)
|
|
{
|
|
|
|
DTLNODE* pNodeEap;
|
|
DWORD dwkey = 0;
|
|
|
|
// Read the EAP params for this interface
|
|
|
|
ZeroMemory ((BYTE *)&EapolIntfParams, sizeof(EAPOL_INTF_PARAMS));
|
|
EapolIntfParams.dwEapFlags = DEFAULT_EAP_STATE;
|
|
EapolIntfParams.dwEapType = DEFAULT_EAP_TYPE;
|
|
if (pndSsid)
|
|
{
|
|
EapolIntfParams.dwSizeOfSSID = pndSsid->SsidLength;
|
|
memcpy (EapolIntfParams.bSSID, pndSsid->Ssid, pndSsid->SsidLength);
|
|
}
|
|
else
|
|
{
|
|
// If NULL SSID, this will get default EAPOL values
|
|
EapolIntfParams.dwSizeOfSSID = 1;
|
|
}
|
|
hr = HrElGetInterfaceParams (
|
|
wszIntfGuid,
|
|
&EapolIntfParams
|
|
);
|
|
if (FAILED (hr))
|
|
{
|
|
TraceTag (ttidLanUi, "HrElGetInterfaceParams failed with error %ld",
|
|
LresFromHr(hr));
|
|
break;
|
|
}
|
|
|
|
|
|
TraceTag (ttidLanUi, "HrElGetInterfaceParams: Got EAPtype=(%ld), EAPState =(%ld)", EapolIntfParams.dwEapType, EapolIntfParams.dwEapFlags);
|
|
|
|
memcpy (&m_EapolIntfParams, &EapolIntfParams, sizeof(EAPOL_INTF_PARAMS));
|
|
|
|
// Read the EAP configuration info for all EAP packages
|
|
|
|
for (pNodeEap = DtlGetFirstNode(pListEapcfgs);
|
|
pNodeEap;
|
|
pNodeEap = DtlGetNextNode(pNodeEap))
|
|
{
|
|
EAPCFG* pEapcfg = (EAPCFG* )DtlGetData(pNodeEap);
|
|
ASSERT( pEapcfg );
|
|
|
|
hr = S_OK;
|
|
pbData = NULL;
|
|
|
|
TraceTag (ttidLanUi, "Calling HrElGetCustomAuthData for EAP %ld",
|
|
pEapcfg->dwKey);
|
|
|
|
cbData = 0;
|
|
|
|
// Get the size of the EAP blob
|
|
|
|
hr = HrElGetCustomAuthData (
|
|
wszIntfGuid,
|
|
pEapcfg->dwKey,
|
|
EapolIntfParams.dwSizeOfSSID,
|
|
EapolIntfParams.bSSID,
|
|
NULL,
|
|
&cbData
|
|
);
|
|
if (!SUCCEEDED(hr))
|
|
{
|
|
if ((EapolIntfParams.dwSizeOfSSID != 0) &&
|
|
(hr == HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)))
|
|
{
|
|
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: SSID!= NULL, not found blob for SSID");
|
|
|
|
// The Last Used SSID did not have a connection
|
|
// blob created. Call again for size of blob with
|
|
// NULL SSID
|
|
|
|
EapolIntfParams.dwSizeOfSSID = 0;
|
|
|
|
// Get the size of the EAP blob
|
|
|
|
hr = HrElGetCustomAuthData (
|
|
wszIntfGuid,
|
|
pEapcfg->dwKey,
|
|
0,
|
|
NULL,
|
|
NULL,
|
|
&cbData
|
|
);
|
|
}
|
|
|
|
if (hr == E_OUTOFMEMORY)
|
|
{
|
|
if (cbData <= 0)
|
|
{
|
|
// No EAP blob stored in the registry
|
|
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: No blob stored in reg at all");
|
|
pbData = NULL;
|
|
|
|
// Will continue processing for errors
|
|
// Not exit
|
|
hr = S_OK;
|
|
|
|
}
|
|
else
|
|
{
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: Found auth blob in registry");
|
|
|
|
// Allocate memory to hold the blob
|
|
|
|
pbData = (PBYTE) MALLOC (cbData);
|
|
|
|
if (pbData == NULL)
|
|
{
|
|
hr = S_OK;
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: Error in memory allocation for EAP blob");
|
|
continue;
|
|
}
|
|
ZeroMemory (pbData, cbData);
|
|
|
|
hr = HrElGetCustomAuthData (
|
|
wszIntfGuid,
|
|
pEapcfg->dwKey,
|
|
EapolIntfParams.dwSizeOfSSID,
|
|
EapolIntfParams.bSSID,
|
|
pbData,
|
|
&cbData
|
|
);
|
|
|
|
if (!SUCCEEDED(hr))
|
|
{
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: HrElGetCustomAuthData failed with %ld",
|
|
LresFromHr(hr));
|
|
FREE ( pbData );
|
|
hr = S_OK;
|
|
continue;
|
|
}
|
|
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: HrElGetCustomAuthData successfully got blob of length %ld"
|
|
, cbData);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
TraceTag (ttidLanUi, "HrElGetCustomAuthData: Not got ERROR_NOT_ENOUGH_MEMORY error; Unknown error !!!");
|
|
hr = S_OK;
|
|
continue;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// HrElGetCustomAuthData will always return
|
|
// error with cbData = 0
|
|
hr = S_OK;
|
|
}
|
|
|
|
if (pEapcfg->pData != NULL)
|
|
{
|
|
FREE ( pEapcfg->pData );
|
|
}
|
|
pEapcfg->pData = (UCHAR *)pbData;
|
|
pEapcfg->cbData = cbData;
|
|
}
|
|
|
|
m_pListEapcfgs = pListEapcfgs;
|
|
}
|
|
else
|
|
{
|
|
hr = E_FAIL;
|
|
}
|
|
|
|
} while (FALSE);
|
|
|
|
return LresFromHr(hr);
|
|
}
|
|
|
|
|
|
//+---------------------------------------------------------------------------
|
|
LRESULT CEapolConfig::SaveEapolConfig(LPWSTR wszIntfGuid, PNDIS_802_11_SSID pndSsid)
|
|
{
|
|
WCHAR *pwszLastUsedSSID = NULL;
|
|
DWORD dwEapFlags = 0;
|
|
HRESULT hrOverall = S_OK;
|
|
HRESULT hr = S_OK;
|
|
|
|
// Save the EAP configuration data into the registry
|
|
|
|
DTLNODE* pNodeEap = NULL;
|
|
|
|
hr = S_OK;
|
|
|
|
// Save data for all EAP packages in the registry
|
|
|
|
if (m_pListEapcfgs == NULL)
|
|
{
|
|
return LresFromHr(S_OK);
|
|
}
|
|
|
|
if (pndSsid)
|
|
{
|
|
m_EapolIntfParams.dwSizeOfSSID = pndSsid->SsidLength;
|
|
memcpy (m_EapolIntfParams.bSSID, pndSsid->Ssid, pndSsid->SsidLength);
|
|
}
|
|
|
|
for (pNodeEap = DtlGetFirstNode(m_pListEapcfgs);
|
|
pNodeEap;
|
|
pNodeEap = DtlGetNextNode(pNodeEap))
|
|
{
|
|
EAPCFG* pcfg = (EAPCFG* )DtlGetData(pNodeEap);
|
|
if (pcfg == NULL)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
hr = S_OK;
|
|
|
|
// ignore error and continue with next
|
|
|
|
hr = HrElSetCustomAuthData (
|
|
wszIntfGuid,
|
|
pcfg->dwKey,
|
|
m_EapolIntfParams.dwSizeOfSSID,
|
|
m_EapolIntfParams.bSSID,
|
|
pcfg->pData,
|
|
pcfg->cbData);
|
|
|
|
if (FAILED (hr))
|
|
{
|
|
TraceTag (ttidLanUi, "HrElSetCustomAuthData failed");
|
|
hrOverall = hr;
|
|
hr = S_OK;
|
|
}
|
|
}
|
|
|
|
if (m_dwCtlFlags & EAPOL_CTL_LOCKED)
|
|
m_EapolIntfParams.dwEapFlags &= ~EAPOL_ENABLED;
|
|
|
|
hr = HrElSetInterfaceParams (
|
|
wszIntfGuid,
|
|
&m_EapolIntfParams
|
|
);
|
|
if (FAILED(hr))
|
|
{
|
|
TraceTag (ttidLanUi, "HrElSetInterfaceParams enabled failed with error %ld",
|
|
LresFromHr(hr));
|
|
}
|
|
|
|
if (hrOverall != S_OK)
|
|
{
|
|
hr = hrOverall;
|
|
}
|
|
|
|
return LresFromHr(hr);
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
BOOL CEapolConfig::Is8021XEnabled()
|
|
{
|
|
return (IS_EAPOL_ENABLED(m_EapolIntfParams.dwEapFlags));
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
VOID CEapolConfig::Set8021XState(BOOLEAN fSet)
|
|
{
|
|
if (fSet)
|
|
m_EapolIntfParams.dwEapFlags |= EAPOL_ENABLED;
|
|
else
|
|
m_EapolIntfParams.dwEapFlags &= ~EAPOL_ENABLED;
|
|
}
|
|
|