Partilhar via


SDK da Proteção de Informações da Microsoft - Conceitos de perfil do SDK de Proteção

Os dois exemplos abaixo mostram como criar o objeto profileSettings usando armazenamento local para armazenamento de estado, bem como somente na memória.

Carregar um perfil

Agora que o ProtectionProfileObserverImpl está definido, vamos usá-lo para instanciar mip::ProtectionProfile. A criação do mip::ProtectionProfile objeto requer mip::ProtectionProfile::Settings.

ProtectionProfile::Parâmetros de configurações

  • std::shared_ptr<MipContext>: O mip::MipContext objeto que foi inicializado para armazenar informações do aplicativo, caminho de estado, etc.
  • mip::CacheStorageType: Define como armazenar o estado: Na memória, no disco ou no disco e criptografado.
  • std::shared_ptr<mip::ConsentDelegate>: Um ponteiro compartilhado da classe mip::ConsentDelegate.
  • std::shared_ptr<mip::ProtectionProfile::Observer> observer: Um ponteiro compartilhado para a implementação do perfil Observer (em PolicyProfile, ProtectionProfilee FileProfile).

Os dois exemplos abaixo mostram como criar o objeto profileSettings usando armazenamento local para armazenamento de estado, bem como somente na memória.

Armazenar estado apenas na memória

mip::ApplicationInfo appInfo {clientId, "APP NAME", "1.2.3" };

std::shared_ptr<mip::MipConfiguration> mipConfiguration = std::make_shared<mip::MipConfiguration>(mAppInfo,
				                                                                                  "mip_data",
                                                                                        		  mip::LogLevel::Trace,
                                                                                                  false);

std::shared_ptr<mip::MipContext> mMipContext = mip::MipContext::Create(mipConfiguration);

ProtectionProfile::Settings profileSettings(
    mMipContext,                                        // mipContext object
    mip::CacheStorageType::InMemory,                   // use in memory storage    
    std::make_shared<ConsentDelegateImpl>(),           // new consent delegate
    std::make_shared<ProtectionProfileObserverImpl>()); // new protection profile observer

Configurações de perfil de leitura/gravação do caminho de armazenamento no disco

mip::ApplicationInfo appInfo {clientId, "APP NAME", "1.2.3" };

std::shared_ptr<mip::MipConfiguration> mipConfiguration = std::make_shared<mip::MipConfiguration>(mAppInfo,
    		                                                                                       "mip_data",
                                                                                       			   mip::LogLevel::Trace,
                                                                                                   false);

std::shared_ptr<mip::MipContext> mMipContext = mip::MipContext::Create(mipConfiguration);

ProtectionProfile::Settings profileSettings(
    mMipContext,                                         // mipContext object
    mip::CacheStorageType::OnDisk,                      // use on disk storage    
    std::make_shared<ConsentDelegateImpl>(),            // new consent delegate
    std::make_shared<ProtectionProfileObserverImpl>()); // new protection profile

Em seguida, use o padrão promise/future para carregar o ProtectionProfile.

auto profilePromise = std::make_shared<std::promise<std::shared_ptr<ProtectionProfile>>>();
auto profileFuture = profilePromise->get_future();
ProtectionProfile::LoadAsync(profileSettings, profilePromise);

Se carregamos um perfil e essa operação foi bem-sucedida, ProtectionProfileObserverImpl::OnLoadSuccessnossa implementação é mip::ProtectionProfile::Observer::OnLoadSuccess chamada. O objeto resultante ou ponteiro de exceção, bem como o contexto, são passados como parâmetros para a função. O contexto é um ponteiro para o std::promise que criamos para lidar com a operação assíncrona. A função simplesmente define o valor da promessa para o objeto ProtectionProfile (contexto). Quando a função principal usa Future.get(), o resultado pode ser armazenado em um novo objeto.

//get the future value and store in profile.
auto profile = profileFuture.get();

Juntando

Tendo implementado totalmente os observadores e o delegado de autenticação, agora é possível carregar totalmente um perfil. O trecho de código abaixo assume que todos os cabeçalhos necessários já estão incluídos.

int main()
{
    const string userName = "MyTestUser@contoso.com";
    const string password = "P@ssw0rd!";
    const string clientId = "MyClientId";

    mip::ApplicationInfo appInfo {clientId, "APP NAME", "1.2.3" };

    std::shared_ptr<mip::MipConfiguration> mipConfiguration = std::make_shared<mip::MipConfiguration>(mAppInfo,
				                                                                                       "mip_data",
                                                                                        			   mip::LogLevel::Trace,
                                                                                                       false);

    std::shared_ptr<mip::MipContext> mMipContext = mip::MipContext::Create(mipConfiguration);

    ProtectionProfile::Settings profileSettings(
        mMipContext,                                    // mipContext object
        mip::CacheStorageType::OnDisk,                 // use on disk storage        
        std::make_shared<ConsentDelegateImpl>(),       // new consent delegate
        std::make_shared<ProfileObserver>());          // new protection profile observer

    auto profilePromise = std::make_shared<promise<shared_ptr<ProtectionProfile>>>();
    auto profileFuture = profilePromise->get_future();
    ProtectionProfile::LoadAsync(profileSettings, profilePromise);
    auto profile = profileFuture.get();
}

O resultado final é que carregamos com êxito o perfil e armazenamos no objeto chamado profile.

Passos Seguintes

Agora que o perfil foi adicionado, a próxima etapa é adicionar um mecanismo ao perfil.

Conceitos do motor de proteção