Compartilhar via


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

O mip::Profile deve ser carregado para que uma operação do SDK de política possa ser executada.

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

Carregar um perfil

Agora que MipContext e ProfileObserver estão definidos, vamos usá-los para instanciar mip::PolicyProfile. A criação do objeto mip::PolicyProfile exige mip::PolicyProfile::Settings e mip::MipContext.

Perfil::parâmetros de configurações

O construtor PolicyProfile::Settings aceita quatro parâmetros, listados abaixo:

  • const std::shared_ptr<MipContext>: o objeto mip::MipContext 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. Para obter mais detalhes, consulte os conceitos de armazenamento em cache.
  • std::shared_ptr<mip::PolicyProfile::Observer> observer: um ponteiro compartilhado para a implementação do perfil Observer (em PolicyProfile, ProtectionProfile e FileProfile).

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

Armazenar estado somente 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);

PolicyProfile::Settings profileSettings(
    mMipContext,                                  // mipContext object
    mip::CacheStorageType::InMemory,              // use in memory storage
    std::make_shared<PolicyProfileObserverImpl>()); // new protection profile observer

Configurações de perfil de leitura/gravação do caminho de armazenamento em 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);

PolicyProfile::Settings profileSettings(
    mipContext,                                    // mipContext object
    mip::CacheStorageType::OnDisk,                 // use on disk storage
    std::make_shared<PolicyProfileObserverImpl>());  // new protection profile observer

Em seguida, use o padrão promessa/futuro para carregar o Profile.

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

Se um perfil for carregado com sucesso, ProfileObserver::OnLoadSuccess, nossa implementação de mip::Profile::Observer::OnLoadSuccess será notificada. O objeto resultante, nesse caso um mip::Profile, bem como o contexto são transmitidos como parâmetros para a função de observador.

O contexto é um ponteiro para o std::promise que criamos para manipular a operação assíncrona. A função simplesmente define o valor da promessa para o objeto perfil que foi transmitido para o primeiro parâmetro. Quando a função principal usa Future.get(), o resultado pode ser armazenado em um novo objeto no threading de chamada.

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

Juntar as peças

Tendo implementado totalmente os observadores e o representante de autenticação, agora é possível carregar totalmente um perfil. A captura do código abaixo presume que todos os cabeçalhos necessários já estejam incluídos.

int main()
{
    const string userName = "MyTestUser@consoto.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);

    PolicyProfile::Settings profileSettings(
        mMipContext,                                    // mipContext object
        mip::CacheStorageType::OnDisk,                 // use on disk storage
        std::make_shared<PolicyProfileObserverImpl>());  // new protection profile observer

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

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

Próximas etapas

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

Conceitos do mecanismo de política