#include "precomp.h" DWORD LoadPersistedMMFilters( HKEY hParentRegKey ) { DWORD dwError = 0; HKEY hRegKey = NULL; DWORD dwSize = 0; WCHAR szMMFilterUniqueID[MAX_PATH]; DWORD dwIndex = 0; PMM_FILTER pMMFilter = NULL; LPWSTR pszServerName = NULL; HANDLE hMMFilter = NULL; DWORD dwPersist = 0; dwPersist |= PERSIST_SPD_OBJECT; dwError = RegOpenKeyExW( hParentRegKey, L"MM Filters", 0, KEY_ALL_ACCESS, &hRegKey ); BAIL_ON_WIN32_ERROR(dwError); while (1) { dwSize = MAX_PATH; szMMFilterUniqueID[0] = L'\0'; dwError = RegEnumKeyExW( hRegKey, dwIndex, szMMFilterUniqueID, &dwSize, NULL, NULL, 0, 0 ); if (dwError == ERROR_NO_MORE_ITEMS) { dwError = ERROR_SUCCESS; break; } BAIL_ON_WIN32_ERROR(dwError); dwError = SPDReadMMFilter( hRegKey, szMMFilterUniqueID, &pMMFilter ); if (dwError) { dwIndex++; continue; } dwError = AddMMFilter( pszServerName, dwPersist, pMMFilter, &hMMFilter ); if (pMMFilter) { FreeMMFilters( 1, pMMFilter ); } if (hMMFilter) { CloseMMFilterHandle(hMMFilter); } dwIndex++; } error: if (hRegKey) { RegCloseKey(hRegKey); } return (dwError); } DWORD SPDReadMMFilter( HKEY hParentRegKey, LPWSTR pszMMFilterUniqueID, PMM_FILTER * ppMMFilter ) { DWORD dwError = 0; HKEY hRegKey = NULL; PMM_FILTER pMMFilter = NULL; LPWSTR pszFilterID = NULL; DWORD dwSize = 0; DWORD dwType = 0; DWORD dwInterfaceType = 0; DWORD dwMirrored = 0; LPBYTE pBuffer = NULL; DWORD dwBufferSize = 0; LPWSTR pszPolicyID = NULL; LPWSTR pszAuthID = NULL; dwError = RegOpenKeyExW( hParentRegKey, pszMMFilterUniqueID, 0, KEY_ALL_ACCESS, &hRegKey ); BAIL_ON_WIN32_ERROR(dwError); pMMFilter = (PMM_FILTER) AllocSPDMem( sizeof(MM_FILTER) ); if (!pMMFilter) { dwError = ERROR_OUTOFMEMORY; BAIL_ON_WIN32_ERROR(dwError); } dwError = RegstoreQueryValue( hRegKey, L"FilterID", REG_SZ, (LPBYTE *)&pszFilterID, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); wGUIDFromString( pszFilterID, &pMMFilter->gFilterID ); dwError = RegstoreQueryValue( hRegKey, L"FilterName", REG_SZ, (LPBYTE *)&pMMFilter->pszFilterName, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); dwType = REG_DWORD; dwSize = sizeof(DWORD); dwError = RegQueryValueExW( hRegKey, L"InterfaceType", NULL, &dwType, (LPBYTE)&dwInterfaceType, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); pMMFilter->InterfaceType = (IF_TYPE) dwInterfaceType; dwType = REG_DWORD; dwSize = sizeof(DWORD); dwError = RegQueryValueExW( hRegKey, L"Mirrored", NULL, &dwType, (LPBYTE)&dwMirrored, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); pMMFilter->bCreateMirror = (BOOL) dwMirrored; dwType = REG_DWORD; dwSize = sizeof(DWORD); dwError = RegQueryValueExW( hRegKey, L"Flags", NULL, &dwType, (LPBYTE)&pMMFilter->dwFlags, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); dwError = RegstoreQueryValue( hRegKey, L"MM Filter Buffer", REG_BINARY, (LPBYTE *)&pBuffer, &dwBufferSize ); BAIL_ON_WIN32_ERROR(dwError); dwError = UnMarshallMMFilterBuffer( pBuffer, dwBufferSize, pMMFilter ); BAIL_ON_WIN32_ERROR(dwError); pMMFilter->dwDirection = 0; pMMFilter->dwWeight = 0; dwError = RegstoreQueryValue( hRegKey, L"PolicyID", REG_SZ, (LPBYTE *)&pszPolicyID, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); wGUIDFromString( pszPolicyID, &pMMFilter->gPolicyID ); dwError = RegstoreQueryValue( hRegKey, L"AuthID", REG_SZ, (LPBYTE *)&pszAuthID, &dwSize ); BAIL_ON_WIN32_ERROR(dwError); wGUIDFromString( pszAuthID, &pMMFilter->gMMAuthID ); *ppMMFilter = pMMFilter; cleanup: if (hRegKey) { RegCloseKey(hRegKey); } if (pszFilterID) { FreeSPDStr(pszFilterID); } if (pBuffer) { FreeSPDMem(pBuffer); } if (pszPolicyID) { FreeSPDStr(pszPolicyID); } if (pszAuthID) { FreeSPDStr(pszAuthID); } return (dwError); error: *ppMMFilter = NULL; if (pMMFilter) { FreeMMFilters( 1, pMMFilter ); } goto cleanup; } DWORD UnMarshallMMFilterBuffer( LPBYTE pBuffer, DWORD dwBufferSize, PMM_FILTER pMMFilter ) { DWORD dwError = 0; LPBYTE pMem = NULL; pMem = pBuffer; pMem += sizeof(GUID); pMem += sizeof(DWORD); memcpy( (LPBYTE) &pMMFilter->SrcAddr, pMem, sizeof(ADDR) ); pMem += sizeof(ADDR); memcpy( (LPBYTE) &pMMFilter->DesAddr, pMem, sizeof(ADDR) ); pMem += sizeof(ADDR); return (dwError); }