Вызов мастеров создания из приложения
Приложение или компонент может использовать те же мастера создания объектов службы каталогов, которые используются оснастками MMC администратора Active Directory. Это достигается с помощью интерфейса ID Администратор CreateObj.
Использование идентификаторов Администратор CreateObj Interface
Приложение или компонент (клиент) создает экземпляр интерфейса идентификаторов Администратор CreateObj путем вызова CoCreateInstance с идентификатором класса CLSID_DsАдминистратор CreateObj. COM необходимо инициализировать путем вызова CoInitialize перед вызовом CoCreateInstance.
Затем клиент вызывает идентификаторы Администратор CreateObj::Initialize для инициализации идентификаторов Администратор CreateObj. Идентификаторы Администратор CreateObj::Initialize принимает указатель интерфейса IADsContainer, представляющий контейнер, в который должен быть создан объект, и имя класса создаваемого объекта. При создании пользовательских объектов также можно указать существующий объект, который будет скопирован в новый объект.
Когда идентификаторы Администратор CreateObj-объект инициализирован, клиент вызывает идентификаторы Администратор CreateObj::CreateModal для отображения мастера создания объектов.
В отличие от большинства идентификаторов классов и интерфейсов, CLSID_DsАдминистратор CreateObj и IID_ADsАдминистратор CreateObj не определены в файле библиотеки. Это означает, что необходимо определить хранилище для этих идентификаторов в приложении. Для этого необходимо включить файл initguid.h непосредственно перед включением dsadmin.h. Файл initguid.h должен быть включен только один раз в приложение. В следующем примере кода показано, как включить эти файлы.
#include <initguid.h>
#include <dsadmin.h>
В следующем примере кода показано, как можно создать интерфейс ID Администратор CreateObj и использовать его для запуска мастера создания объектов для пользовательского объекта.
// Add activeds.lib to your project
// Add adsiid.lib to your project
#include "stdafx.h"
#include <atlbase.h>
#include <atlstr.h>
#include "activeds.h"
#include <initguid.h> // Only include this in one source file
#include <dsadmin.h>
// GetUserContainer() function binds to the user container
IADsContainer* GetUserContainer(void)
{
IADsContainer *pUsers = NULL;
HRESULT hr;
IADs *pRoot;
// Bind to the rootDSE.
hr = ADsGetObject(L"LDAP://rootDSE", IID_IADs, (LPVOID*)&pRoot);
if(SUCCEEDED(hr))
{
VARIANT var;
VariantInit(&var);
CComBSTR sbstr(L"defaultNamingContext");
// Get the default naming context (domain) DN.
hr = pRoot->Get(sbstr, &var);
if(SUCCEEDED(hr) && (VT_BSTR == var.vt))
{
CStringW sstr(L"LDAP://CN=Users,");
sstr += var.bstrVal;
// Bind to the User container.
hr = ADsGetObject(sstr, IID_IADsContainer, (LPVOID*)&pUsers);
VariantClear(&var);
}
}
return pUsers;
}
// The LaunchNewUserWizard() function launches the user wizard.
HRESULT LaunchNewUserWizard(IADs** ppAdsOut)
{
if(NULL == ppAdsOut)
{
return E_INVALIDARG;
}
HRESULT hr;
IDsAdminCreateObj* pCreateObj = NULL;
hr = ::CoCreateInstance(CLSID_DsAdminCreateObj,
NULL,
CLSCTX_INPROC_SERVER,
IID_IDsAdminCreateObj,
(void**)&pCreateObj);
if(SUCCEEDED(hr))
{
IADsContainer *pContainer;
pContainer = GetUserContainer();
if(pContainer)
{
hr = pCreateObj->Initialize(pContainer, NULL, L"user");
if(SUCCEEDED(hr))
{
HWND hwndParent;
hwndParent = GetDesktopWindow();
hr = pCreateObj->CreateModal(hwndParent, ppAdsOut);
}
pContainer->Release();
}
pCreateObj->Release();
}
return hr;
}
// Entry point to the application
int main(void)
{
HRESULT hr;
IADs *pAds = NULL;
CoInitialize(NULL);
hr = LaunchNewUserWizard(&pAds);
if((S_OK == hr) && (NULL != pAds))
{
pAds->Release();
}
CoUninitialize();
return 0;
}