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

292 lines
6.4 KiB
C++

// Copyright (c) 2001 Microsoft Corporation
//
// File: NetbiosPage.cpp
//
// Synopsis: Defines the new netbios name page used in the
// Express path for the CYS Wizard
//
// History: 02/08/2001 JeffJon Created
#include "pch.h"
#include "resource.h"
#include "InstallationUnitProvider.h"
#include "NetbiosPage.h"
static PCWSTR NETBIOS_PAGE_HELP = L"cys.chm::/typical_setup.htm#typicalnetbios";
NetbiosDomainPage::NetbiosDomainPage()
:
CYSWizardPage(
IDD_NETBIOS_NAME,
IDS_NETBIOS_NAME_TITLE,
IDS_NETBIOS_NAME_SUBTITLE,
NETBIOS_PAGE_HELP)
{
LOG_CTOR(NetbiosDomainPage);
}
NetbiosDomainPage::~NetbiosDomainPage()
{
LOG_DTOR(NetbiosDomainPage);
}
void
NetbiosDomainPage::OnInit()
{
LOG_FUNCTION(NetbiosDomainPage::OnInit);
CYSWizardPage::OnInit();
Win::Edit_LimitText(
Win::GetDlgItem(hwnd, IDC_NETBIOS),
MAX_NETBIOS_NAME_LENGTH);
}
static
void
enable(HWND dialog)
{
ASSERT(Win::IsWindow(dialog));
int next =
!Win::GetTrimmedDlgItemText(dialog, IDC_NETBIOS).empty()
? PSWIZB_NEXT : 0;
Win::PropSheet_SetWizButtons(
Win::GetParent(dialog),
PSWIZB_BACK | next);
}
HRESULT
MyDsRoleDnsNameToFlatName(
const String& domainDNSName,
String& result,
bool& nameWasTweaked)
{
LOG_FUNCTION(MyDsRoleDnsNameToFlatName);
ASSERT(!domainDNSName.empty());
nameWasTweaked = false;
result.erase();
LOG(L"Calling DsRoleDnsNameToFlatName");
LOG( L"lpServer : (null)");
LOG(String::format(L"lpDnsName : %1", domainDNSName.c_str()));
PWSTR flatName = 0;
ULONG flags = 0;
HRESULT hr =
Win32ToHresult(
::DsRoleDnsNameToFlatName(
0, // this server
domainDNSName.c_str(),
&flatName,
&flags));
LOG_HRESULT(hr);
if (SUCCEEDED(hr) && flatName)
{
LOG(String::format(L"lpFlatName : %1", flatName));
LOG(String::format(L"lpStatusFlag : %1!X!", flags));
result = flatName;
if (result.length() > DNLEN)
{
result.resize(DNLEN);
}
::DsRoleFreeMemory(flatName);
// the name was tweaked if it is not the default. 338443
nameWasTweaked = !(flags & DSROLE_FLATNAME_DEFAULT);
}
return hr;
}
// return true if the name generated has already been validated, false
// if not.
bool
GenerateDefaultNetbiosName(HWND parent)
{
LOG_FUNCTION(GenerateDefaultNetbiosName);
ASSERT(Win::IsWindow(parent));
Win::CursorSetting cursor(IDC_WAIT);
bool result = false;
String dnsDomainName =
InstallationUnitProvider::GetInstance().GetADInstallationUnit().GetNewDomainDNSName();
bool nameWasTweaked = false;
String generatedName;
HRESULT hr =
MyDsRoleDnsNameToFlatName(
dnsDomainName,
generatedName,
nameWasTweaked);
if (FAILED(hr))
{
// if the api call failed, the name could not have been validated.
result = false;
// fall back to just the first 15 characters of the first label
generatedName =
dnsDomainName.substr(0, min(DNLEN, dnsDomainName.find(L'.')));
LOG(String::format(L"falling back to %1", generatedName.c_str()));
}
else
{
// the api validated the name for us.
result = true;
}
generatedName.to_upper();
if (generatedName.is_numeric())
{
// the generated name is all-numeric. This is not allowed. So we
// toss it out. 368777 bis
generatedName.erase();
nameWasTweaked = false;
}
Win::SetDlgItemText(
parent,
IDC_NETBIOS,
generatedName);
// inform the user that the default NetBIOS name was adjusted due
// to name collision on the network
if (nameWasTweaked)
{
popup.Info(
parent,
String::format(
IDS_GENERATED_NAME_WAS_TWEAKED,
generatedName.c_str()));
}
return result;
}
bool
NetbiosDomainPage::OnSetActive()
{
LOG_FUNCTION(NetbiosDomainPage::OnSetActive);
Win::PropSheet_SetWizButtons(
Win::GetParent(hwnd),
PSWIZB_BACK);
String dnsDomainName =
InstallationUnitProvider::GetInstance().GetADInstallationUnit().GetNewDomainDNSName();
Win::SetDlgItemText(
hwnd,
IDC_DOMAIN_DNS_EDIT,
dnsDomainName);
// do this here instead of in init to regenerate a default name if the
// user has not annointed one already.
if (InstallationUnitProvider::GetInstance().GetADInstallationUnit().GetNewDomainNetbiosName().empty())
{
GenerateDefaultNetbiosName(hwnd);
}
enable(hwnd);
return true;
}
bool
NetbiosDomainPage::OnCommand(
HWND /* windowFrom */ ,
unsigned controlIDFrom,
unsigned code)
{
// LOG_FUNCTION(NetbiosDomainPage::OnCommand);
switch (controlIDFrom)
{
case IDC_NETBIOS:
{
if (code == EN_CHANGE)
{
SetChanged(controlIDFrom);
enable(hwnd);
}
break;
}
default:
{
// do nothing
break;
}
}
return false;
}
int
NetbiosDomainPage::Validate()
{
LOG_FUNCTION(NetbiosDomainPage::Validate);
int nextPage = IDD_MILESTONE_PAGE;
if (!ValidateDomainNetbiosName(hwnd, IDC_NETBIOS, popup))
{
nextPage = -1;
}
else
{
String netbiosName = Win::GetTrimmedDlgItemText(hwnd, IDC_NETBIOS);
InstallationUnitProvider::GetInstance().GetADInstallationUnit().SetNewDomainNetbiosName(netbiosName);
// If there is more than one NIC we need to offer the user routing
// and firewall. This also ensures we can distinguish between
// the public and private NICs
if (State::GetInstance().GetNICCount() > 1)
{
InstallationUnitProvider::GetInstance().
GetRRASInstallationUnit().SetExpressPathValues(true);
}
// Check to see if there are any DNS servers configured
// on any of the interfaces. If there are then we will just
// use those. If not we will ask the user to provide them
// using the DNS Forwarders page.
if (!State::GetInstance().HasDNSServerOnAnyNicToForwardTo())
{
nextPage = IDD_DNS_FORWARDER_PAGE;
}
}
return nextPage;
}