Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

165 lines
4.5 KiB

// Copyright (c) 2000 Microsoft Corp.
//
// launches dns wizard from the dhcp snapin using mmc automation
#include "headers.hxx"
#include "resource.h"
#include "smartptr.hpp"
#include "misc.hpp"
//
// This is the language independent menu ID of the Configure a DNS Wizard
//
#define DNS_CONFIGE_WIZARD_MENU_ID L"_DNS_CONFIGURETOP"
HINSTANCE hResourceModuleHandle = 0;
HRESULT
getContextMenu(const SmartInterface<View>& view, ContextMenu** dumbMenu)
{
HRESULT hr = S_OK;
_variant_t missingParam2(DISP_E_PARAMNOTFOUND, VT_ERROR);
hr = view->get_ScopeNodeContextMenu(missingParam2, dumbMenu);
return hr;
}
HRESULT
doIt()
{
HRESULT hr = S_OK;
SmartInterface<Document> doc(0);
do
{
hr = ::CoInitialize(0);
BREAK_ON_FAILED_HRESULT(hr, L"CoInitialize failed.");
SmartInterface<_Application> app(0);
hr =
app.AcquireViaCreateInstance(
CLSID_Application,
0,
// we expect the object is out-of-proc, local server, but
// we really don't care, so we'll take any implementation
// available.
CLSCTX_ALL);
BREAK_ON_FAILED_HRESULT(hr, L"CoCreateInstance failed.");
Document* dumbDoc = 0;
hr = app->get_Document(&dumbDoc);
BREAK_ON_FAILED_HRESULT(hr, L"get_Document failed.");
doc.Acquire(dumbDoc);
SmartInterface<SnapIns> snapIns(0);
SnapIns* dumbSnapIns = 0;
hr = doc->get_SnapIns(&dumbSnapIns);
BREAK_ON_FAILED_HRESULT(hr, L"get_SnapIns failed.");
snapIns.Acquire(dumbSnapIns);
static const wchar_t* DNS_SNAPIN_CLSID =
L"{2FAEBFA2-3F1A-11D0-8C65-00C04FD8FECB}";
SmartInterface<SnapIn> snapIn(0);
SnapIn* dumbSnapIn = 0;
_variant_t missingParam(DISP_E_PARAMNOTFOUND, VT_ERROR);
_variant_t missingParam2(DISP_E_PARAMNOTFOUND, VT_ERROR);
hr =
snapIns->Add(AutoBstr(DNS_SNAPIN_CLSID), missingParam, missingParam2, &dumbSnapIn);
BREAK_ON_FAILED_HRESULT(hr, L"SnapIns::Add failed. Is DNS installed?");
snapIn.Acquire(dumbSnapIn);
SmartInterface<Views> views(0);
Views* dumbViews = 0;
hr = doc->get_Views(&dumbViews);
BREAK_ON_FAILED_HRESULT(hr, L"get_Views failed.");
views.Acquire(dumbViews);
SmartInterface<View> view(0);
View* dumbView = 0;
hr = views->Item(1, &dumbView);
BREAK_ON_FAILED_HRESULT(hr, L"Views::Item failed.");
view.Acquire(dumbView);
// navigate thru the scope node namespace to find the node
// for the computer
SmartInterface<ScopeNamespace> sn(0);
ScopeNamespace* dumbSn = 0;
hr = doc->get_ScopeNamespace(&dumbSn);
BREAK_ON_FAILED_HRESULT(hr, L"get_ScopeNamespace failed.");
sn.Acquire(dumbSn);
SmartInterface<Node> rootnode(0);
Node* dumbNode = 0;
hr = sn->GetRoot(&dumbNode);
BREAK_ON_FAILED_HRESULT(hr, L"GetRoot failed.");
rootnode.Acquire(dumbNode);
SmartInterface<Node> child1(0);
hr = sn->GetChild(rootnode, &dumbNode);
BREAK_ON_FAILED_HRESULT(hr, L"GetChild failed.");
child1.Acquire(dumbNode);
hr = view->put_ActiveScopeNode(child1);
BREAK_ON_FAILED_HRESULT(hr, L"put_ActiveScopeNode failed.");
// have to read back the child node we just put...
hr = view->get_ActiveScopeNode(&dumbNode);
BREAK_ON_FAILED_HRESULT(hr, L"GetActiveScopeNode failed.");
child1 = dumbNode;
dumbNode->Release();
dumbNode = 0;
SmartInterface<Node> child2(0);
hr = sn->GetChild(child1, &dumbNode);
BREAK_ON_FAILED_HRESULT(hr, L"GetChild failed.");
child2.Acquire(dumbNode);
hr = view->put_ActiveScopeNode(child2);
BREAK_ON_FAILED_HRESULT(hr, L"put_ActiveScopeNode failed.");
_variant_t missingParam3(DISP_E_PARAMNOTFOUND, VT_ERROR);
hr =
view->ExecuteScopeNodeMenuItem(
AutoBstr(DNS_CONFIGE_WIZARD_MENU_ID),
missingParam3);
BREAK_ON_FAILED_HRESULT(
hr,
L"ExecuteScopeNodeMenuItem " DNS_CONFIGE_WIZARD_MENU_ID L" failed");
}
while (0);
// don't save the console file.
if (doc)
{
doc->Close(FALSE);
}
return hr;
}
int WINAPI
WinMain(
HINSTANCE hInstance,
HINSTANCE /* hPrevInstance */ ,
LPSTR /* lpszCmdLine */ ,
int /* nCmdShow */ )
{
hResourceModuleHandle = hInstance;
int exitCode = static_cast<int>(doIt());
return exitCode;
}