Sdílet prostřednictvím


Microsoft Information Protection SDK – Koncepty profilů sady SDK ochrany

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čtení profilu

Teď, když je definovaný ProtectionProfileObserverImpl , použijeme ho k vytvoření instance mip::ProtectionProfile. Vytvoření objektu mip::ProtectionProfile vyžaduje mip::ProtectionProfile::Settings.

ProtectionProfile::Settings Parameters

  • std::shared_ptr<MipContext>: Objekt mip::MipContext inicializovaný k uložení informací o aplikaci, cesty stavu 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řídy mip::ConsentDelegate.
  • std::shared_ptr<mip::ProtectionProfile::Observer> observer: Sdílený ukazatel na implementaci profilu Observer (v PolicyProfileProtectionProfile, a FileProfile).

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

Nastavení profilu čtení a zápisu z cesty k úložišti 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

V dalším kroku použijte k načtení vzorce příslibu ProtectionProfilea budoucnosti .

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::OnLoadSuccessvolá se 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 vytvořenou std::promise 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();

Seskupování

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

Po přidání profilu je dalším krokem přidání modulu do profilu.

Koncepty modulu ochrany