Invocando assistentes de criação de seu aplicativo
Um aplicativo ou componente pode usar os mesmos assistentes de criação de objeto de serviço de diretório usados pelos snap-ins do MMC administrativo do Active Directory. Isso é feito com a interface IDsAdminCreateObj.
Usando a interface IDsAdminCreateObj
Um aplicativo ou componente (cliente) cria uma instância da interface IDsAdminCreateObj chamando CoCreateInstance com o identificador de classe CLSID_DsAdminCreateObj. COM deve ser inicializado chamando CoInitialize antes de CoCreateInstance é chamado.
Em seguida, o cliente chama IDsAdminCreateObj::Initialize para inicializar o objeto IDsAdminCreateObj. IDsAdminCreateObj::Initialize aceita um ponteiro de interface IADsContainer que representa o contêiner no qual o objeto deve ser criado e o nome da classe do objeto a ser criado. Ao criar objetos de usuário, também é possível especificar um objeto existente que será copiado para o novo objeto.
Quando o objeto IDsAdminCreateObj tiver sido inicializado, o cliente chamará IDsAdminCreateObj::CreateModal para exibir o assistente de criação de objeto.
Ao contrário da maioria dos identificadores de classe e interface, CLSID_DsAdminCreateObj e IID_ADsAdminCreateObj não são definidos em um arquivo de biblioteca. Isso significa que você deve definir o armazenamento para esses identificadores em seu aplicativo. Para fazer isso, você deve incluir o arquivo initguid.h imediatamente antes de incluir dsadmin.h. O arquivo initguid.h só deve ser incluído uma vez em um aplicativo. O exemplo de código a seguir mostra como incluir esses arquivos.
#include <initguid.h>
#include <dsadmin.h>
O exemplo de código a seguir mostra como a interface IDsAdminCreateObj pode ser criada e usada para iniciar o assistente de criação de objeto para um objeto de usuário.
// 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;
}