Windows2003-3790/admin/cys/win32/expressrebootpage.cpp
2020-09-30 16:53:55 +02:00

1323 lines
36 KiB
C++

// Copyright (c) 2001 Microsoft Corporation
//
// File: ExpressRebootPage.cpp
//
// Synopsis: Defines the ExpressRebootPage that shows
// the progress of the changes being made to
// the server after the reboot fromt the
// express path
//
// History: 05/11/2001 JeffJon Created
#include "pch.h"
#include "resource.h"
#include "InstallationUnitProvider.h"
#include "ExpressRebootPage.h"
// Private window messages for updating the UI status
// For these messages the WPARAM is the operation that finished, and
// the LPARAM is the operation that is next
const UINT ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS = WM_USER + 1001;
const UINT ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED = WM_USER + 1002;
const UINT ExpressRebootPage::CYS_OPERATION_COMPLETE_SUCCESS = WM_USER + 1003;
const UINT ExpressRebootPage::CYS_OPERATION_COMPLETE_FAILED = WM_USER + 1004;
// This structure maps the four static controls that make up an operation
// together. The pageProgress array must be in the order the operations
// will take place so that the page can update appropriately when
// an CYS_OPERATION_FINISHED_* message is sent back to the page
typedef struct _PageProgressStruct
{
unsigned int currentIconControl;
unsigned int checkIconControl;
unsigned int errorIconControl;
unsigned int staticIconControl;
} PageProgressStruct;
PageProgressStruct pageOperationProgress[] =
{
{
IDC_IPADDRESS_CURRENT_STATIC,
IDC_IPADDRESS_CHECK_STATIC,
IDC_IPADDRESS_ERROR_STATIC,
IDC_IPADDRESS_STATIC
},
{
IDC_DHCP_CURRENT_STATIC,
IDC_DHCP_CHECK_STATIC,
IDC_DHCP_ERROR_STATIC,
IDC_DHCP_STATIC
},
{
IDC_AD_CURRENT_STATIC,
IDC_AD_CHECK_STATIC,
IDC_AD_ERROR_STATIC,
IDC_AD_STATIC
},
{
IDC_DNS_CURRENT_STATIC,
IDC_DNS_CHECK_STATIC,
IDC_DNS_ERROR_STATIC,
IDC_DNS_STATIC
},
{
IDC_FORWARDER_CURRENT_STATIC,
IDC_FORWARDER_CHECK_STATIC,
IDC_FORWARDER_ERROR_STATIC,
IDC_FORWARDER_STATIC
},
{
IDC_DHCP_SCOPE_CURRENT_STATIC,
IDC_DHCP_SCOPE_CHECK_STATIC,
IDC_DHCP_SCOPE_ERROR_STATIC,
IDC_DHCP_SCOPE_STATIC
},
{
IDC_AUTHORIZE_SCOPE_CURRENT_STATIC,
IDC_AUTHORIZE_SCOPE_CHECK_STATIC,
IDC_AUTHORIZE_SCOPE_ERROR_STATIC,
IDC_AUTHORIZE_SCOPE_STATIC
},
{
IDC_TAPI_CURRENT_STATIC,
IDC_TAPI_CHECK_STATIC,
IDC_TAPI_ERROR_STATIC,
IDC_TAPI_STATIC
},
{ 0, 0, 0, 0 }
};
bool
SetDNSForwarder(HANDLE logfileHandle)
{
LOG_FUNCTION(SetDNSForwarder);
bool result = true;
do
{
// First read the regky
DWORD forwarder = 0;
String autoForwarder;
bool forwarderResult = GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_FORWARDER,
forwarder);
bool autoForwarderResult = GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_AUTOFORWARDER,
autoForwarder);
if (forwarderResult &&
forwarder != 0)
{
DWORD forwarderInDisplayOrder = ConvertIPAddressOrder(forwarder);
LOG(String::format(
L"Setting forwarder from forwarder regkey: %1",
IPAddressToString(forwarderInDisplayOrder).c_str()));
DNS_STATUS error = ::DnssrvResetForwarders(
L"localhost",
1,
&forwarder,
DNS_DEFAULT_FORWARD_TIMEOUT,
DNS_DEFAULT_SLAVE);
if (error != 0)
{
LOG(String::format(
L"Failed to set the forwarder: error = 0x%1!x!",
error));
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_FORWARDER_FAILED));
result = false;
break;
}
CYS_APPEND_LOG(
String::format(
IDS_EXPRESS_REBOOT_FORWARDER_SUCCEEDED,
IPAddressToString(forwarderInDisplayOrder).c_str()));
}
else if (autoForwarderResult &&
!autoForwarder.empty())
{
LOG(String::format(
L"Setting forwarder from autoforwarder regkey: %1",
autoForwarder.c_str()));
// Now parse the forwarders string into a DWORD array
StringList forwardersList;
autoForwarder.tokenize(std::back_inserter(forwardersList));
DWORD count = 0;
DWORD* forwarderArray = StringIPListToDWORDArray(forwardersList, count);
if (forwarderArray)
{
DNS_STATUS error = ::DnssrvResetForwarders(
L"localhost",
count,
forwarderArray,
DNS_DEFAULT_FORWARD_TIMEOUT,
DNS_DEFAULT_SLAVE);
// Delete the memory returned from StringIPListToDWORDArray
delete[] forwarderArray;
forwarderArray = 0;
// Check for errors
if (error != 0)
{
LOG(String::format(
L"Failed to set the forwarder: error = 0x%1!x!",
error));
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_FORWARDER_FAILED));
result = false;
break;
}
}
}
else
{
// Since the regkey wasn't set that means we should try
// to take the forwarders from the NICs defined server list
IPAddressList forwarders;
InstallationUnitProvider::GetInstance().GetDNSInstallationUnit().GetForwarders(forwarders);
if (forwarders.empty())
{
LOG(L"No DNS servers set on any NIC");
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_FORWARDER_FAILED));
result = false;
break;
}
// This is an exception throwing new so there is no
// reason to check for NULL
DWORD forwardersCount = static_cast<DWORD>(forwarders.size());
DWORD* forwardersArray = new DWORD[forwardersCount];
// Copy the forwarders addresses into the array
for (DWORD idx = 0; idx < forwardersCount; ++idx)
{
// The IP address must be in network order (d.c.b.a) not in the UI
// order (a.b.c.d)
forwardersArray[idx] = ConvertIPAddressOrder(forwarders[idx]);
}
// Now set the forwarders in the DNS server
DNS_STATUS error = ::DnssrvResetForwarders(
L"localhost",
forwardersCount,
forwardersArray,
DNS_DEFAULT_FORWARD_TIMEOUT,
DNS_DEFAULT_SLAVE);
// Delete the allocated array
delete[] forwardersArray;
forwardersArray = 0;
// Check for errors
if (error != 0)
{
LOG(String::format(
L"Failed to set the forwarders: error = 0x%1!x!",
error));
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_FORWARDER_FAILED));
result = false;
break;
}
CYS_APPEND_LOG(
String::format(
IDS_EXPRESS_REBOOT_FORWARDER_SUCCEEDED,
IPAddressToString(ConvertIPAddressOrder(forwardersArray[0])).c_str()));
}
} while (false);
LOG_BOOL(result);
return result;
}
void _cdecl
wrapperThreadProc(void* p)
{
if (!p)
{
ASSERT(p);
return;
}
bool result = true;
ExpressRebootPage* page =
reinterpret_cast<ExpressRebootPage*>(p);
ASSERT(page);
HWND hwnd = page->GetHWND();
// Create the log file
bool logFileAvailable = false;
String logName;
HANDLE logfileHandle = AppendLogFile(
CYS_LOGFILE_NAME,
logName);
if (logfileHandle &&
logfileHandle != INVALID_HANDLE_VALUE)
{
LOG(String::format(L"New log file was created: %1", logName.c_str()));
logFileAvailable = true;
}
else
{
LOG(L"Unable to create the log file!!!");
logFileAvailable = false;
}
ExpressInstallationUnit& expressInstallationUnit =
InstallationUnitProvider::GetInstance().GetExpressInstallationUnit();
// NTRAID#NTBUG9-638337-2002/06/13-JeffJon
// Need to compare the IP address that was written to the registry
// to the current IP address to see if they are the same
String currentIPAddress;
NetworkInterface* localNIC =
State::GetInstance().GetLocalNICFromRegistry();
if (localNIC)
{
// Set the static text for the IP Address
currentIPAddress =
localNIC->GetStringIPAddress(0);
}
String attemptedIPAddress = page->GetIPAddressString();
if (attemptedIPAddress.icompare(currentIPAddress) == 0)
{
LOG(L"The current IP address and the IP address from the registry match");
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_STATIC_IP,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DHCP);
}
else
{
// Since the IP addresses didn't match we have to show the error
// Most likely this was caused by another machine coming up on the
// network with the same IP as we set before the reboot.
LOG(L"Failed to set the static IP address.");
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_STATIC_IP,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DHCP);
}
if (!page->WasDHCPInstallAttempted() ||
InstallationUnitProvider::GetInstance().
GetDHCPInstallationUnit().IsServiceInstalled())
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DHCP,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_AD);
}
else
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DHCP,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_AD);
if (result)
{
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_DHCP_INSTALL_FAILURE);
}
result = false;
}
// Verify the machine is a DC
// Check to see if DCPromo was successful in making this a DC
if (State::GetInstance().IsDC())
{
CYS_APPEND_LOG(String::load(IDS_LOG_DCPROMO_REBOOT_SUCCEEDED));
// Log the new domain name
CYS_APPEND_LOG(String::load(IDS_EXPRESS_SERVER_AD));
CYS_APPEND_LOG(
String::format(
IDS_EXPRESS_AD_DOMAIN_NAME,
State::GetInstance().GetDomainDNSName().c_str()));
CYS_APPEND_LOG(
String::format(
IDS_EXPRESS_AD_NETBIOS_NAME,
State::GetInstance().GetDomainNetbiosName().c_str()));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_AD,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DNS);
}
else
{
LOG(L"DCPromo failed on reboot");
CYS_APPEND_LOG(String::load(IDS_LOG_DCPROMO_REBOOT_FAILED));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_AD,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DNS);
// Only override the role result if it hasn't already been set
if (result)
{
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_AD_FAILURE);
}
result = false;
}
// DNS is now the current operation, check to see if it is installed
if (InstallationUnitProvider::GetInstance().
GetDNSInstallationUnit().IsServiceInstalled())
{
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_DNS_SERVER_SUCCEEDED));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DNS,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER);
if (page->SetForwarder())
{
// Now wait for the service to start before trying to set the forwarders
NTService serviceObject(CYS_DNS_SERVICE_NAME);
HRESULT hr = serviceObject.WaitForServiceState(SERVICE_RUNNING);
if (SUCCEEDED(hr))
{
if (SetDNSForwarder(logfileHandle))
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
}
else
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_DNS_FORWARDER_FAILURE);
result = false;
}
}
else
{
LOG(L"The DNS service never started!");
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_DNS_FORWARDER_FAILURE);
result = false;
}
}
else
{
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_LOG_NO_FORWARDER));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
}
}
else
{
CYS_APPEND_LOG(String::load(IDS_EXPRESS_REBOOT_DNS_SERVER_FAILED));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SERVER_DNS,
(LPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER);
// If the DNS service isn't installed there is no way to set a
// forwarder
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_SET_DNS_FORWARDER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
// Only override the role result if it hasn't already been set
if (result)
{
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_DNS_SERVER_FAILURE);
}
result = false;
}
// Verify DHCP scope activation
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_ACTIVATE_DHCP_SCOPE,
(LPARAM)ExpressRebootPage::CYS_OPERATION_AUTHORIZE_DHCP_SERVER);
// Authorize the DHCP server
String dnsName = Win::GetComputerNameEx(ComputerNameDnsFullyQualified);
if (page->WasDHCPInstallAttempted())
{
if (InstallationUnitProvider::GetInstance().GetDHCPInstallationUnit().AuthorizeDHCPServer(dnsName))
{
LOG(L"DHCP server successfully authorized");
CYS_APPEND_LOG(String::load(IDS_LOG_DHCP_AUTHORIZATION_SUCCEEDED));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_AUTHORIZE_DHCP_SERVER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_CREATE_TAPI_PARTITION);
}
else
{
LOG(L"DHCP scope authorization failed");
String failureMessage = String::load(IDS_LOG_DHCP_AUTHORIZATION_FAILED);
CYS_APPEND_LOG(failureMessage);
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_AUTHORIZE_DHCP_SERVER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_CREATE_TAPI_PARTITION);
// Only override the role result if it hasn't already been set
if (result)
{
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_DHCP_ACTIVATION_FAILURE);
}
result = false;
}
}
else
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_AUTHORIZE_DHCP_SERVER,
(LPARAM)ExpressRebootPage::CYS_OPERATION_CREATE_TAPI_PARTITION);
}
// Do TAPI config
HRESULT hr =
InstallationUnitProvider::GetInstance().
GetExpressInstallationUnit().DoTapiConfig(
State::GetInstance().GetDomainDNSName());
if (SUCCEEDED(hr))
{
LOG(L"TAPI config succeeded");
CYS_APPEND_LOG(String::load(IDS_LOG_TAPI_CONFIG_SUCCEEDED));
CYS_APPEND_LOG(
String::format(
IDS_LOG_TAPI_CONFIG_SUCCEEDED_FORMAT,
dnsName.c_str()));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_SUCCESS,
(WPARAM)ExpressRebootPage::CYS_OPERATION_CREATE_TAPI_PARTITION,
(LPARAM)ExpressRebootPage::CYS_OPERATION_END);
}
else
{
LOG(L"TAPI config failed");
CYS_APPEND_LOG(
String::format(
IDS_LOG_TAPI_CONFIG_FAILED_FORMAT,
hr));
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_FINISHED_FAILED,
(WPARAM)ExpressRebootPage::CYS_OPERATION_CREATE_TAPI_PARTITION,
(LPARAM)ExpressRebootPage::CYS_OPERATION_END);
// Only override the role result if it hasn't already been set
if (result)
{
expressInstallationUnit.SetExpressRoleResult(
ExpressInstallationUnit::EXPRESS_TAPI_FAILURE);
}
result = false;
}
// Close the log file
Win::CloseHandle(logfileHandle);
if (result)
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_COMPLETE_SUCCESS,
0,
0);
}
else
{
Win::SendMessage(
hwnd,
ExpressRebootPage::CYS_OPERATION_COMPLETE_FAILED,
0,
0);
}
}
static PCWSTR EXPRESS_REBOOT_PAGE_HELP = L"cys.chm::/typical_setup.htm";
ExpressRebootPage::ExpressRebootPage()
:
dhcpInstallAttempted(true),
setForwarder(true),
threadDone(false),
CYSWizardPage(
IDD_EXPRESS_REBOOT_PAGE,
IDS_EXPRESS_REBOOT_TITLE,
IDS_EXPRESS_REBOOT_SUBTITLE,
EXPRESS_REBOOT_PAGE_HELP)
{
LOG_CTOR(ExpressRebootPage);
}
ExpressRebootPage::~ExpressRebootPage()
{
LOG_DTOR(ExpressRebootPage);
}
void
ExpressRebootPage::OnInit()
{
LOG_FUNCTION(ExpressRebootPage::OnInit);
CYSWizardPage::OnInit();
// Since this page can be started directly
// we have to be sure to set the wizard title
Win::PropSheet_SetTitle(
Win::GetParent(hwnd),
0,
String::load(IDS_WIZARD_TITLE));
ClearOperationStates();
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
IDC_EXPRESS_CONFIG_DONE_STATIC),
false);
// Set the range and step size for the progress bar
Win::SendMessage(
Win::GetDlgItem(hwnd, IDC_CONFIG_PROGRESS),
PBM_SETRANGE,
0,
MAKELPARAM(CYS_OPERATION_SET_STATIC_IP, CYS_OPERATION_END));
Win::SendMessage(
Win::GetDlgItem(hwnd, IDC_CONFIG_PROGRESS),
PBM_SETSTEP,
(WPARAM)1,
0);
// Set the state object so that CYS doesn't run again
// State::GetInstance().SetRerunWizard(false);
// Initialize the state object so we can get the info to put
// in the UI
State::GetInstance().RetrieveMachineConfigurationInformation(
0,
false,
IDS_RETRIEVE_NIC_INFO,
IDS_RETRIEVE_OS_INFO,
IDS_LOCAL_AREA_CONNECTION,
IDS_DETECTING_SETTINGS_FORMAT);
// NTRAID#NTBUG9-638337-2002/06/13-JeffJon
// We need to display the IP address that was written to the
// registry before the reboot because the "local NIC" IP
// address may have been changed if a machine was brought
// up on the network with a duplicate IP address while we
// were rebooting.
if (!GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_STATIC_IP,
ipaddressString,
HKEY_LOCAL_MACHINE))
{
LOG(L"Failed to read the regkey for the static IP address.");
}
String ipaddressStaticText = String::format(
IDS_EXPRESS_REBOOT_IPADDRESS,
ipaddressString.c_str());
Win::SetDlgItemText(
hwnd,
IDC_IPADDRESS_STATIC,
ipaddressStaticText);
// Set the static text for the DNS Forwarder
String forwarderStaticText;
String autoForwardersText;
DWORD forwarder = 0;
bool forwarderResult = GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_FORWARDER,
forwarder);
bool autoForwarderResult = GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_AUTOFORWARDER,
autoForwardersText);
if (forwarderResult)
{
// We were able to read the fowarder regkey so the user
// must have seen the DNS Forwarder page before the reboot
if (forwarder != 0)
{
// The user entered an IP address on the DNS Forwarder page
// before the reboot
DWORD forwarderInDisplayOrder = ConvertIPAddressOrder(forwarder);
forwarderStaticText = String::format(
IDS_EXPRESS_REBOOT_FORWARDER,
IPAddressToString(forwarderInDisplayOrder).c_str());
LOG(String::format(
L"Read forwarders from forwarder key: %1",
forwarderStaticText.c_str()));
}
else
{
// The user chose not to forward when prompted on the DNS Forwarder
// page before the reboot
forwarderStaticText = String::load(IDS_EXPRESS_REBOOT_NO_FORWARDER);
setForwarder = false;
}
}
else if (autoForwarderResult &&
!autoForwardersText.empty())
{
forwarderStaticText = String::format(
IDS_EXPRESS_REBOOT_FORWARDER,
autoForwardersText.c_str());
LOG(String::format(
L"Read forwarders from autoforwarder key: %1",
autoForwardersText.c_str()));
}
else
{
LOG(L"Failed to read both the forwarders and autoforwarders key, using local NIC settings instead");
// Get the DNS servers from the NICs
IPAddressList forwarders;
InstallationUnitProvider::GetInstance().GetDNSInstallationUnit().GetForwarders(forwarders);
if (!forwarders.empty())
{
// Format the IP addresses into a string for display
// each IP address is separated by a space
String ipList;
for (IPAddressList::iterator itr = forwarders.begin();
itr != forwarders.end();
++itr)
{
if (!ipList.empty())
{
ipList += L" ";
}
ipList += String::format(
L"%1",
IPAddressToString(*itr).c_str());
}
forwarderStaticText = String::format(
IDS_EXPRESS_REBOOT_FORWARDER,
ipList.c_str());
}
else
{
forwarderStaticText = String::load(IDS_EXPRESS_REBOOT_NO_FORWARDER);
setForwarder = false;
}
}
Win::SetDlgItemText(
hwnd,
IDC_FORWARDER_STATIC,
forwarderStaticText);
SetDHCPStatics();
// Start up another thread that will perform the operations
// and post messages back to the page to update the UI
_beginthread(wrapperThreadProc, 0, this);
}
bool
ExpressRebootPage::OnSetActive()
{
LOG_FUNCTION(ExpressRebootPage::OnSetActive);
// Disable all the wizard buttons until the other
// thread is finished
if (threadDone)
{
Win::PropSheet_SetWizButtons(
Win::GetParent(hwnd),
PSWIZB_NEXT);
}
else
{
Win::PropSheet_SetWizButtons(
Win::GetParent(hwnd),
0);
}
// Disable the cancel button and the X in the upper
// right corner
SetCancelState(false);
return true;
}
void
ExpressRebootPage::SetCancelState(bool enable) const
{
LOG_FUNCTION(ExpressRebootPage::SetCancelState);
// Set the state of the button
Win::EnableWindow(
Win::GetDlgItem(
Win::GetParent(hwnd),
IDCANCEL),
enable);
// Set the state of the X in the upper right corner
HMENU menu = GetSystemMenu(GetParent(hwnd), FALSE);
if (menu)
{
if (enable)
{
EnableMenuItem(
menu,
SC_CLOSE,
MF_BYCOMMAND | MF_ENABLED);
}
else
{
EnableMenuItem(
menu,
SC_CLOSE,
MF_BYCOMMAND | MF_GRAYED);
}
}
}
void
ExpressRebootPage::SetDHCPStatics()
{
LOG_FUNCTION(ExpressRebootPage::SetDHCPStatics);
DWORD dhcpInstalled = 0;
bool regResult = GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_DHCP_SERVERED,
dhcpInstalled,
HKEY_LOCAL_MACHINE);
if (regResult && !dhcpInstalled)
{
dhcpInstallAttempted = false;
// Set the static text so that users know we didn't install DHCP
Win::SetDlgItemText(
hwnd,
IDC_DHCP_STATIC,
String::load(IDS_EXPRESS_DHCP_NOT_REQUIRED));
Win::SetDlgItemText(
hwnd,
IDC_DHCP_SCOPE_STATIC,
String::load(IDS_EXPRESS_DHCP_SCOPE_NONE));
Win::SetDlgItemText(
hwnd,
IDC_AUTHORIZE_SCOPE_STATIC,
String::load(IDS_EXPRESS_DHCP_NO_AUTHORIZATION));
}
else
{
dhcpInstallAttempted = true;
// Set the static text for the DHCP scopes to authorize
String start;
if (!GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_SCOPE_START,
start))
{
LOG(L"Failed to get the start scope regkey");
}
String end;
if (!GetRegKeyValue(
CYS_FIRST_DC_REGKEY,
CYS_FIRST_DC_SCOPE_END,
end))
{
LOG(L"Failed to get the end scope regkey");
}
String authorizedScopesText = String::format(
IDS_EXPRESS_REBOOT_DHCP_SCOPE,
start.c_str(),
end.c_str());
Win::SetDlgItemText(
hwnd,
IDC_DHCP_SCOPE_STATIC,
authorizedScopesText);
}
}
bool
ExpressRebootPage::OnMessage(
UINT message,
WPARAM wparam,
LPARAM lparam)
{
// LOG_FUNCTION(ExpressRebootPage::OnMessage);
bool result = false;
CYS_OPERATION_TYPES finishedOperation = static_cast<CYS_OPERATION_TYPES>(wparam);
CYS_OPERATION_TYPES nextOperation = static_cast<CYS_OPERATION_TYPES>(lparam);
switch (message)
{
case CYS_OPERATION_FINISHED_SUCCESS:
SetOperationState(
OPERATION_STATE_FINISHED_SUCCESS,
finishedOperation,
nextOperation);
result = true;
break;
case CYS_OPERATION_FINISHED_FAILED:
SetOperationState(
OPERATION_STATE_FINISHED_FAILED,
finishedOperation,
nextOperation);
result = true;
break;
case CYS_OPERATION_COMPLETE_SUCCESS:
{
// enable the Next button
Win::PropSheet_SetWizButtons(
Win::GetParent(hwnd),
PSWIZB_NEXT);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
IDC_EXPRESS_CONFIG_DONE_STATIC),
true);
result = true;
threadDone = true;
InstallationUnitProvider::GetInstance().
GetExpressInstallationUnit().SetInstallResult(INSTALL_SUCCESS);
}
break;
case CYS_OPERATION_COMPLETE_FAILED:
{
// enable the Next button
Win::PropSheet_SetWizButtons(
Win::GetParent(hwnd),
PSWIZB_NEXT);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
IDC_EXPRESS_CONFIG_DONE_STATIC),
true);
result = true;
threadDone = true;
InstallationUnitProvider::GetInstance().
GetExpressInstallationUnit().SetInstallResult(INSTALL_FAILURE);
}
break;
default:
result =
CYSWizardPage::OnMessage(
message,
wparam,
lparam);
break;
}
return result;
}
void
ExpressRebootPage::SetOperationState(
OperationStateType state,
CYS_OPERATION_TYPES currentOperation,
CYS_OPERATION_TYPES nextOperation)
{
LOG_FUNCTION(ExpressRebootPage::SetOperationState);
switch (state)
{
case OPERATION_STATE_UNKNOWN:
if (currentOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].currentIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].checkIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].errorIconControl),
SW_HIDE);
}
if (nextOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].currentIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].checkIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].errorIconControl),
SW_HIDE);
}
break;
case OPERATION_STATE_FINISHED_SUCCESS:
if (currentOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].currentIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].errorIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].checkIconControl),
SW_SHOW);
}
if (nextOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].checkIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].errorIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].currentIconControl),
SW_SHOW);
}
// Update the progress bar
Win::SendMessage(
Win::GetDlgItem(hwnd, IDC_CONFIG_PROGRESS),
PBM_STEPIT,
0,
0);
break;
case OPERATION_STATE_FINISHED_FAILED:
if (currentOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].currentIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].checkIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[currentOperation].errorIconControl),
SW_SHOW);
}
if (nextOperation < CYS_OPERATION_END)
{
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].checkIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].errorIconControl),
SW_HIDE);
Win::ShowWindow(
Win::GetDlgItem(
hwnd,
pageOperationProgress[nextOperation].currentIconControl),
SW_SHOW);
}
// Update the progress bar
Win::SendMessage(
Win::GetDlgItem(hwnd, IDC_CONFIG_PROGRESS),
PBM_STEPIT,
0,
0);
break;
default:
// Right now I am not handling the CYS_OPERATION_COMPLETED_* messages
break;
}
}
void
ExpressRebootPage::ClearOperationStates()
{
LOG_FUNCTION(ExpressRebootPage::ClearOperationStates);
SetOperationState(
OPERATION_STATE_UNKNOWN,
CYS_OPERATION_SET_STATIC_IP,
CYS_OPERATION_SERVER_DHCP);
SetOperationState(
OPERATION_STATE_UNKNOWN,
CYS_OPERATION_SERVER_AD,
CYS_OPERATION_SERVER_DNS);
SetOperationState(
OPERATION_STATE_UNKNOWN,
CYS_OPERATION_SET_DNS_FORWARDER,
CYS_OPERATION_ACTIVATE_DHCP_SCOPE);
SetOperationState(
OPERATION_STATE_UNKNOWN,
CYS_OPERATION_AUTHORIZE_DHCP_SERVER,
CYS_OPERATION_CREATE_TAPI_PARTITION);
}
int
ExpressRebootPage::Validate()
{
LOG_FUNCTION(ExpressRebootPage::Validate);
int nextPage = IDD_FINISH_PAGE;
return nextPage;
}
String
ExpressRebootPage::GetIPAddressString() const
{
LOG_FUNCTION(ExpressRebootPage::GetIPAddressString);
String result = ipaddressString;
LOG(result);
return result;
}