Leaked source code of windows server 2003
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

/**************************************************************************
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;
}