Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Následující dva příklady ukazují, jak vytvořit objekt profileSettings pomocí místního úložiště pro úložiště stavu a pouze v paměti.
Načíst profil
Teď, když je definovaný ProtectionProfileObserverImpl , použijeme ho k vytvoření instance mip::ProtectionProfile. Vytvoření objektu mip::ProtectionProfile vyžaduje mip::ProtectionProfile::Settings.
Parametry ProtectionProfile::Nastavení
-
std::shared_ptr<MipContext>: Objektmip::MipContextinicializovaný k uložení informací o aplikaci, stavové cesty atd. -
mip::CacheStorageType: Definuje, jak uložit stav: V paměti, na disku nebo na disku a zašifrováno. -
std::shared_ptr<mip::ConsentDelegate>: Sdílený ukazatel třídymip::ConsentDelegate. -
std::shared_ptr<mip::ProtectionProfile::Observer> observer: Sdílený ukazatel na implementaci profiluObserver(vPolicyProfile,ProtectionProfileaFileProfile).
Následující dva příklady ukazují, jak vytvořit objekt profileSettings pomocí místního úložiště pro úložiště stavu a pouze v paměti.
Uložení stavu pouze v paměti
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
Čtení a zápis nastavení profilu z úložné cesty na disku
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
Dále použijte vzor promise/future k načtení ProtectionProfile.
auto profilePromise = std::make_shared<std::promise<std::shared_ptr<ProtectionProfile>>>();
auto profileFuture = profilePromise->get_future();
ProtectionProfile::LoadAsync(profileSettings, profilePromise);
Pokud jsme načetli profil a tato operace byla úspěšná, ProtectionProfileObserverImpl::OnLoadSuccess se volá naše implementace mip::ProtectionProfile::Observer::OnLoadSuccess. Výsledný objekt nebo ukazatel výjimky a kontext se předá funkci jako parametry. Kontext je ukazatel na std::promise, který jsme vytvořili pro zpracování asynchronní operace. Funkce jednoduše nastaví hodnotu příslibu na objekt ProtectionProfile (kontext). Pokud hlavní funkce použije Future.get(), výsledek může být uložen v novém objektu.
//get the future value and store in profile.
auto profile = profileFuture.get();
Dát dohromady
Když jste plně implementovali pozorovatele a delegáta ověřování, je teď možné plně načíst profil. Následující výnič kódu předpokládá, že jsou už zahrnuté všechny nezbytné hlavičky.
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();
}
Konečný výsledek je, že jsme úspěšně načetli profil a uložili do objektu s názvem profile.
Další kroky
Nyní, když byl profil přidán, je dalším krokem přidání enginu do profilu.