Microsoft Information Protection SDK — koncepcje profilów zestawu SDK ochrony

Dwa poniższe przykłady pokazują, jak utworzyć obiekt profileSettings przy użyciu magazynu lokalnego na przykład do przechowywania informacji o stanie oraz tylko w pamięci.

Ładowanie profilu

Teraz, ProtectionProfileObserverImpl gdy jest zdefiniowany, użyjemy jej do wystąpienia mip::ProtectionProfile . Do utworzenia mip::ProtectionProfile obiektu jest wymagany mip::ProtectionProfile::Settings .

ProtectionProfile::Ustawienia Parameters

  • std::shared_ptr<MipContext>: mip::MipContext Obiekt, który został zainicjowany w celu przechowywania informacji o aplikacji, ścieżka województwa itp.
  • mip::CacheStorageType: Definiuje sposób przechowywania stanu: W pamięci, na dysku lub na dysku i zaszyfrowany.
  • std::shared_ptr<mip::ConsentDelegate>: Udostępniony wskaźnik zajęć mip::ConsentDelegate .
  • std::shared_ptr<mip::ProtectionProfile::Observer> observer: Udostępniony wskaźnik implementacji Observer profilu (w PolicyProfile , i ProtectionProfileFileProfile ).

Dwa poniższe przykłady pokazują, jak utworzyć obiekt profileSettings przy użyciu magazynu lokalnego na przykład do przechowywania informacji o stanie oraz tylko w pamięci.

Stan przechowywania tylko w pamięci

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

Ustawienia profilu odczytu/zapisu ze ścieżki magazynu na dysku

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

Następnie załaduj przycisk . ProtectionProfile

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

Jeśli załadowano profil i ta operacja się powiedzie, to ProtectionProfileObserverImpl::OnLoadSuccess nasza implementacja mip::ProtectionProfile::Observer::OnLoadSuccess jest nazywana. Wynikowy obiekt lub wskaźnik wyjątku, a także kontekst, są przekazywane jako parametry do funkcji. Kontekst jest wskaźnikiem utworzonym do obsługi std::promise operacji synchronizacji. Funkcja po prostu ustawia wartość obietnicy obiektu ProtectionProfile (kontekst). Gdy funkcja główna używa Future.get() , wynik może być przechowywany w nowym obiekcie.

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

Umieszczanie go na nim

Po pełnym wdrożeniu użytkowników i pełnomocnika uwierzytelniania można teraz całkowicie załadować profil. W poniższej wycinka kodu założono, że wszystkie niezbędne nagłówki są już uwzględnione.

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();
}

Wynikiem jest to, że pomyślnie załadowaliśmy profil i przechowywano go w obiekcie o nazwie profile .

Następne kroki

Po dodaniu profilu następnym krokiem jest dodanie aparatu do profilu.

Koncepcje aparatu ochrony