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>
: Omip::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 classemip::ConsentDelegate
.std::shared_ptr<mip::ProtectionProfile::Observer> observer
: Um ponteiro compartilhado para a implementação do perfilObserver
(emPolicyProfile
,ProtectionProfile
eFileProfile
).
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::OnLoadSuccess
nossa 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.