Udostępnij za pośrednictwem


Zestaw SDK usługi Microsoft Information Protection — pojęcia dotyczące profilu zestawu SDK zasad

Przed mip::Profile wykonaniem jakichkolwiek operacji zestawu SDK zasad należy je załadować.

W dwóch poniższych przykładach pokazano, jak utworzyć obiekt profileSettings przy użyciu magazynu lokalnego dla magazynu stanu, a także tylko w pamięci.

Ładowanie profilu

Teraz, gdy wartości MipContext i ProfileObserver są zdefiniowane, użyjemy ich do utworzenia wystąpienia mip::PolicyProfileelementu . mip::PolicyProfile Utworzenie obiektu wymaga mip::PolicyProfile::Settings elementów i mip::MipContext.

Profile::Settings Parameters

Konstruktor PolicyProfile::Settings akceptuje cztery parametry wymienione poniżej:

  • const std::shared_ptr<MipContext> mip::MipContext: obiekt, który został zainicjowany do przechowywania informacji o aplikacji, ścieżki stanu itp.
  • mip::CacheStorageType: definiuje sposób przechowywania stanu: w pamięci, na dysku lub na dysku i zaszyfrowane. Aby uzyskać więcej informacji, zobacz Pojęcia dotyczące magazynu pamięci podręcznej.
  • std::shared_ptr<mip::PolicyProfile::Observer> observer: wskaźnik udostępniony do implementacji profilu Observer (w PolicyProfilesystemach , ProtectionProfilei FileProfile).

W dwóch poniższych przykładach pokazano, jak utworzyć obiekt profileSettings przy użyciu magazynu lokalnego dla magazynu stanu, a także tylko w pamięci.

Przechowywanie stanu 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);

PolicyProfile::Settings profileSettings(
    mMipContext,                                  // mipContext object
    mip::CacheStorageType::InMemory,              // use in memory storage
    std::make_shared<PolicyProfileObserverImpl>()); // 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);

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

Następnie użyj wzorca promise/future, aby załadować Profileelement .

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

Jeśli profil został pomyślnie załadowany, ProfileObserver::OnLoadSuccessnasza implementacja mip::Profile::Observer::OnLoadSuccess jest powiadamiana. Wynikowy obiekt, w tym przypadku mip::Profile, a także kontekst, są przekazywane jako parametry do funkcji obserwatora.

Kontekst jest wskaźnikiem utworzonym std::promise w celu obsługi operacji asynchronicznych. Funkcja po prostu ustawia wartość obietnicy dla obiektu Profile, który został przekazany dla pierwszego parametru. Gdy funkcja main używa Future.get()metody , wynik może być przechowywany w nowym obiekcie w wątku wywołującym.

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

Łączenie go

Po pełnym zaimplementowaniu obserwatorów i delegata uwierzytelniania można teraz w pełni załadować profil. Poniższy fragment kodu zakłada, że wszystkie niezbędne nagłówki są już uwzględnione.

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

Wynik końcowy oznacza, że pomyślnie załadowaliśmy profil i zapisano go w obiekcie o nazwie profile.

Następne kroki

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

Pojęcia dotyczące aparatu zasad