Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

1038 lines
27 KiB

/*
File wizard.c
Implementation of the incoming connections wizard.
Paul Mayfield, 10/30/97
*/
#include "rassrv.h"
#include <tapi.h>
// Help maps
static const DWORD phmWizardDccdev[] =
{
CID_Wizard_Dccdev_LB_Devices, IDH_Wizard_Dccdev_LB_Devices,
0, 0
};
static const DWORD phmWizardVpn[] =
{
0, 0
};
#define RASSRV_WIZTITLE_SIZE 256
#define RASSRV_WIZSUBTITLE_SIZE 256
// This structure let's us remember information needed
// to keep our device data page in sync
typedef struct _DCCDEV_DATA
{
HANDLE hDevice;
BOOL bEnabled;
} DCCDEV_DATA;
//
// This dialog proc implements the vpn tab on the incoming connections
// wizard.
//
INT_PTR
CALLBACK
VpnWizDialogProc(
HWND hwndDlg,
UINT uMsg,
WPARAM wParam,
LPARAM lParam);
//
// Dialog procedure that handles the host dcc wizard device page
//
INT_PTR
CALLBACK
DccdevWizDialogProc(
HWND hwndDlg,
UINT uMsg,
WPARAM wParam,
LPARAM lParam);
//
// This dialog procedure responds to messages sent to the
// switch to mmc wizard tab.
//
INT_PTR
CALLBACK
SwitchMmcWizDialogProc (
HWND hwndDlg,
UINT uMsg,
WPARAM wParam,
LPARAM lParam);
//
// Fills in the property sheet structure with the information required to
// display the device tab in the incoming connections wizard.
//
DWORD
DeviceWizGetPropertyPage(
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
LPCTSTR pszHeader, pszSubHeader;
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// Load the string resources
pszHeader = PszLoadString(
Globals.hInstDll,
SID_WIZDEVICETITLE);
pszSubHeader = PszLoadString(
Globals.hInstDll,
SID_WIZDEVICESUBTITLE);
// The General Properties dialog procedure also implements the device
// tab in the incoming connections wizard
ppage->pfnDlgProc = GenTabDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_GenTab);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->pszHeaderTitle = (PWCHAR)pszHeader;
ppage->pszHeaderSubTitle = (PWCHAR)pszSubHeader;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Fills in the property sheet structure with the information required
// to display the vpn tab in the incoming connections wizard.
//
DWORD
VpnWizGetPropertyPage(
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
LPCTSTR pszHeader, pszSubHeader;
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// Load the string resources
pszHeader = PszLoadString(
Globals.hInstDll,
SID_WIZVPNTITLE);
pszSubHeader = PszLoadString(
Globals.hInstDll,
SID_WIZVPNSUBTITLE);
// I could have used the general tab dialog procedure to implement the
// vpn tab. The only problem is that the general tab has a single
// check to enable vpn while the vpn tab in the wizard has a yes/no
// radio check group. For this reason, I made the vpn tab its very
// own dialog proc.
ppage->pfnDlgProc = VpnWizDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_Vpn);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->pszHeaderTitle = (PWCHAR)pszHeader;
ppage->pszHeaderSubTitle = (PWCHAR)pszSubHeader;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Function fills in the given lpPage structure with the information needed
// to run the user tab in the incoming connections wizard.
//
DWORD
UserWizGetPropertyPage(
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
LPCTSTR pszHeader, pszSubHeader;
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// Load the string resources
pszHeader = PszLoadString(Globals.hInstDll, SID_WIZUSERTITLE);
pszSubHeader = PszLoadString(Globals.hInstDll, SID_WIZUSERSUBTITLE);
// The User Properties dialog procedure also implements the user tab
// in the incoming connections wizard
ppage->pfnDlgProc = UserTabDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_UserTab);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->pszHeaderTitle = (PWCHAR)pszHeader;
ppage->pszHeaderSubTitle = (PWCHAR)pszSubHeader;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Fills a LPPROPSHEETPAGE structure with the information
// needed to display the protocol tab in the incoming connections wizard.
//
DWORD
ProtWizGetPropertyPage(
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
LPCTSTR pszHeader, pszSubHeader;
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// Load the string resources
pszHeader = PszLoadString(Globals.hInstDll, SID_WIZPROTTITLE);
pszSubHeader = PszLoadString(Globals.hInstDll, SID_WIZPROTSUBTITLE);
// The Advanced Properties dialog procedure also implements the net tab
// in the incoming connections wizard
ppage->pfnDlgProc = NetTabDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_NetTab);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->pszHeaderTitle = (PWCHAR)pszHeader;
ppage->pszHeaderSubTitle = (PWCHAR)pszSubHeader;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Function fills in the given LPPROPSHEETPAGE structure with the info
// needed to run the dcc device tab in the incoming connections wizard.
//
DWORD
DccdevWizGetPropertyPage(
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
LPCTSTR pszHeader, pszSubHeader;
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// Load the string resources
pszHeader = PszLoadString(Globals.hInstDll, SID_WIZDCCDEVTITLE);
pszSubHeader = PszLoadString(Globals.hInstDll, SID_WIZDCCDEVSUBTITLE);
// The Advanced Properties dialog procedure also implements the protocol
// tab in the incoming connections wizard
ppage->pfnDlgProc = DccdevWizDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_Dccdev);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->pszHeaderTitle = (PWCHAR)pszHeader;
ppage->pszHeaderSubTitle = (PWCHAR)pszSubHeader;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Function fills in the given LPPROPSHEETPAGE structure with the
// information needed to run the dummy wizard page that switches to mmc.
//
DWORD
SwitchMmcWizGetProptertyPage (
IN LPPROPSHEETPAGE ppage,
IN LPARAM lpUserData)
{
// Initialize
ZeroMemory(ppage, sizeof(PROPSHEETPAGE));
// The Advanced Properties dialog procedure also implements
// the protocol tab in the incoming connections wizard
ppage->pfnDlgProc = SwitchMmcWizDialogProc;
// Fill in the values
ppage->dwSize = sizeof(PROPSHEETPAGE);
ppage->hInstance = Globals.hInstDll;
ppage->pszTemplate = MAKEINTRESOURCE(PID_Wizard_SwitchMmc);
ppage->pfnCallback = RasSrvInitDestroyPropSheetCb;
ppage->lParam = lpUserData;
ppage->dwFlags = PSP_USEHEADERSUBTITLE |
PSP_USEHEADERTITLE |
PSP_USECALLBACK;
return NO_ERROR;
}
//
// Initializes the vpn wizard tab.
//
DWORD
VpnWizInitializeDialog(
IN HWND hwndDlg,
IN WPARAM wParam)
{
DWORD dwErr;
BOOL bFlag;
HANDLE hDevDatabase = NULL;
// Get handles to the databases we're interested in
RasSrvGetDatabaseHandle(hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
// Initialize the vpn check
dwErr = devGetVpnEnable(hDevDatabase, &bFlag);
if (dwErr != NO_ERROR)
{
ErrDisplayError(
hwndDlg,
ERR_DEVICE_DATABASE_CORRUPT,
ERR_GENERALTAB_CATAGORY,
0,
Globals.dwErrorData);
return dwErr;
}
SendMessage(GetDlgItem(hwndDlg, CID_Wizard_Vpn_RB_Yes),
BM_SETCHECK,
(bFlag) ? BST_CHECKED : BST_UNCHECKED,
0);
SendMessage(GetDlgItem(hwndDlg, CID_Wizard_Vpn_RB_No),
BM_SETCHECK,
(!bFlag) ? BST_CHECKED : BST_UNCHECKED,
0);
return NO_ERROR;
}
//
// Handles cancel button being pressed for the vpn wizard page
//
DWORD
VpnWizCancelEdit(
IN HWND hwndDlg,
IN NMHDR* pNotifyData)
{
HANDLE hDevDatabase = NULL;
DWORD dwErr;
DbgOutputTrace("Rolling back vpn wizard tab.");
// Cancel flush of database
RasSrvGetDatabaseHandle(hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
dwErr = devRollbackDatabase(hDevDatabase);
if (dwErr != NO_ERROR)
{
ErrDisplayError(
hwndDlg,
ERR_GENERAL_CANT_ROLLBACK_CHANGES,
ERR_GENERALTAB_CATAGORY,
0,
Globals.dwErrorData);
}
return NO_ERROR;
}
//
// Handles having the vpn wizard come active
//
DWORD
VpnWizSetActive (
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
PropSheet_SetWizButtons(GetParent(hwndDlg), PSWIZB_NEXT | PSWIZB_BACK);
return NO_ERROR;
}
//
// Handles vpn loose activation messages
//
DWORD
VpnWizKillActive (
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
HANDLE hDevDatabase = NULL;
BOOL bEnable;
//For Whistler bug#123769
//In order to let the SetPortMapping commit
//when creating a new IC connection, we set
//the fVpnEnabledOrig to be different from
// the fVpnEnable
//
RasSrvGetDatabaseHandle(hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
bEnable = IsDlgButtonChecked( hwndDlg, CID_Wizard_Vpn_RB_Yes );
devSetVpnOrigEnable(hDevDatabase, !bEnable);
return NO_ERROR;
}
//
// Processes command messages for the vpn wizard page
//
DWORD
VpnWizCommand(
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
HANDLE hDevDatabase = NULL;
BOOL bEnable;
RasSrvGetDatabaseHandle(hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
if (wParam == CID_Wizard_Vpn_RB_Yes || wParam == CID_Wizard_Vpn_RB_No)
{
bEnable = (BOOL) SendMessage(
GetDlgItem(hwndDlg, CID_Wizard_Vpn_RB_Yes),
BM_GETCHECK,
0,
0);
devSetVpnEnable(hDevDatabase, bEnable);
}
return NO_ERROR;
}
//
// This dialog procedure responds to messages sent to the
// vpn wizard tab.
//
INT_PTR CALLBACK
VpnWizDialogProc(
IN HWND hwndDlg,
IN UINT uMsg,
IN WPARAM wParam,
IN LPARAM lParam)
{
// Filter the customized ras server ui page messages. By filtering
// messages through here, we are able to call RasSrvGetDatabaseHandle
// below
if (RasSrvMessageFilter(hwndDlg, uMsg, wParam, lParam))
return TRUE;
// Process other messages as normal
switch (uMsg)
{
case WM_INITDIALOG:
return FALSE;
break;
case WM_NOTIFY:
switch (((NMHDR*)lParam)->code)
{
case PSN_RESET:
VpnWizCancelEdit(hwndDlg, (NMHDR*)lParam);
SetWindowLongPtr(hwndDlg, DWLP_MSGRESULT, FALSE);
break;
case PSN_SETACTIVE:
if (! GetWindowLongPtr(hwndDlg, GWLP_USERDATA))
{
VpnWizInitializeDialog(hwndDlg, wParam);
SetWindowLongPtr(hwndDlg, GWLP_USERDATA, 1);
}
VpnWizSetActive (hwndDlg, wParam, lParam);
break;
case PSN_KILLACTIVE:
VpnWizKillActive (hwndDlg, wParam, lParam);
break;
}
case WM_COMMAND:
VpnWizCommand(hwndDlg, wParam, lParam);
break;
}
return FALSE;
}
// Fill the device combo box
DWORD
DccdevFillDeviceList(
IN HWND hwndDlg,
IN HANDLE hDevDatabase,
IN HANDLE hDevSelect)
{
HWND hwndCb = GetDlgItem(hwndDlg, CID_Wizard_Dccdev_LB_Devices);
DWORD dwCount, dwIndex, dwErr, i, j=0, dwSelect = 0;
HANDLE hDevice;
PWCHAR pszName = NULL;
// Delete anything that was in the combo box
SendMessage(hwndCb, CB_RESETCONTENT, 0, 0);
// Get the count of devices
if ((dwErr = devGetDeviceCount(hDevDatabase, &dwCount)) != NO_ERROR)
{
return dwErr;
}
// Add them to the device combo box
for (i = 0; i < dwCount; i++)
{
// If the device wasn't filtered out, add it to the combo
// box and remember its handle
dwErr = devGetDeviceHandle(hDevDatabase, i, &hDevice);
if (dwErr == NO_ERROR)
{
devGetDeviceName (hDevice, &pszName);
dwIndex = (DWORD) SendMessage (
hwndCb,
CB_ADDSTRING,
0,
(LPARAM)pszName);
SendMessage (
hwndCb,
CB_SETITEMDATA,
dwIndex,
(LPARAM)hDevice);
// If this is the device to select, remember that fact
if (hDevice == hDevSelect)
{
dwSelect = j;
}
j++;
}
}
ComboBox_SetCurSel(hwndCb, dwSelect);
return NO_ERROR;
}
//
// Initializes the dcc device wizard tab.
//
DWORD
DccdevWizInitializeDialog(
IN HWND hwndDlg,
IN WPARAM wParam)
{
HANDLE hDevDatabase = NULL, hDevice = NULL;
DWORD dwStatus, dwErr, dwCount, i;
BOOL bEnabled;
DCCDEV_DATA * pDcData;
// Whenever the dcc device page is left, the currently selected device
// is remembered and its original enabling is recorded. Then this device
// is set to enabled. Whenever the page is activated, the remembered
// device is restored to its original enabling state if it is still
// enabled.
//
// This whole process is a little confusing, but it ensures that the dcc
// device page will interact correctly when the user goes down the dcc
// path and then the incoming path and back and forth.
//
if ((pDcData = RassrvAlloc (sizeof(DCCDEV_DATA), TRUE)) == NULL)
{
return ERROR_NOT_ENOUGH_MEMORY;
}
// Get handles to the databases we're interested in
RasSrvGetDatabaseHandle(hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
// Add the com ports as devices and filter out all non dcc
// devices from the device database
devFilterDevices(hDevDatabase, INCOMING_TYPE_DIRECT);
devAddComPorts(hDevDatabase);
// Get the count of devices
if ((dwErr = devGetDeviceCount(hDevDatabase, &dwCount)) != NO_ERROR)
{
return dwErr;
}
// Get the handle to the first device if any
for (i = 0; i < dwCount; i++)
{
if (devGetDeviceHandle (hDevDatabase, i, &hDevice) == NO_ERROR)
{
break;
}
}
// Record the device's enabling -- index is 0 (default)
if (hDevice)
{
dwErr = devGetDeviceEnable (hDevice, &(pDcData->bEnabled));
if (dwErr != NO_ERROR)
{
return dwErr;
}
pDcData->hDevice = hDevice;
}
// Record the status bits
SetWindowLongPtr (hwndDlg, GWLP_USERDATA, (LONG_PTR)pDcData);
return NO_ERROR;
}
//
// Cleans up the dcc device wizard
//
DWORD
DccdevWizCleanupDialog(
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
DCCDEV_DATA * pDcData =
(DCCDEV_DATA *) GetWindowLongPtr(hwndDlg, GWLP_USERDATA);
if (pDcData)
{
RassrvFree (pDcData);
}
return NO_ERROR;
}
//
// Called to do any processing when the dcc wizard device page is
// gaining focus
//
DWORD
DccdevWizSetActive (
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
HANDLE hDevDatabase = NULL;
BOOL bEnabled;
DCCDEV_DATA * pDcData;
// Whenever the page is activated, the remembered device
// is restored to its original enabling state if it is still enabled.
pDcData = (DCCDEV_DATA*) GetWindowLongPtr(hwndDlg, GWLP_USERDATA);
if (pDcData && pDcData->hDevice)
{
if (devGetDeviceEnable (pDcData->hDevice, &bEnabled) == NO_ERROR)
{
if (bEnabled)
{
devSetDeviceEnable (pDcData->hDevice, pDcData->bEnabled);
}
}
}
// Get handles to the databases we're interested in
RasSrvGetDatabaseHandle (hwndDlg, ID_DEVICE_DATABASE, &hDevDatabase);
// Fill the device combo box
DccdevFillDeviceList (
hwndDlg,
hDevDatabase,
(pDcData) ? pDcData->hDevice : NULL);
PropSheet_SetWizButtons(GetParent(hwndDlg), PSWIZB_NEXT | PSWIZB_BACK);
return NO_ERROR;
}
//
// Called to do any processing when the dcc wizard device
// page is loosing focus
//
DWORD
DccdevWizKillActive (
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
HANDLE hDevDatabase = NULL, hDevice = NULL;
DCCDEV_DATA * pDcData;
INT iCurSel;
HWND hwndCb = GetDlgItem (hwndDlg, CID_Wizard_Dccdev_LB_Devices);
DWORD dwErr;
// Whenever the dcc device page is left, the currently selected
// device is remembered and its original enabling is recorded.
// Then this device is set to enabled.
pDcData = (DCCDEV_DATA*) GetWindowLongPtr(hwndDlg, GWLP_USERDATA);
if (pDcData)
{
iCurSel = ComboBox_GetCurSel(hwndCb);
if (iCurSel != -1)
{
hDevice = (HANDLE) ComboBox_GetItemData(hwndCb, iCurSel);
dwErr = devGetDeviceEnable (hDevice, &(pDcData->bEnabled));
if (dwErr == NO_ERROR)
{
pDcData->hDevice = hDevice;
devSetDeviceEnable (hDevice, TRUE);
}
}
else
{
pDcData->hDevice = NULL;
}
}
// Get handles to the databases we're interested in
RasSrvGetDatabaseHandle(
hwndDlg,
ID_DEVICE_DATABASE,
&hDevDatabase);
// Undo the filter so that other pages aren't affected
//devFilterDevices(
// hDevDatabase,
// 0xffffffff);
return NO_ERROR;
}
//
// Called to cancel the edit operation on the dcc host
// device wizard tab.
//
DWORD
DccdevWizCancelEdit(
IN HWND hwndDlg,
IN NMHDR* pNotifyData)
{
HANDLE hDevDatabase = NULL;
DWORD dwErr;
DbgOutputTrace("Rolling back dcc device wizard tab.");
// Cancel the commit on the device database
RasSrvGetDatabaseHandle(
hwndDlg,
ID_DEVICE_DATABASE,
&hDevDatabase);
dwErr = devRollbackDatabase(hDevDatabase);
if (dwErr != NO_ERROR)
{
ErrDisplayError(
hwndDlg,
ERR_GENERAL_CANT_ROLLBACK_CHANGES,
ERR_GENERALTAB_CATAGORY,
0,
Globals.dwErrorData);
}
return NO_ERROR;
}
//
// Raises properties for a component
//
DWORD
DccdevWizRaiseProperties (
IN HWND hwndDlg,
IN HWND hwndLb,
IN INT iItem)
{
HANDLE hDevice;
DWORD dwErr = NO_ERROR, dwId;
MSGARGS MsgArgs;
BOOL bIsComPort = FALSE;
// Get a handle to the device
hDevice = (HANDLE) ComboBox_GetItemData(hwndLb, iItem);
if (hDevice == NULL)
{
return ERROR_CAN_NOT_COMPLETE;
}
// Find out if the device is a com port which has not yet had a
// null modem installed.
//
dwErr = devDeviceIsComPort(hDevice, &bIsComPort);
if (dwErr != NO_ERROR)
{
return ERROR_CAN_NOT_COMPLETE;
}
// If so, popup info to the user explaining
// the situation.
//
if (bIsComPort)
{
ZeroMemory(&MsgArgs, sizeof(MsgArgs));
MsgArgs.dwFlags = MB_OK | MB_ICONINFORMATION;
MsgDlgUtil(
hwndDlg,
SID_COM_PORT_NOT_ENABLED,
&MsgArgs,
Globals.hInstDll,
SID_DEFAULT_MSG_TITLE);
return NO_ERROR;
}
// Get the tapi id of the device
if (devGetDeviceId(hDevice, &dwId) != NO_ERROR)
{
return ERROR_CAN_NOT_COMPLETE;
}
// Launch the device properties dialog
dwErr = lineConfigDialogW(dwId, hwndDlg, NULL);
if (dwErr == LINEERR_OPERATIONUNAVAIL)
{
ErrDisplayError(
hwndDlg,
ERR_DEVICE_HAS_NO_CONFIG,
ERR_GENERALTAB_CATAGORY,
0,
Globals.dwErrorData);
dwErr = NO_ERROR;
}
return dwErr;
}
//
// Called when "iItem" is being selected to enable or disable the
// properties button.
//
DWORD
DccdevWizEnableDisableProperties(
IN HWND hwndDlg,
IN HWND hwndLb,
IN INT iItem)
{
return NO_ERROR;
}
//
// Called to cancel the edit operation on the dcc host
// device wizard tab.
//
DWORD
DccdevWizCommand(
HWND hwndDlg,
WPARAM wParam,
LPARAM lParam)
{
switch (LOWORD(wParam))
{
case CID_Dccdev_PB_Properties:
{
HWND hwndLb;
hwndLb = GetDlgItem(hwndDlg, CID_Wizard_Dccdev_LB_Devices);
DccdevWizRaiseProperties(
hwndDlg,
hwndLb,
ComboBox_GetCurSel(hwndLb));
}
break;
case CID_Wizard_Dccdev_LB_Devices:
{
if (HIWORD(wParam) == CBN_SELCHANGE)
{
DccdevWizEnableDisableProperties(
hwndDlg,
(HWND)lParam,
ComboBox_GetCurSel((HWND)lParam));
}
}
break;
}
return NO_ERROR;
}
INT_PTR
CALLBACK
DccdevWizDialogProc(
IN HWND hwndDlg,
IN UINT uMsg,
IN WPARAM wParam,
IN LPARAM lParam)
{
// Filter the customized ras server ui page
// messages. By filtering messages through
// here, we are able to call RasSrvGetDatabaseHandle
// below
if (RasSrvMessageFilter(hwndDlg, uMsg, wParam, lParam))
return TRUE;
// Process other messages as normal
switch (uMsg)
{
case WM_INITDIALOG:
return FALSE;
case WM_NOTIFY:
switch (((NMHDR*)lParam)->code)
{
case PSN_RESET:
DccdevWizCancelEdit(hwndDlg, (NMHDR*)lParam);
SetWindowLongPtr(hwndDlg, DWLP_MSGRESULT, FALSE);
break;
case PSN_SETACTIVE:
{
DWORD dwErr;
if (! GetWindowLongPtr(hwndDlg, GWLP_USERDATA))
{
DccdevWizInitializeDialog(hwndDlg, wParam);
}
dwErr = DccdevWizSetActive (
hwndDlg,
wParam,
lParam);
if (dwErr != NO_ERROR)
{
SetWindowLongPtr(hwndDlg, DWLP_MSGRESULT, -1);
}
}
break;
case PSN_KILLACTIVE:
DccdevWizKillActive (hwndDlg, wParam, lParam);
break;
}
break;//for bug 187918
case WM_COMMAND:
DccdevWizCommand(hwndDlg, wParam, lParam);
break;
case WM_DESTROY:
DccdevWizCleanupDialog(hwndDlg, wParam, lParam);
break;
}
return FALSE;
}
//
// Handles the activation of the switch to mmc wizard page.
//
DWORD
SwitchMmcWizSetActive (
IN HWND hwndDlg,
IN WPARAM wParam,
IN LPARAM lParam)
{
PWCHAR pszTitle;
PWCHAR pszMessage;
INT iRet;
// Load the messages to display
pszTitle = (PWCHAR)
PszLoadString(Globals.hInstDll, WRN_WIZARD_NOT_ALLOWED_TITLE);
pszMessage = (PWCHAR)
PszLoadString(Globals.hInstDll, WRN_WIZARD_NOT_ALLOWED_MSG);
iRet = MessageBox (
hwndDlg,
pszMessage,
pszTitle,
MB_YESNO | MB_ICONINFORMATION);
if (iRet == 0)
{
return ERROR_NOT_ENOUGH_MEMORY;
}
// If yes was pressed, switch to mpradmin snapin.
if (iRet == IDYES)
{
RasSrvLeaveServiceRunning (hwndDlg);
PropSheet_PressButton (GetParent (hwndDlg), PSBTN_CANCEL);
RassrvLaunchMMC (RASSRVUI_MPRCONSOLE);
}
// Otherwise, display the welcome page
else if (iRet == IDNO)
{
PropSheet_PressButton (GetParent (hwndDlg), PSBTN_BACK);
}
// No matter what, don't accept activation
SetWindowLongPtr(hwndDlg, DWLP_MSGRESULT, -1);
return NO_ERROR;
}
// This dialog procedure responds to messages sent to the
// switch to mmc wizard tab.
INT_PTR
CALLBACK
SwitchMmcWizDialogProc (
HWND hwndDlg,
UINT uMsg,
WPARAM wParam,
LPARAM lParam)
{
// Filter the customized ras server ui page messages. By filtering
// messages through here, we are able to call RasSrvGetDatabaseHandle
// below
if (RasSrvMessageFilter(hwndDlg, uMsg, wParam, lParam))
return TRUE;
// Process other messages as normal
switch (uMsg)
{
case WM_NOTIFY:
switch (((NMHDR*)lParam)->code)
{
case PSN_SETACTIVE:
return SwitchMmcWizSetActive (hwndDlg, wParam, lParam);
break;
}
break;
}
return FALSE;
}