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.
514 lines
18 KiB
514 lines
18 KiB
/**************************************************************************
|
|
Copyright (C) 1999 Microsoft Corporation. All Rights Reserved.
|
|
|
|
MODULE: FILECFG.CPP
|
|
|
|
PURPOSE: Source module reading/writing PM config sets from a file
|
|
|
|
FUNCTIONS:
|
|
|
|
COMMENTS:
|
|
|
|
**************************************************************************/
|
|
|
|
/**************************************************************************
|
|
Include Files
|
|
**************************************************************************/
|
|
|
|
#include "pmcfg.h"
|
|
|
|
#define MAX_EXT 10
|
|
#define MAX_FILTER 256
|
|
|
|
TCHAR g_szPassportManager[] = TEXT("PassportManager");
|
|
|
|
/**************************************************************************
|
|
|
|
PMAdmin_GetFileName
|
|
|
|
*******************************************************************************/
|
|
BOOL PMAdmin_GetFileName
|
|
(
|
|
HWND hWnd,
|
|
BOOL fOpen,
|
|
LPTSTR lpFileName,
|
|
DWORD cbFileName
|
|
)
|
|
{
|
|
UINT TitleStringID, FilterID;
|
|
TCHAR szTitle[MAX_TITLE];
|
|
TCHAR szDefaultExtension[MAX_EXT];
|
|
TCHAR szFilter[MAX_FILTER];
|
|
LPTSTR lpFilterChar;
|
|
OPENFILENAME OpenFileName;
|
|
BOOL fSuccess;
|
|
|
|
//
|
|
// Load various strings that will be displayed and used by the common open
|
|
// or save dialog box. Note that if any of these fail, the error is not
|
|
// fatal-- the common dialog box may look odd, but will still work.
|
|
//
|
|
|
|
if (fOpen)
|
|
{
|
|
TitleStringID = IDS_OPENFILETITLE;
|
|
FilterID = IDS_PMOPENFILEFILTER;
|
|
}
|
|
else
|
|
{
|
|
TitleStringID = IDS_SAVEFILETITLE;
|
|
FilterID = IDS_PMSAVEFILEFILTER;
|
|
}
|
|
|
|
LoadString(g_hInst, TitleStringID, szTitle, DIMENSION(szTitle));
|
|
LoadString(g_hInst, IDS_PMCONFIGDEFEXT, szDefaultExtension, DIMENSION(szDefaultExtension));
|
|
|
|
if (LoadString(g_hInst, FilterID, szFilter, DIMENSION(szFilter)))
|
|
{
|
|
//
|
|
// The common dialog library requires that the substrings of the
|
|
// filter string be separated by nulls, but we cannot load a string
|
|
// containing nulls. So we use some dummy character in the resource
|
|
// that we now convert to nulls.
|
|
//
|
|
for (lpFilterChar = szFilter;
|
|
*lpFilterChar != 0;
|
|
lpFilterChar = CharNext(lpFilterChar))
|
|
{
|
|
|
|
if (*lpFilterChar == TEXT('#'))
|
|
*lpFilterChar++ = 0;
|
|
}
|
|
}
|
|
|
|
ZeroMemory(&OpenFileName, sizeof(OPENFILENAME));
|
|
|
|
OpenFileName.lStructSize = sizeof(OPENFILENAME);
|
|
OpenFileName.hwndOwner = hWnd;
|
|
OpenFileName.hInstance = g_hInst;
|
|
OpenFileName.lpstrFilter = szFilter;
|
|
OpenFileName.lpstrFile = lpFileName;
|
|
OpenFileName.nMaxFile = cbFileName;
|
|
OpenFileName.lpstrTitle = szTitle;
|
|
OpenFileName.lpstrDefExt = szDefaultExtension;
|
|
if (fOpen)
|
|
{
|
|
OpenFileName.Flags = OFN_HIDEREADONLY | OFN_EXPLORER | OFN_FILEMUSTEXIST;
|
|
fSuccess = GetOpenFileName(&OpenFileName);
|
|
}
|
|
else
|
|
{
|
|
OpenFileName.Flags = OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT |
|
|
OFN_EXPLORER | OFN_NOREADONLYRETURN | OFN_PATHMUSTEXIST;
|
|
fSuccess = GetSaveFileName(&OpenFileName);
|
|
}
|
|
return fSuccess;
|
|
}
|
|
|
|
// prototype of function implemented in regcfg.cpp
|
|
BOOL OpenTopRegKey
|
|
(
|
|
HWND hWndDlg,
|
|
LPTSTR lpszRemoteComputer,
|
|
HKEY *phklm,
|
|
HKEY *phkeyPassport
|
|
);
|
|
|
|
/**************************************************************************
|
|
|
|
ReadFileConfigSet
|
|
|
|
Read the current passport manager config set from the specified file
|
|
|
|
**************************************************************************/
|
|
BOOL ReadFileConfigSet
|
|
(
|
|
LPPMSETTINGS lpPMConfig,
|
|
LPCTSTR lpszFileName
|
|
)
|
|
{
|
|
HKEY hklm = 0;
|
|
HKEY hkeyPassport = 0;
|
|
DWORD dwTemp;
|
|
TCHAR achTemp[INTERNET_MAX_URL_LENGTH];
|
|
|
|
// makesure the specified file exists.
|
|
if (!PathFileExists(lpszFileName))
|
|
{
|
|
ReportError(NULL, IDS_FILENOTFOUND);
|
|
return FALSE;
|
|
}
|
|
|
|
// make sure this user can save any changes, if not simply bail
|
|
if (!OpenTopRegKey(NULL, g_szRemoteComputer, &hklm, &hkeyPassport))
|
|
{
|
|
if (hklm && hklm != HKEY_LOCAL_MACHINE)
|
|
RegCloseKey(hklm);
|
|
return FALSE;
|
|
}
|
|
RegCloseKey(hkeyPassport);
|
|
if (hklm != HKEY_LOCAL_MACHINE)
|
|
RegCloseKey(hklm);
|
|
|
|
// Zero Init the structure
|
|
ZeroMemory(lpPMConfig, sizeof(PMSETTINGS));
|
|
|
|
// Read the Time Window Number
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szTimeWindow,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwTimeWindow = dwTemp;
|
|
|
|
// Read the value for Forced Signin
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szForceSignIn,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwForceSignIn = dwTemp;
|
|
|
|
// Read the value for NSRefresh
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szNSRefresh,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwEnableManualRefresh = dwTemp;
|
|
|
|
// Read the default language ID
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szLanguageID,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwLanguageID = dwTemp;
|
|
|
|
// Get the co-branding template
|
|
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szCoBrandTemplate,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szCoBrandTemplate, achTemp);
|
|
|
|
|
|
// Get the SiteID
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szSiteID,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwSiteID = dwTemp;
|
|
|
|
// Get the return URL template
|
|
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szReturnURL,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szReturnURL, achTemp);
|
|
|
|
// Get the ticket cookie domain
|
|
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szTicketDomain,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szTicketDomain, achTemp);
|
|
|
|
// Get the ticket cookie path
|
|
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szTicketPath,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szTicketPath, achTemp);
|
|
|
|
// Get the profile cookie domain
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szProfileDomain,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szProfileDomain, achTemp);
|
|
|
|
// Get the profile cookie path
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szProfilePath,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szProfilePath, achTemp);
|
|
|
|
// Get the secure cookie domain
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szSecureDomain,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szSecureDomain, achTemp);
|
|
|
|
// Get the secure cookie path
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szSecurePath,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szSecurePath, achTemp);
|
|
|
|
// Get the DisasterURL
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szDisasterURL,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szDisasterURL, achTemp);
|
|
|
|
// Get Standalone mode setting
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szStandAlone,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwStandAlone = dwTemp;
|
|
|
|
// Get DisableCookies mode setting
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szDisableCookies,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwDisableCookies = dwTemp;
|
|
|
|
// Get the HostName
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szHostName,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpyn(lpPMConfig->szHostName, achTemp, DIMENSION(lpPMConfig->szHostName));
|
|
|
|
// Get the HostIP
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szHostIP,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpyn(lpPMConfig->szHostIP, achTemp, DIMENSION(lpPMConfig->szHostIP));
|
|
|
|
// Get the Verbose Mode
|
|
dwTemp = GetPrivateProfileInt(g_szPassportManager,
|
|
g_szVerboseMode,
|
|
-1,
|
|
lpszFileName);
|
|
if(dwTemp != -1)
|
|
lpPMConfig->dwVerboseMode = dwTemp;
|
|
|
|
|
|
// Get the EnvName
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szEnvName,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpyn(lpPMConfig->szEnvName, achTemp, DIMENSION(lpPMConfig->szEnvName));
|
|
|
|
// Get the RemoteFile
|
|
GetPrivateProfileString(g_szPassportManager,
|
|
g_szRemoteFile,
|
|
(LPTSTR)TEXT("\xFF"),
|
|
achTemp,
|
|
DIMENSION(achTemp),
|
|
lpszFileName);
|
|
if(lstrcmp(achTemp, TEXT("\xFF")) != 0)
|
|
lstrcpy(lpPMConfig->szRemoteFile, achTemp);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
/**************************************************************************
|
|
|
|
WriteFileConfigSet
|
|
|
|
Writes the current passport manager config set to the specified file
|
|
|
|
**************************************************************************/
|
|
BOOL WriteFileConfigSet
|
|
(
|
|
LPPMSETTINGS lpPMConfig,
|
|
LPCTSTR lpszFileName
|
|
)
|
|
{
|
|
TCHAR szTemp[MAX_PATH];
|
|
|
|
// Write the Time Window Number
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwTimeWindow);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szTimeWindow,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// write the value for Forced Signin
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwForceSignIn);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szForceSignIn,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// write the value for NSRefresh
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwEnableManualRefresh);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szNSRefresh,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Read the default language ID
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwLanguageID);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szLanguageID,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Write the co-branding template
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szCoBrandTemplate,
|
|
lpPMConfig->szCoBrandTemplate,
|
|
lpszFileName);
|
|
|
|
// Write the SiteID
|
|
wsprintf (szTemp, TEXT("%lu"),lpPMConfig->dwSiteID);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szSiteID,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Write the return URL template
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szReturnURL,
|
|
lpPMConfig->szReturnURL,
|
|
lpszFileName);
|
|
|
|
// Write the ticket cookie domain
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szTicketDomain,
|
|
lpPMConfig->szTicketDomain,
|
|
lpszFileName);
|
|
|
|
// Write the ticket cookie path
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szTicketPath,
|
|
lpPMConfig->szTicketPath,
|
|
lpszFileName);
|
|
|
|
// Write the profile cookie domain
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szProfileDomain,
|
|
lpPMConfig->szProfileDomain,
|
|
lpszFileName);
|
|
|
|
// Write the profile cookie path
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szProfilePath,
|
|
lpPMConfig->szProfilePath,
|
|
lpszFileName);
|
|
|
|
// Write the secure cookie domain
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szSecureDomain,
|
|
lpPMConfig->szSecureDomain,
|
|
lpszFileName);
|
|
|
|
// Write the secure profile cookie path
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szSecurePath,
|
|
lpPMConfig->szSecurePath,
|
|
lpszFileName);
|
|
|
|
// Write the Disaster URL
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szDisasterURL,
|
|
lpPMConfig->szDisasterURL,
|
|
lpszFileName);
|
|
|
|
// Write Standalone mode setting
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwStandAlone);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szStandAlone,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Write DisableCookies mode setting
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwDisableCookies);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szDisableCookies,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Write the Host Name
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szHostName,
|
|
lpPMConfig->szHostName,
|
|
lpszFileName);
|
|
|
|
// Write the Host IP
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szHostIP,
|
|
lpPMConfig->szHostIP,
|
|
lpszFileName);
|
|
|
|
// Write the Verbose Mode
|
|
wsprintf (szTemp, TEXT("%lu"), lpPMConfig->dwVerboseMode);
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szVerboseMode,
|
|
szTemp,
|
|
lpszFileName);
|
|
|
|
// Write the EnvName
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szEnvName,
|
|
lpPMConfig->szEnvName,
|
|
lpszFileName);
|
|
|
|
// Write the RemoteFile
|
|
WritePrivateProfileString(g_szPassportManager,
|
|
g_szRemoteFile,
|
|
lpPMConfig->szRemoteFile,
|
|
lpszFileName);
|
|
|
|
return TRUE;
|
|
}
|