288 lines
7.3 KiB
C++
288 lines
7.3 KiB
C++
// Copyright (c) 2001-2001 Microsoft Corporation
|
|
//
|
|
// Implementation of ExecuteWizard
|
|
//
|
|
// 30 Mar 2000 sburns
|
|
// 05 Fed 2001 jeffjon copied and modified to work with
|
|
// a Win32 version of CYS
|
|
|
|
|
|
|
|
#include "pch.h"
|
|
#include "resource.h"
|
|
|
|
|
|
|
|
String
|
|
LaunchWrapperWizardExe(
|
|
const String& fullPath,
|
|
String& commandLine,
|
|
unsigned launchFailureResId,
|
|
unsigned failureResId,
|
|
unsigned successResId)
|
|
{
|
|
LOG_FUNCTION2(LaunchWrapperWizardExe, fullPath);
|
|
LOG(String::format(
|
|
L"commandLine = %1",
|
|
commandLine.c_str()));
|
|
|
|
ASSERT(!fullPath.empty());
|
|
ASSERT(launchFailureResId);
|
|
ASSERT(failureResId);
|
|
ASSERT(successResId);
|
|
|
|
String result;
|
|
do
|
|
{
|
|
DWORD exitCode = 0;
|
|
HRESULT hr = CreateAndWaitForProcess(fullPath, commandLine, exitCode);
|
|
if (FAILED(hr))
|
|
{
|
|
result = String::load(launchFailureResId);
|
|
break;
|
|
}
|
|
|
|
// the exit codes from the wrapper wizards are HRESULTs.
|
|
|
|
if (SUCCEEDED(static_cast<HRESULT>(exitCode)))
|
|
{
|
|
result = String::load(successResId);
|
|
break;
|
|
}
|
|
|
|
result = String::load(failureResId);
|
|
}
|
|
while (0);
|
|
|
|
LOG(result);
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
|
|
// On success, returns the empty string.
|
|
// On failure, returns a failure message string for the CYS log.
|
|
|
|
String
|
|
LaunchPrintWizardExe(
|
|
HWND parent,
|
|
const String& commandLine,
|
|
unsigned launchFailureResId,
|
|
unsigned failureResId,
|
|
unsigned executeFailureResId,
|
|
HRESULT& hr)
|
|
{
|
|
LOG_FUNCTION2(LaunchPrintWizardExe, commandLine);
|
|
ASSERT(Win::IsWindow(parent));
|
|
ASSERT(!commandLine.empty());
|
|
ASSERT(launchFailureResId);
|
|
ASSERT(failureResId);
|
|
ASSERT(executeFailureResId);
|
|
|
|
String result;
|
|
HINSTANCE printui = 0;
|
|
|
|
do
|
|
{
|
|
hr = Win::LoadLibrary(L"printui.dll", printui);
|
|
if (FAILED(hr))
|
|
{
|
|
LOG("LoadLibrary Failed");
|
|
|
|
result =
|
|
String::format(
|
|
failureResId,
|
|
String::load(launchFailureResId).c_str(),
|
|
hr,
|
|
GetErrorMessage(hr).c_str());
|
|
break;
|
|
}
|
|
|
|
FARPROC proc = 0;
|
|
hr = Win::GetProcAddress(printui, L"PrintUIEntryW", proc);
|
|
if (FAILED(hr))
|
|
{
|
|
LOG("GetProcAddress Failed");
|
|
|
|
result =
|
|
String::format(
|
|
failureResId,
|
|
String::load(launchFailureResId).c_str(),
|
|
hr,
|
|
GetErrorMessage(hr).c_str());
|
|
break;
|
|
}
|
|
|
|
typedef DWORD (*PrintUIEntryW)(HWND, HINSTANCE, PCTSTR, UINT);
|
|
PrintUIEntryW uiproc = reinterpret_cast<PrintUIEntryW>(proc);
|
|
|
|
DWORD err =
|
|
uiproc(
|
|
parent,
|
|
Win::GetModuleHandle(),
|
|
commandLine.c_str(),
|
|
TRUE);
|
|
|
|
hr = Win32ToHresult(err);
|
|
if (FAILED(hr))
|
|
{
|
|
result =
|
|
String::format(
|
|
failureResId,
|
|
String::load(executeFailureResId).c_str(),
|
|
hr,
|
|
GetErrorMessage(hr).c_str());
|
|
}
|
|
}
|
|
while (0);
|
|
|
|
if (printui)
|
|
{
|
|
HRESULT unused = Win::FreeLibrary(printui);
|
|
ASSERT(SUCCEEDED(unused));
|
|
}
|
|
|
|
LOG_HRESULT(hr);
|
|
LOG(result);
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
|
|
// Return : True if the wizard was run, false if the serviceName was unknown
|
|
// Other errors are propogated out through the hr parameter. These
|
|
// errors originate as exit codes from the wizards which are being
|
|
// called
|
|
|
|
bool ExecuteWizard(
|
|
HWND parent,
|
|
PCWSTR serviceName,
|
|
String& resultText,
|
|
HRESULT& hr)
|
|
{
|
|
LOG_FUNCTION2(
|
|
ExecuteWizard,
|
|
serviceName ? serviceName : L"(empty)");
|
|
|
|
// some wizards, namely the printer wizard, like to have a parent window so
|
|
// that they can run modally.
|
|
// NTRAID#NTBUG9-706913-2002/09/23-sburns
|
|
|
|
ASSERT(Win::IsWindow(parent));
|
|
|
|
resultText.erase();
|
|
|
|
bool result = true;
|
|
|
|
// This is ignored by most of the Installation Units
|
|
// but can be used for determining success or cancellation by others
|
|
|
|
hr = S_OK;
|
|
|
|
do
|
|
{
|
|
if (!serviceName)
|
|
{
|
|
ASSERT(serviceName);
|
|
break;
|
|
}
|
|
|
|
String service(serviceName);
|
|
|
|
if (service.icompare(CYS_DNS_SERVICE_NAME) == 0)
|
|
{
|
|
// launch wrapper exe
|
|
|
|
resultText =
|
|
LaunchWrapperWizardExe(
|
|
String::format(
|
|
IDS_LAUNCH_DNS_WIZARD_COMMAND_LINE,
|
|
Win::GetSystemDirectory().c_str()),
|
|
String(),
|
|
IDS_LAUNCH_DNS_WIZARD_FAILED,
|
|
IDS_DNS_WIZARD_FAILED,
|
|
IDS_DNS_WIZARD_SUCCEEDED);
|
|
}
|
|
else if (service.icompare(CYS_DHCP_SERVICE_NAME) == 0)
|
|
{
|
|
// launch wrapper exe
|
|
|
|
resultText =
|
|
LaunchWrapperWizardExe(
|
|
String::format(
|
|
IDS_LAUNCH_DHCP_WIZARD_COMMAND_LINE,
|
|
Win::GetSystemDirectory().c_str()),
|
|
String(),
|
|
IDS_LAUNCH_DHCP_WIZARD_FAILED,
|
|
IDS_DHCP_WIZARD_FAILED,
|
|
IDS_DHCP_WIZARD_SUCCEEDED);
|
|
}
|
|
else if (service.icompare(CYS_RRAS_SERVICE_NAME) == 0)
|
|
{
|
|
// launch wrapper exe
|
|
|
|
resultText =
|
|
LaunchWrapperWizardExe(
|
|
String::format(
|
|
IDS_LAUNCH_RRAS_WIZARD_COMMAND_LINE,
|
|
Win::GetSystemDirectory().c_str()),
|
|
String(),
|
|
IDS_LAUNCH_RRAS_WIZARD_FAILED,
|
|
IDS_RRAS_WIZARD_FAILED,
|
|
IDS_RRAS_WIZARD_SUCCEEDED);
|
|
}
|
|
else if (service.icompare(CYS_RRAS_UNINSTALL) == 0)
|
|
{
|
|
// launch wrapper exe
|
|
|
|
resultText =
|
|
LaunchWrapperWizardExe(
|
|
String::format(
|
|
IDS_LAUNCH_RRAS_WIZARD_COMMAND_LINE,
|
|
Win::GetSystemDirectory().c_str()),
|
|
String(L"/u"),
|
|
IDS_LAUNCH_RRAS_WIZARD_FAILED,
|
|
IDS_RRAS_WIZARD_FAILED,
|
|
IDS_RRAS_WIZARD_SUCCEEDED);
|
|
}
|
|
else if (service.icompare(CYS_PRINTER_WIZARD_NAME) == 0)
|
|
{
|
|
resultText =
|
|
LaunchPrintWizardExe(
|
|
parent,
|
|
L"/il /Wr",
|
|
IDS_LAUNCH_PRINTER_WIZARD_FAILED,
|
|
IDS_PRINTER_WIZARD_FAILED,
|
|
IDS_EXECUTE_PRINTER_WIZARD_FAILED,
|
|
hr);
|
|
}
|
|
else if (service.icompare(CYS_PRINTER_DRIVER_WIZARD_NAME) == 0)
|
|
{
|
|
resultText =
|
|
LaunchPrintWizardExe(
|
|
parent,
|
|
L"/id /Wr",
|
|
IDS_LAUNCH_PRINTER_DRIVER_WIZARD_FAILED,
|
|
IDS_PRINTER_DRIVER_WIZARD_FAILED,
|
|
IDS_EXECUTE_PRINTER_DRIVER_WIZARD_FAILED,
|
|
hr);
|
|
}
|
|
else
|
|
{
|
|
LOG(String::format(
|
|
L"Unknown wizard name: %1",
|
|
service.c_str()));
|
|
ASSERT(FALSE);
|
|
result = false;
|
|
}
|
|
} while (false);
|
|
|
|
LOG(resultText);
|
|
LOG_HRESULT(hr);
|
|
LOG_BOOL(result);
|
|
return result;
|
|
}
|
|
|