Partilhar via


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;
}