1039 lines
27 KiB
C
1039 lines
27 KiB
C
|
/*
|
||
|
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;
|
||
|
}
|
||
|
|
||
|
|
||
|
|