Windows2003-3790/admin/snapin/dnsmgr/dnssnap.cpp
2020-09-30 16:53:55 +02:00

1322 lines
39 KiB
C++

// This is a part of the Microsoft Management Console.
// Copyright (C) Microsoft Corporation, 1995 - 1999
// All rights reserved.
//
// This source code is only intended as a supplement to the
// Microsoft Management Console and related
// electronic documentation provided with the interfaces.
// You will need the NT SUR Beta 2 SDK or VC 4.2 in order to build this
// project. This is because you will need MIDL 3.00.15 or higher and new
// headers and libs. If you have VC 4.2 installed, then everything should
// already be configured correctly.
#include "preDNSsn.h"
#include <SnapBase.h>
#include "resource.h"
#include "dnsutil.h"
#include "DNSSnap.h"
#include "snapdata.h"
#include "server.h"
#include "domain.h"
#include "record.h"
#include "zone.h"
#include "HelpArr.h" // context help ID's
// Version info
#include <ntverp.h>
#define IDS_SNAPIN_VERSION VER_PRODUCTVERSION_STR
#define IDS_SNAPIN_PROVIDER VER_COMPANYNAME_STR
#ifdef DEBUG_ALLOCATOR
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
#endif
//////////////////////////////////////////////////////////////////////////////
// regsvr debugging
// define to enable MsgBox debugging for regsvr32
//#define _MSGBOX_ON_REG_FAIL
#ifdef _MSGBOX_ON_REG_FAIL
#define _MSGBOX(x) AfxMessageBox(x)
#else
#define _MSGBOX(x)
#endif
#ifdef _MSGBOX_ON_REG_FAIL
#define _REPORT_FAIL(lpszMessage, lpszClsid, lRes) \
ReportFail(lpszMessage, lpszClsid, lRes)
void ReportFail(LPCWSTR lpszMessage, LPCWSTR lpszClsid, LONG lRes)
{
if (lRes == ERROR_SUCCESS)
return;
CString sz;
sz.Format(_T("%s %s %d"), lpszMessage,lpszClsid, lRes);
CThemeContextActivator activator;
AfxMessageBox(sz);
}
#else
#define _REPORT_FAIL(lpszMessage, lpszClsid, lRes)
#endif
//////////////////////////////////////////////////////////////////////////////
// global constants and macros
// GUIDs for snapin
const CLSID CLSID_DNSSnapin =
{ 0x2faebfa2, 0x3f1a, 0x11d0, { 0x8c, 0x65, 0x0, 0xc0, 0x4f, 0xd8, 0xfe, 0xcb } };
// {80105023-50B1-11d1-B930-00A0C9A06D2D}
const CLSID CLSID_DNSSnapinEx =
{ 0x80105023, 0x50b1, 0x11d1, { 0xb9, 0x30, 0x0, 0xa0, 0xc9, 0xa0, 0x6d, 0x2d } };
// {6C1303DC-BA00-11d1-B949-00A0C9A06D2D}
const CLSID CLSID_DNSSnapinAbout =
{ 0x6c1303dc, 0xba00, 0x11d1, { 0xb9, 0x49, 0x0, 0xa0, 0xc9, 0xa0, 0x6d, 0x2d } };
// {6C1303DD-BA00-11d1-B949-00A0C9A06D2D}
const CLSID CLSID_DNSSnapinAboutEx =
{ 0x6c1303dd, 0xba00, 0x11d1, { 0xb9, 0x49, 0x0, 0xa0, 0xc9, 0xa0, 0x6d, 0x2d } };
///////////////////////////////////////////////////////////////////////////////
// RESOURCES
BEGIN_MENU(CDNSRootDataMenuHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FILTER")
CTX_ENTRY_TOP(IDM_SNAPIN_CONNECT_TO_SERVER, L"_DNS_CONNECTTOP")
CTX_ENTRY_TASK(IDM_SNAPIN_CONNECT_TO_SERVER, L"_DNS_CONNECTTASK")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_FILTERING)
RES_ENTRY(IDS_SNAPIN_CONNECT_TO_SERVER)
RES_ENTRY(IDS_SNAPIN_CONNECT_TO_SERVER)
END_RES
END_MENU
BEGIN_MENU(CDNSServerMenuHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_MESSAGE, L"_DNS_MESSAGE")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FILTER")
CTX_ENTRY_TOP(IDM_SERVER_CONFIGURE, L"_DNS_CONFIGURETOP")
#ifdef USE_NDNC
CTX_ENTRY_TOP(IDM_SERVER_CREATE_NDNC, L"_DNS_CREATENDNC")
#endif
CTX_ENTRY_TOP(IDM_SERVER_NEW_ZONE, L"_DNS_ZONE")
CTX_ENTRY_TOP(IDM_SERVER_SET_AGING, L"_DNS_AGING")
CTX_ENTRY_TOP(IDM_SERVER_SCAVENGE, L"_DNS_SCAVENGETOP")
CTX_ENTRY_TOP(IDM_SERVER_UPDATE_DATA_FILES, L"_DNS_UPDATETOP")
CTX_ENTRY_TOP(IDM_SERVER_CLEAR_CACHE, L"_DNS_CLEARCACHETOP")
CTX_ENTRY_TOP(IDM_SERVER_NSLOOKUP, L"_DNS_NSLOOKUPTOP")
CTX_ENTRY_TASK(IDM_SERVER_CONFIGURE, L"_DNS_CONFIGURETASK")
CTX_ENTRY_TASK(IDM_SERVER_SCAVENGE, L"_DNS_SCAVENGETASK")
CTX_ENTRY_TASK(IDM_SERVER_UPDATE_DATA_FILES, L"_DNS_UPDATETASK")
CTX_ENTRY_TASK(IDM_SERVER_CLEAR_CACHE, L"_DNS_CLEARCACHETASK")
CTX_ENTRY_TASK(IDM_SERVER_NSLOOKUP, L"_DNS_NSLOOKUPTASK")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_MESSAGE)
RES_ENTRY(IDS_SNAPIN_FILTERING)
RES_ENTRY(IDS_SERVER_CONFIGURE)
#ifdef USE_NDNC
RES_ENTRY(IDS_SERVER_CREATE_NDNC)
#endif
RES_ENTRY(IDS_SERVER_NEW_ZONE)
RES_ENTRY(IDS_SERVER_SET_AGING)
RES_ENTRY(IDS_SERVER_SCAVENGE)
RES_ENTRY(IDS_SERVER_UPDATE_DATA_FILES)
RES_ENTRY(IDS_SERVER_CLEAR_CACHE)
RES_ENTRY(IDS_SERVER_NSLOOKUP)
RES_ENTRY(IDS_SERVER_CONFIGURE)
RES_ENTRY(IDS_SERVER_SCAVENGE)
RES_ENTRY(IDS_SERVER_UPDATE_DATA_FILES)
RES_ENTRY(IDS_SERVER_CLEAR_CACHE)
RES_ENTRY(IDS_SERVER_NSLOOKUP)
END_RES
END_MENU
BEGIN_MENU(CDNSCathegoryFolderHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FILTER")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_FILTERING)
END_RES
END_MENU
BEGIN_MENU(CDNSAuthoritatedZonesMenuHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FILTER")
CTX_ENTRY_TOP(IDM_SERVER_NEW_ZONE, L"_DNS_ZONETOP")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_FILTERING)
RES_ENTRY(IDS_SERVER_NEW_ZONE)
END_RES
END_MENU
BEGIN_MENU(CDNSCacheMenuHolder)
BEGIN_CTX
CTX_ENTRY_TOP(IDM_CACHE_FOLDER_CLEAR_CACHE, L"_DNS_CLEARCACHETOP")
CTX_ENTRY_TASK(IDM_CACHE_FOLDER_CLEAR_CACHE, L"_DNS_CLEARCACHETASK")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_CACHE_FOLDER_CLEAR_CACHE)
RES_ENTRY(IDS_CACHE_FOLDER_CLEAR_CACHE)
END_RES
END_MENU
BEGIN_MENU(CDNSZoneMenuHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FILTER")
CTX_ENTRY_TOP(IDM_ZONE_UPDATE_DATA_FILE, L"_DNS_UPDATETOP")
CTX_ENTRY_TOP(IDM_ZONE_RELOAD, L"_DNS_RELOADTOP")
CTX_ENTRY_TOP(IDM_ZONE_TRANSFER, L"_DNS_TRANSFERTOP")
CTX_ENTRY_TOP(IDM_ZONE_RELOAD_FROM_MASTER, L"_DNS_RELOADMASTERTOP")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_HOST, L"_DNS_NEWHOST")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_PTR, L"_DNS_NEWPTR")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_ALIAS, L"_DNS_NEWALIAS")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_MX, L"_DNS_NEWMX")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_DOMAIN, L"_DNS_NEWDOMAIN")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_DELEGATION, L"_DNS_NEWDELEGATION")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_RECORD, L"_DNS_NEWRECORD")
CTX_ENTRY_TASK(IDM_ZONE_UPDATE_DATA_FILE, L"_DNS_UPDATETASK")
CTX_ENTRY_TASK(IDM_ZONE_RELOAD, L"_DNS_RELOADTASK")
CTX_ENTRY_TASK(IDM_ZONE_TRANSFER, L"_DNS_TRANSFERTASK")
CTX_ENTRY_TASK(IDM_ZONE_RELOAD_FROM_MASTER, L"_DNS_RELOADMASTERTASK")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_FILTERING)
//RES_ENTRY(IDS_ZONE_PAUSE)
RES_ENTRY(IDS_ZONE_UPDATE_DATA_FILE)
RES_ENTRY(IDS_ZONE_RELOAD)
RES_ENTRY(IDS_ZONE_TRANSFER)
RES_ENTRY(IDS_ZONE_RELOAD_FROM_MASTER)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_HOST)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_PTR)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_ALIAS)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_MX)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_DOMAIN)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_DELEGATION)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_RECORD)
RES_ENTRY(IDS_ZONE_UPDATE_DATA_FILE)
RES_ENTRY(IDS_ZONE_RELOAD)
RES_ENTRY(IDS_ZONE_TRANSFER)
RES_ENTRY(IDS_ZONE_RELOAD_FROM_MASTER)
END_RES
END_MENU
BEGIN_MENU(CDNSDomainMenuHolder)
BEGIN_CTX
CTX_ENTRY_VIEW(IDM_SNAPIN_ADVANCED_VIEW, L"_DNS_ADVANCED")
CTX_ENTRY_VIEW(IDM_SNAPIN_FILTERING, L"_DNS_FITLER")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_HOST, L"_DNS_NEWHOST")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_PTR, L"_DNS_NEWPTR")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_ALIAS, L"_DNS_NEWALIAS")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_MX, L"_DNS_NEWMX")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_DOMAIN, L"_DNS_NEWDOMAIN")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_DELEGATION, L"_DNS_NEWDELEGATION")
CTX_ENTRY_TOP(IDM_DOMAIN_NEW_RECORD, L"_DNS_NEWRECORD")
END_CTX
BEGIN_RES
RES_ENTRY(IDS_SNAPIN_ADVANCED_VIEW)
RES_ENTRY(IDS_SNAPIN_FILTERING)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_HOST)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_PTR)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_ALIAS)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_MX)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_DOMAIN)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_DELEGATION)
RES_ENTRY(IDS_DOMAIN_NEW_NEW_RECORD)
END_RES
END_MENU
BEGIN_MENU(CDNSRecordMenuHolder)
BEGIN_CTX
END_CTX
BEGIN_RES
END_RES
END_MENU
// # of columns in the result pane and map for resource strings
extern RESULT_HEADERMAP _DefaultHeaderStrings[] =
{
{ L"", IDS_HEADER_NAME, LVCFMT_LEFT, 180},
{ L"", IDS_HEADER_TYPE, LVCFMT_LEFT, 150},
{ L"", IDS_HEADER_DATA, LVCFMT_LEFT, 160}
};
extern RESULT_HEADERMAP _ServerHeaderStrings[] =
{
{ L"", IDS_HEADER_NAME, LVCFMT_LEFT, 180},
};
extern RESULT_HEADERMAP _ZoneHeaderStrings[] =
{
{ L"", IDS_HEADER_NAME, LVCFMT_LEFT, 180},
{ L"", IDS_HEADER_TYPE, LVCFMT_LEFT, 90},
// { L"", IDS_HEADER_PARTITION, LVCFMT_LEFT, 100},
{ L"", IDS_HEADER_STATUS, LVCFMT_LEFT, 160}
};
#define N_ZONE_TYPES (7)
extern ZONE_TYPE_MAP _ZoneTypeStrings[] =
{
{ L"", IDS_ZONE_TYPE_AD_INTEGRATED },
{ L"", IDS_ZONE_TYPE_STANDARD_PRIMARY },
{ L"", IDS_ZONE_TYPE_SECONDARY },
{ L"", IDS_ZONE_TYPE_RUNNING },
{ L"", IDS_ZONE_TYPE_PAUSED },
{ L"", IDS_ZONE_TYPE_STUB },
{ L"", IDS_ZONE_TYPE_STUB_DS }
};
//
// Toolbar buttons
//
MMCBUTTON g_DNSMGR_SnapinButtons[] =
{
{ 0, toolbarNewServer, !TBSTATE_ENABLED, TBSTYLE_BUTTON, 0, 0 },
{ 1, toolbarNewRecord, !TBSTATE_ENABLED, TBSTYLE_BUTTON, 0, 0 },
{ 2, toolbarNewZone, !TBSTATE_ENABLED, TBSTYLE_BUTTON, 0, 0 }
};
//
// We have to maintain the memory for the toolbar button strings
// so this class holds the strings until it is time for them to be
// deleted
//
class CButtonStringsHolder
{
public:
CButtonStringsHolder()
{
m_astr = NULL;
}
~CButtonStringsHolder()
{
if (m_astr != NULL)
delete[] m_astr;
}
CString* m_astr; // dynamic array of CStrings
};
CButtonStringsHolder g_astrButtonStrings;
BOOL LoadZoneTypeResources(ZONE_TYPE_MAP* pHeaderMap, int nCols)
{
HINSTANCE hInstance = _Module.GetModuleInstance();
for ( int i = 0; i < nCols ; i++)
{
if ( 0 == ::LoadString(hInstance, pHeaderMap[i].uResID, pHeaderMap[i].szBuffer, MAX_RESULT_HEADER_STRLEN))
return TRUE;
}
return TRUE;
}
///////////////////////////////////////////////////////////////////////////////
// CDNSMgrModule
HRESULT WINAPI CDNSMgrModule::UpdateRegistryCLSID(const CLSID& clsid, BOOL bRegister)
{
static const WCHAR szIPS32[] = _T("InprocServer32");
static const WCHAR szCLSID[] = _T("CLSID");
HRESULT hRes = S_OK;
LPOLESTR lpOleStrCLSIDValue = NULL;
::StringFromCLSID(clsid, &lpOleStrCLSIDValue);
if (lpOleStrCLSIDValue == NULL)
{
return E_OUTOFMEMORY;
}
CRegKey key;
if (bRegister)
{
LONG lRes = key.Open(HKEY_CLASSES_ROOT, szCLSID);
_REPORT_FAIL(L"key.Open(HKEY_CLASSES_ROOT", lpOleStrCLSIDValue, lRes);
if (lRes == ERROR_SUCCESS)
{
lRes = key.Create(key, lpOleStrCLSIDValue);
_REPORT_FAIL(L"key.Create(key", lpOleStrCLSIDValue, lRes);
if (lRes == ERROR_SUCCESS)
{
DWORD bufferSizeInCharacters = MAX_PATH;
WCHAR* szModule = 0;
do
{
if (szModule)
{
delete[] szModule;
szModule = 0;
}
szModule = new WCHAR[bufferSizeInCharacters + 1];
if (szModule)
{
ZeroMemory(szModule, sizeof(WCHAR) * (bufferSizeInCharacters + 1));
DWORD result =
::GetModuleFileName(
m_hInst,
szModule,
bufferSizeInCharacters);
if (result < bufferSizeInCharacters)
{
break;
}
// truncation occurred, grow the buffer and try again
bufferSizeInCharacters *= 2;
}
else
{
break;
}
} while (bufferSizeInCharacters < USHRT_MAX);
if (szModule)
{
lRes = key.SetKeyValue(szIPS32, szModule);
_REPORT_FAIL(L"key.SetKeyValue(szIPS32", lpOleStrCLSIDValue, lRes);
delete[] szModule;
}
}
}
if (lRes != ERROR_SUCCESS)
{
hRes = HRESULT_FROM_WIN32(lRes);
}
}
else
{
key.Attach(HKEY_CLASSES_ROOT);
if (key.Open(key, szCLSID) == ERROR_SUCCESS)
key.RecurseDeleteKey(lpOleStrCLSIDValue);
}
::CoTaskMemFree(lpOleStrCLSIDValue);
return hRes;
}
///////////////////////////////////////////////////////////////////////////////
// Module, Object Map and DLL entry points
CDNSMgrModule _Module;
BEGIN_OBJECT_MAP(ObjectMap)
OBJECT_ENTRY(CLSID_DNSSnapin, CDNSComponentDataObject) // standalone snapin
OBJECT_ENTRY(CLSID_DNSSnapinEx, CDNSComponentDataObjectEx) // namespace extension
OBJECT_ENTRY(CLSID_DNSSnapinAbout, CDNSSnapinAbout) // standalone snapin about
OBJECT_ENTRY(CLSID_DNSSnapinAboutEx, CDNSSnapinAboutEx) // namespace extension about
END_OBJECT_MAP()
STDAPI DllCanUnloadNow(void)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
return (AfxDllCanUnloadNow()==S_OK && _Module.GetLockCount()==0) ? S_OK : S_FALSE;
}
STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv)
{
return _Module.GetClassObject(rclsid, riid, ppv);
}
static _NODE_TYPE_INFO_ENTRY _NodeTypeInfoEntryArray[] = {
{ &CDNSRootData::NodeTypeGUID, _T("Root DNS Snapin Subtree") },
{ &CDNSServerNode::NodeTypeGUID, _T("DNS Snapin Server Node") },
{ &CDNSZoneNode::NodeTypeGUID, _T("DNS Snapin Zone Node") },
{ &CDNSDomainNode::NodeTypeGUID, _T("DNS Snapin Domain Node") },
{ &CDNSRecordNodeBase::NodeTypeGUID, _T("DNS Snapin Record Node") },
{ NULL, NULL }
};
///////////////////////////////////////////////////////////////////////////
// external GUIDs (from Computer Management Snapin)
const CLSID CLSID_SystemServiceManagementExt =
{0x58221C6a,0xEA27,0x11CF,{0xAD,0xCF,0x00,0xAA,0x00,0xA8,0x00,0x33}};
const CLSID CLSID_NodeTypeServerApps =
{ 0x476e6449, 0xaaff, 0x11d0, { 0xb9, 0x44, 0x0, 0xc0, 0x4f, 0xd8, 0xd5, 0xb0 } };
const CLSID CLSID_EventViewerExt =
{ 0x394C052E, 0xB830, 0x11D0, { 0x9A, 0x86, 0x00, 0xC0, 0x4F, 0xD8, 0xDB, 0xF7 } };
////////////////////////////////////////////////////////////////////
// Server Applications Registration functions
const TCHAR DNS_KEY[] = TEXT("System\\CurrentControlSet\\Services\\DNS");
const TCHAR CONTROL_KEY[] = TEXT("System\\CurrentControlSet\\Control\\");
BOOL IsDNSServerInstalled()
{
CRegKey regkeyDNSService;
LONG lRes = regkeyDNSService.Open(HKEY_LOCAL_MACHINE, DNS_KEY);
return (lRes == ERROR_SUCCESS);
}
////////////////////////////////////////////////////////////////////
STDAPI DllRegisterServer(void)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
// registers all objects
HRESULT hr = _Module.RegisterServer(/* bRegTypeLib */ FALSE);
ASSERT(SUCCEEDED(hr));
if (FAILED(hr))
{
_MSGBOX(_T("_Module.RegisterServer() failed"));
return hr;
}
CString szVersion, szProvider, szSnapinName, szSnapinNameEx;
szVersion = IDS_SNAPIN_VERSION;
szProvider = IDS_SNAPIN_PROVIDER;
szSnapinName.LoadString(IDS_SNAPIN_NAME);
szSnapinNameEx.LoadString(IDS_SNAPIN_NAME_EX);
// register the standalone DNS snapin into the console snapin list
hr = RegisterSnapin(&CLSID_DNSSnapin,
&CDNSRootData::NodeTypeGUID,
&CLSID_DNSSnapinAbout,
szSnapinName, szVersion, szProvider,
FALSE /*bExtension*/,
_NodeTypeInfoEntryArray,
IDS_SNAPIN_NAME);
ASSERT(SUCCEEDED(hr));
if (FAILED(hr))
{
_MSGBOX(_T("RegisterSnapin(&CLSID_DNSSnapin) failed"));
return hr;
}
// register the extension DNS snapin into the console snapin list
hr = RegisterSnapin(&CLSID_DNSSnapinEx,
&CDNSRootData::NodeTypeGUID,
&CLSID_DNSSnapinAboutEx,
szSnapinNameEx, szVersion, szProvider,
TRUE /*bExtension*/,
_NodeTypeInfoEntryArray,
IDS_SNAPIN_NAME);
ASSERT(SUCCEEDED(hr));
if (FAILED(hr))
{
_MSGBOX(_T("RegisterSnapin(&CLSID_DNSSnapinEx) failed"));
return hr;
}
// register the snapin nodes into the console node list
for (_NODE_TYPE_INFO_ENTRY* pCurrEntry = _NodeTypeInfoEntryArray;
pCurrEntry->m_pNodeGUID != NULL; pCurrEntry++)
{
hr = RegisterNodeType(pCurrEntry->m_pNodeGUID,pCurrEntry->m_lpszNodeDescription);
ASSERT(SUCCEEDED(hr));
if (FAILED(hr))
{
_MSGBOX(_T("RegisterNodeType() failed"));
return hr;
}
}
// the Services Snapin will extend the Server Node (context menu to start/stop DNS)
//
// JonN 9/15/98: Removed the "dynamic" setting. I don't understand why this was
// being registered as a dynamic extension.
hr = RegisterNodeExtension(&CDNSServerNode::NodeTypeGUID, _T("ContextMenu"),
&CLSID_SystemServiceManagementExt,
_T("System Service Management Extension"), FALSE /*bDynamic*/);
if (FAILED(hr))
{
_MSGBOX(_T("RegisterNodeExtension(&CDNSServerNode::NodeTypeGUID) failed"));
return hr;
}
//
// Register the event viewer as a namespace extension of the server node
//
hr = RegisterNodeExtension(&CDNSServerNode::NodeTypeGUID, _T("NameSpace"),
&CLSID_EventViewerExt, _T("Event Viewer Extension"), FALSE);
if (FAILED(hr))
{
_MSGBOX(_T("RegisterNodeExtension(&CDNSServerNode::NodeTypeGUID) failed"));
return hr;
}
//
// the DNS Snapin will be a namespace extension for the Server Apps node
// in the Computer Management Snapin
//
//
// Fixed Bug 13620 DNSMGR: on workstation with AdminPak, dnsmgr.dll should not get loaded
//
OSVERSIONINFOEX verInfoEx;
verInfoEx.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX);
if (!::GetVersionEx((OSVERSIONINFO*)&verInfoEx) || verInfoEx.wProductType != VER_NT_WORKSTATION)
{
hr = RegisterNodeExtension(&CLSID_NodeTypeServerApps, _T("NameSpace"),
&CLSID_DNSSnapinEx, szSnapinNameEx, TRUE /*bDynamic*/);
if (FAILED(hr))
{
_MSGBOX(_T("RegisterNodeExtension(&CLSID_NodeTypeServerApps) failed"));
return hr;
}
}
return hr;
}
STDAPI DllUnregisterServer(void)
{
HRESULT hr = _Module.UnregisterServer();
ASSERT(SUCCEEDED(hr));
// un register the standalone snapin
hr = UnregisterSnapin(&CLSID_DNSSnapin);
ASSERT(SUCCEEDED(hr));
// un register the extension snapin
hr = UnregisterSnapin(&CLSID_DNSSnapinEx);
ASSERT(SUCCEEDED(hr));
// unregister the snapin nodes,
// this removes also the server node, with the Services Snapin extension keys
for (_NODE_TYPE_INFO_ENTRY* pCurrEntry = _NodeTypeInfoEntryArray;
pCurrEntry->m_pNodeGUID != NULL; pCurrEntry++)
{
hr = UnregisterNodeType(pCurrEntry->m_pNodeGUID);
ASSERT(SUCCEEDED(hr));
}
// the DNS Snapin will be a namespace extension for the Server Apps node
// in the Computer Management Snapin
hr = UnregisterNodeExtension(&CLSID_NodeTypeServerApps, _T("NameSpace"),
&CLSID_DNSSnapinEx, TRUE /*bDynamic*/);
ASSERT(SUCCEEDED(hr));
return S_OK;
}
///////////////////////////////////////////////////////////////////////////////
// CDNSSnapinApp
class CDNSSnapinApp : public CWinApp
{
public:
virtual BOOL InitInstance();
virtual int ExitInstance();
};
CDNSSnapinApp theApp;
BOOL CDNSSnapinApp::InitInstance()
{
_Module.Init(ObjectMap, m_hInstance);
// Add theming support
SHFusionInitializeFromModuleID(m_hInstance, 2);
// initialize font for Mask Control
WCHAR szFontName[LF_FACESIZE];
int nFontSize;
VERIFY(LoadFontInfoFromResource(IDS_MASK_CTRL_FONT_NAME,
IDS_MASK_CTRL_FONT_SIZE,
szFontName, LF_FACESIZE,
nFontSize,
L"MS Shell Dlg", 8 // default if something goes wrong
));
if (!DNS_ControlsInitialize(m_hInstance, szFontName, nFontSize))
return FALSE;
if (!CDNSComponentDataObject::LoadResources())
return FALSE;
return CWinApp::InitInstance();
}
int CDNSSnapinApp::ExitInstance()
{
#ifdef _DEBUG_REFCOUNT
TRACE(_T("CDNSSnapinApp::ExitInstance()\n"));
ASSERT(CComponentDataObject::m_nOustandingObjects == 0);
ASSERT(CComponentObject::m_nOustandingObjects == 0);
ASSERT(CDataObject::m_nOustandingObjects == 0);
#endif // _DEBUG_REFCOUNT
// Theming support
SHFusionUninitialize();
_Module.Term();
return CWinApp::ExitInstance();
}
////////////////////////////////////////////////////////////////////////
// CDNSComponentObject (.i.e "view")
HRESULT CDNSComponentObject::InitializeHeaders(CContainerNode* pContainerNode)
{
HRESULT hr = S_OK;
ASSERT(m_pHeader);
CColumnSet* pColumnSet = pContainerNode->GetColumnSet();
POSITION pos = pColumnSet->GetHeadPosition();
while (pos != NULL)
{
CColumn* pColumn = pColumnSet->GetNext(pos);
hr = m_pHeader->InsertColumn(pColumn->GetColumnNum(),
pColumn->GetHeader(),
pColumn->GetFormat(),
AUTO_WIDTH);
if (FAILED(hr))
return hr;
hr = m_pHeader->SetColumnWidth(pColumn->GetColumnNum(), pColumn->GetWidth());
if (FAILED(hr))
return hr;
}
return hr;
}
HRESULT CDNSComponentObject::InitializeBitmaps(CTreeNode*)
{
// image lists for nodes
CBitmapHolder<IDB_16x16> _bmp16x16;
CBitmapHolder<IDB_32x32> _bmp32x32;
HRESULT hr = S_OK;
BOOL bLoaded = _bmp16x16.LoadBitmap() && _bmp32x32.LoadBitmap();
if (bLoaded)
{
ASSERT(m_pImageResult != NULL);
hr = m_pImageResult->ImageListSetStrip(reinterpret_cast<LONG_PTR*>(static_cast<HBITMAP>(_bmp16x16)),
reinterpret_cast<LONG_PTR*>(static_cast<HBITMAP>(_bmp32x32)),
0, BMP_COLOR_MASK);
}
else
{
hr = S_FALSE;
}
return hr;
}
CONST INT cButtons = sizeof(g_DNSMGR_SnapinButtons)/sizeof(MMCBUTTON);
HRESULT CDNSComponentObject::InitializeToolbar(IToolbar* pToolbar)
{
ASSERT(pToolbar != NULL);
HRESULT hr = S_OK;
LoadToolbarStrings(g_DNSMGR_SnapinButtons);
CBitmapHolder<IDB_TOOLBAR_BUTTONS> _bmpToolbarButtons;
BOOL bLoaded = _bmpToolbarButtons.LoadBitmap();
if (bLoaded)
{
hr = m_pToolbar->AddBitmap(cButtons, (HBITMAP)_bmpToolbarButtons, 16, 16, RGB(255,0,255));
}
hr = m_pToolbar->AddButtons(cButtons, g_DNSMGR_SnapinButtons);
return hr;
}
HRESULT CDNSComponentObject::LoadToolbarStrings(MMCBUTTON * Buttons)
{
if (g_astrButtonStrings.m_astr == NULL )
{
//
// load strings
//
g_astrButtonStrings.m_astr = new CString[2*cButtons];
for (UINT i = 0; i < cButtons; i++)
{
UINT iButtonTextId = 0, iTooltipTextId = 0;
switch (Buttons[i].idCommand)
{
case toolbarNewServer:
iButtonTextId = IDS_BUTTON_NEW_SERVER;
iTooltipTextId = IDS_TOOLTIP_NEW_SERVER;
break;
case toolbarNewRecord:
iButtonTextId = IDS_BUTTON_NEW_RECORD;
iTooltipTextId = IDS_TOOLTIP_NEW_RECORD;
break;
case toolbarNewZone:
iButtonTextId = IDS_BUTTON_NEW_ZONE;
iTooltipTextId = IDS_TOOLTIP_NEW_ZONE;
break;
default:
ASSERT(FALSE);
break;
}
if (g_astrButtonStrings.m_astr)
{
g_astrButtonStrings.m_astr[i*2].LoadString(iButtonTextId);
Buttons[i].lpButtonText =
const_cast<BSTR>((LPCTSTR)(g_astrButtonStrings.m_astr[i*2]));
g_astrButtonStrings.m_astr[(i*2)+1].LoadString(iTooltipTextId);
Buttons[i].lpTooltipText =
const_cast<BSTR>((LPCTSTR)(g_astrButtonStrings.m_astr[(i*2)+1]));
}
}
}
return S_OK;
}
////////////////////////////////////////////////////////////////////////
// CDNSComponentDataObjectBase (.i.e "document")
CDNSComponentDataObjectBase::CDNSComponentDataObjectBase()
{
CWatermarkInfo* pWatermarkInfo = new CWatermarkInfo;
if (pWatermarkInfo)
{
pWatermarkInfo->m_nIDBanner = IDB_WIZBANNER;
pWatermarkInfo->m_nIDWatermark = IDB_WIZWATERMARK;
}
SetWatermarkInfo(pWatermarkInfo);
CDNSDefaultColumnSet* pDefaultCols =
new CDNSDefaultColumnSet(L"---Default Column Set---");
if (pDefaultCols)
{
m_columnSetList.AddTail(pDefaultCols);
}
CDNSServerColumnSet* pServerCols =
new CDNSServerColumnSet(L"---Server Column Set---");
if (pServerCols)
{
m_columnSetList.AddTail(pServerCols);
}
CDNSZoneColumnSet* pZoneCols =
new CDNSZoneColumnSet(L"---Zone Column Set---");
if (pZoneCols)
{
m_columnSetList.AddTail(pZoneCols);
}
SetLogFileName(L"dcpromodns");
}
HRESULT CDNSComponentDataObjectBase::OnSetImages(LPIMAGELIST lpScopeImage)
{
// image lists for nodes
CBitmapHolder<IDB_16x16> _bmp16x16;
CBitmapHolder<IDB_32x32> _bmp32x32;
BOOL bLoaded = _bmp16x16.LoadBitmap() && _bmp32x32.LoadBitmap();
HRESULT hr = S_OK;
if (bLoaded)
{
ASSERT(lpScopeImage != NULL);
hr = lpScopeImage->ImageListSetStrip(reinterpret_cast<LONG_PTR*>(static_cast<HBITMAP>(_bmp16x16)),
reinterpret_cast<LONG_PTR*>(static_cast<HBITMAP>(_bmp32x32)),
0, BMP_COLOR_MASK);
}
else
{
hr = S_FALSE;
}
return hr;
}
CRootData* CDNSComponentDataObjectBase::OnCreateRootData()
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
CString szSnapinType;
szSnapinType.LoadString(IDS_SNAPIN_NAME);
CDNSRootData* pDNSRootNode = new CDNSRootData(this);
if (pDNSRootNode)
{
pDNSRootNode->SetDisplayName(szSnapinType);
}
return pDNSRootNode;
}
BOOL CDNSComponentDataObjectBase::LoadResources()
{
return
LoadContextMenuResources(CDNSRootDataMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSServerMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSCathegoryFolderHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSAuthoritatedZonesMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSCacheMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSZoneMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSDomainMenuHolder::GetMenuMap()) &&
LoadContextMenuResources(CDNSRecordMenuHolder::GetMenuMap()) &&
LoadResultHeaderResources(_DefaultHeaderStrings,N_DEFAULT_HEADER_COLS) &&
LoadResultHeaderResources(_ServerHeaderStrings,N_SERVER_HEADER_COLS) &&
LoadResultHeaderResources(_ZoneHeaderStrings,N_ZONE_HEADER_COLS) &&
LoadZoneTypeResources(_ZoneTypeStrings, N_ZONE_TYPES) &&
CDNSRecordInfo::LoadResources();
}
STDMETHODIMP CDNSComponentDataObjectBase::CreateComponent(LPCOMPONENT* ppComponent)
{
ASSERT(ppComponent != NULL);
CComObject<CDNSComponentObject>* pObject;
CComObject<CDNSComponentObject>::CreateInstance(&pObject);
ASSERT(pObject != NULL);
// Store IComponentData
pObject->SetIComponentData(this);
return pObject->QueryInterface(IID_IComponent,
reinterpret_cast<void**>(ppComponent));
}
void CDNSComponentDataObjectBase::OnTimer()
{
CDNSRootData* pDNSRootData = (CDNSRootData*)GetRootData();
pDNSRootData->TestServers(m_dwTimerTime, GetTimerInterval(), this);
m_dwTimerTime += GetTimerInterval();
}
void CDNSComponentDataObjectBase::OnTimerThread(WPARAM wParam, LPARAM lParam)
{
CDNSRootData* pDNSRootData = (CDNSRootData*)GetRootData();
pDNSRootData->OnServerTestData(wParam,lParam, this);
}
CTimerThread* CDNSComponentDataObjectBase::OnCreateTimerThread()
{
return new CDNSServerTestTimerThread;
}
void CDNSComponentDataObjectBase::OnNodeContextHelp(CNodeList* pNodeList)
{
ASSERT(pNodeList);
if (pNodeList)
{
ASSERT(pNodeList->GetCount() > 0);
OnNodeContextHelp(pNodeList->GetHead());
}
}
void CDNSComponentDataObjectBase::OnNodeContextHelp(CTreeNode* /*pNode*/)
{
CComPtr<IDisplayHelp> spHelp;
HRESULT hr = GetConsole()->QueryInterface(IID_IDisplayHelp, (void **)&spHelp);
if (SUCCEEDED(hr))
spHelp->ShowTopic(L"DNSconcepts.chm::/sag_DNStopnode.htm");
/*
CString szNode;
if (IS_CLASS(*pNode, CDNSRootData))
{
szNode = _T("Root Node");
}
else if (IS_CLASS(*pNode, CDNSServerNode))
{
szNode = _T("Server Node");
}
else if (IS_CLASS(*pNode, CDNSForwardZonesNode))
{
szNode = _T("Forward Zones Node");
}
else if (IS_CLASS(*pNode, CDNSReverseZonesNode))
{
szNode = _T("Reverse Zones Node");
}
else if (IS_CLASS(*pNode, CDNSZoneNode))
{
szNode = _T("Zone Node");
}
else if (IS_CLASS(*pNode, CDNSDomainNode))
{
szNode = _T("Domain Node");
}
else if (IS_CLASS(*pNode, CDNSCacheNode))
{
szNode = _T("Domain Node");
}
else if (dynamic_cast<CDNSRecordNodeBase*>(pNode) != NULL)
{
szNode = _T("Record Node");
}
if (!szNode.IsEmpty())
{
CString szMsg = _T("Context Help on ");
szMsg += szNode;
AFX_MANAGE_STATE(AfxGetStaticModuleState());
CThemeContextActivator activator;
AfxMessageBox(szMsg);
}
*/
}
LPCWSTR g_szContextHelpFileName = L"\\help\\dnsmgr.hlp";
LPCWSTR g_szHTMLHelpFileName = L"\\help\\dnsmgr.chm";
LPCWSTR CDNSComponentDataObjectBase::GetHTMLHelpFileName()
{
return g_szHTMLHelpFileName;
}
void CDNSComponentDataObjectBase::OnDialogContextHelp(UINT nDialogID, HELPINFO* pHelpInfo)
{
ULONG nContextTopic;
if (FindDialogContextTopic(nDialogID, pHelpInfo, &nContextTopic))
WinHelp(g_szContextHelpFileName, HELP_CONTEXTPOPUP, nContextTopic);
}
////////////////////////////////////////////////////////////////////////////////
// help context macros and maps
#define BEGIN_HELP_MAP(map) static DWORD_PTR map[] = {
#define HELP_MAP_ENTRY(x) x, (DWORD_PTR)&g_aHelpIDs_##x ,
#define END_HELP_MAP 0, 0 };
#define NEXT_HELP_MAP_ENTRY(p) ((p)+2)
#define MAP_ENTRY_DLG_ID(p) (*p)
#define MAP_ENTRY_TABLE(p) ((DWORD*)(*(p+1)))
#define IS_LAST_MAP_ENTRY(p) (MAP_ENTRY_DLG_ID(p) == 0)
#define NEXT_HELP_TABLE_ENTRY(p) ((p)+2)
#define TABLE_ENTRY_CTRL_ID(p) (*p)
#define TABLE_ENTRY_HELP_ID(p) (*(p+1))
#define IS_LAST_TABLE_ENTRY(p) (TABLE_ENTRY_CTRL_ID(p) == 0)
BEGIN_HELP_MAP(_DNSMgrContextHelpMap)
// misc dialogs
HELP_MAP_ENTRY(IDD_CHOOSER_CHOOSE_MACHINE)
HELP_MAP_ENTRY(IDD_BROWSE_DIALOG)
HELP_MAP_ENTRY(IDD_FILTERING_LIMITS)
HELP_MAP_ENTRY(IDD_FILTERING_NAME)
// misc. add dialogs
HELP_MAP_ENTRY(IDD_DOMAIN_ADDNEWHOST) // TODO
HELP_MAP_ENTRY(IDD_DOMAIN_ADDNEWDOMAIN)// TODO
HELP_MAP_ENTRY(IDD_SELECT_RECORD_TYPE_DIALOG)
// name servers page, there are more than one
HELP_MAP_ENTRY(IDD_NAME_SERVERS_PAGE)
HELP_MAP_ENTRY(IDD_COPY_ROOTHINTS_DIALOG)
// server property pages
HELP_MAP_ENTRY(IDD_SERVER_INTERFACES_PAGE)
HELP_MAP_ENTRY(IDD_SERVER_DOMAIN_FORWARDERS_PAGE)
HELP_MAP_ENTRY(IDD_SERVER_NEW_DOMAIN_FORWARDER)
HELP_MAP_ENTRY(IDD_SERVER_ADVANCED_PAGE)
HELP_MAP_ENTRY(IDD_SERVER_DEBUG_LOGGING_PAGE)
HELP_MAP_ENTRY(IDD_IP_FILTER_DIALOG)
HELP_MAP_ENTRY(IDD_SERVER_EVENT_LOGGING_PAGE)
HELP_MAP_ENTRY(IDD_SERVMON_TEST_PAGE)
HELP_MAP_ENTRY(IDD_SERVER_AGING_DIALOG)
// zone property pages
#ifdef USE_NDNC
HELP_MAP_ENTRY(IDD_ZONE_GENERAL_PAGE_NDNC)
HELP_MAP_ENTRY(IDD_ZONE_GENERAL_CHANGE_REPLICATION)
#else
HELP_MAP_ENTRY(IDD_ZONE_GENERAL_PAGE)
#endif // USE_NDNC
HELP_MAP_ENTRY(IDD_ZONE_GENERAL_CHANGE_TYPE)
HELP_MAP_ENTRY(IDD_ZONE_WINS_PAGE)
HELP_MAP_ENTRY(IDD_ZONE_NBSTAT_PAGE)
HELP_MAP_ENTRY(IDD_ZONE_ZONE_TRANSFER_PAGE)
HELP_MAP_ENTRY(IDD_ZONE_WINS_ADVANCED) // this is a subdialog
HELP_MAP_ENTRY(IDD_ZONE_NOTIFY_SUBDIALOG) // this is a subdialog
HELP_MAP_ENTRY(IDD_ZONE_AGING_DIALOG)
// record property pages
HELP_MAP_ENTRY(IDD_RR_NS_EDIT)
HELP_MAP_ENTRY(IDD_RR_SOA)
HELP_MAP_ENTRY(IDD_RR_A)
HELP_MAP_ENTRY(IDD_RR_ATMA)
HELP_MAP_ENTRY(IDD_RR_CNAME)
HELP_MAP_ENTRY(IDD_RR_MX)
HELP_MAP_ENTRY(IDD_RR_UNK)
HELP_MAP_ENTRY(IDD_RR_TXT)
HELP_MAP_ENTRY(IDD_RR_X25)
HELP_MAP_ENTRY(IDD_RR_ISDN)
HELP_MAP_ENTRY(IDD_RR_HINFO)
HELP_MAP_ENTRY(IDD_RR_AAAA)
HELP_MAP_ENTRY(IDD_RR_MB)
HELP_MAP_ENTRY(IDD_RR_MG)
HELP_MAP_ENTRY(IDD_RR_MD)
HELP_MAP_ENTRY(IDD_RR_MF)
HELP_MAP_ENTRY(IDD_RR_MR)
HELP_MAP_ENTRY(IDD_RR_MINFO)
HELP_MAP_ENTRY(IDD_RR_RP)
HELP_MAP_ENTRY(IDD_RR_RT)
HELP_MAP_ENTRY(IDD_RR_AFSDB)
HELP_MAP_ENTRY(IDD_RR_WKS)
HELP_MAP_ENTRY(IDD_RR_PTR)
HELP_MAP_ENTRY(IDD_RR_SRV)
HELP_MAP_ENTRY(IDD_RR_KEY)
HELP_MAP_ENTRY(IDD_RR_SIG)
HELP_MAP_ENTRY(IDD_RR_NXT)
END_HELP_MAP
BOOL CDNSComponentDataObjectBase::FindDialogContextTopic(/*IN*/UINT nDialogID,
/*IN*/ HELPINFO* pHelpInfo,
/*OUT*/ ULONG* pnContextTopic)
{
ASSERT(pHelpInfo != NULL);
*pnContextTopic = 0;
const DWORD_PTR* pMapEntry = _DNSMgrContextHelpMap;
while (!IS_LAST_MAP_ENTRY(pMapEntry))
{
if (nDialogID == MAP_ENTRY_DLG_ID(pMapEntry))
{
DWORD* pTable = MAP_ENTRY_TABLE(pMapEntry);
// look inside the table
while (!IS_LAST_TABLE_ENTRY(pTable))
{
if (TABLE_ENTRY_CTRL_ID(pTable) == static_cast<UINT>(pHelpInfo->iCtrlId))
{
*pnContextTopic = TABLE_ENTRY_HELP_ID(pTable);
return TRUE;
}
pTable = NEXT_HELP_TABLE_ENTRY(pTable);
}
}
pMapEntry = NEXT_HELP_MAP_ENTRY(pMapEntry);
}
return FALSE;
}
////////////////////////////////////////////////////////////////////////
// CDNSComponentDataObjectEx (.i.e "document")
// extension snapin
unsigned int g_CFMachineName =
RegisterClipboardFormat(L"MMC_SNAPIN_MACHINE_NAME");
LPWSTR ExtractMachineName(LPDATAOBJECT lpDataObject)
{
ASSERT(lpDataObject != NULL);
STGMEDIUM stgmedium = { TYMED_HGLOBAL, NULL };
FORMATETC formatetc = { (CLIPFORMAT)g_CFMachineName, NULL,
DVASPECT_CONTENT, -1, TYMED_HGLOBAL
};
// Allocate memory for the stream
stgmedium.hGlobal = GlobalAlloc(GMEM_SHARE, 512);
LPWSTR pwszMachineName = NULL;
// Attempt to get data from the object
do
{
if (stgmedium.hGlobal == NULL)
break;
if (FAILED(lpDataObject->GetDataHere(&formatetc, &stgmedium)))
break;
pwszMachineName = reinterpret_cast<LPWSTR>(stgmedium.hGlobal);
if (pwszMachineName == NULL)
break;
} while (FALSE);
return pwszMachineName;
}
HRESULT CDNSComponentDataObjectEx::OnExtensionExpand(LPDATAOBJECT lpDataObject, LPARAM param)
{
// this is a namespace extension, need to add
// the root of the snapin
AFX_MANAGE_STATE(AfxGetStaticModuleState());
// NOTICE: the name of the root node is already set in the constructor
// insert the root node in the console
CDNSRootData* pDNSRootNode = (CDNSRootData*)GetRootData();
HSCOPEITEM pParent = param;
pDNSRootNode->SetScopeID(pParent);
HRESULT hr = AddContainerNode(pDNSRootNode, pParent);
if (FAILED(hr))
return hr;
BOOL bLocalHost = FALSE;
if (!pDNSRootNode->IsEnumerated())
{
// get information from the data object
LPWSTR pwszMachineName = ExtractMachineName(lpDataObject);
if ( (pwszMachineName == NULL) || (pwszMachineName[0] == NULL) )
{
if (pwszMachineName != NULL)
::GlobalFree((void*)pwszMachineName);
DWORD dwCharLen = MAX_COMPUTERNAME_LENGTH+1;
pwszMachineName = (LPWSTR)GlobalAlloc(GMEM_SHARE, sizeof(WCHAR)*dwCharLen);
if (pwszMachineName)
{
BOOL bRes = ::GetComputerName(pwszMachineName, &dwCharLen);
ASSERT(dwCharLen <= MAX_COMPUTERNAME_LENGTH);
if (!bRes)
{
wcscpy(pwszMachineName, _T("localhost."));
}
bLocalHost = TRUE;
}
}
// add a new server node with the server name from the data object
CDNSServerNode* pDNSServerNode = new CDNSServerNode(pwszMachineName, bLocalHost);
FREE_INTERNAL((void*)pwszMachineName);
if (pDNSServerNode)
{
VERIFY(pDNSRootNode->AddChildToList(pDNSServerNode));
pDNSRootNode->AddServerToThreadList(pDNSServerNode, this);
}
pDNSRootNode->MarkEnumerated();
}
return hr;
}
HRESULT CDNSComponentDataObjectEx::OnRemoveChildren(LPDATAOBJECT, LPARAM)
{
ASSERT(IsExtensionSnapin());
CDNSRootData* pDNSRootNode = (CDNSRootData*)GetRootData();
CNodeList* pChildList = pDNSRootNode->GetContainerChildList();
ASSERT(pChildList != NULL);
// loop through thelist of servers and remove them from
// the test list
for(POSITION pos = pChildList->GetHeadPosition(); pos != NULL; )
{
CDNSServerNode* pCurrServerNode = (CDNSServerNode*)pChildList->GetNext(pos);
ASSERT(pCurrServerNode != NULL);
pDNSRootNode->RemoveServerFromThreadList(pCurrServerNode, this);
}
// detach all the threads that might be still running
GetRunningThreadTable()->RemoveAll();
// shut down property sheets, if any
GetPropertyPageHolderTable()->WaitForAllToShutDown();
// remove all the children of the root from chaild list
pDNSRootNode->RemoveAllChildrenFromList();
pDNSRootNode->MarkEnumerated(FALSE);
return S_OK;
}
//////////////////////////////////////////////////////////////////////////
// CDNSSnapinAbout
CDNSSnapinAbout::CDNSSnapinAbout()
{
m_szProvider = IDS_SNAPIN_PROVIDER;
m_szVersion = IDS_SNAPIN_VERSION;
m_uIdStrDestription = IDS_SNAPINABOUT_DESCRIPTION;
m_uIdIconImage = IDI_DNS_SNAPIN;
m_uIdBitmapSmallImage = IDB_ABOUT_16x16;
m_uIdBitmapSmallImageOpen = IDB_ABOUT_OPEN_16x16;
m_uIdBitmapLargeImage = IDB_ABOUT_32x32;
m_crImageMask = BMP_COLOR_MASK;
}
//////////////////////////////////////////////////////////////////////////
// CDNSSnapinAboutEx
CDNSSnapinAboutEx::CDNSSnapinAboutEx()
{
m_szProvider = IDS_SNAPIN_PROVIDER;
m_szVersion = IDS_SNAPIN_VERSION;
m_uIdStrDestription = IDS_SNAPINABOUT_DESCRIPTION;
m_uIdIconImage = IDI_DNS_SNAPIN;
m_uIdBitmapSmallImage = IDB_16x16;
m_uIdBitmapSmallImageOpen = IDB_16x16;
m_uIdBitmapLargeImage = IDB_32x32;
m_crImageMask = BMP_COLOR_MASK;
}