Microsoft Information Protection SDK — pojęcia dotyczące profilu zestawu SDK plików

Profil jest klasą główną dla wszystkich operacji w zestawie MIP SDK. Przed użyciem dowolnej funkcji zestawu SDK plików należy utworzyć obiekt , a FileProfile wszystkie przyszłe operacje zostaną wykonane przez profil lub przez inne obiekty dodane do profilu.

Istnieje kilka wymagań wstępnych dotyczących kodu, które należy spełnić przed podjęciem próby utworzenia wystąpienia profilu:

  • MipContext został utworzony i przechowywany w obiekcie dostępnym dla mip::FileProfile obiektu.
  • ConsentDelegateImpl implementuje mip::ConsentDelegate.
  • Aplikacja została zarejestrowana w identyfikatorze Entra firmy Microsoft, a identyfikator klienta jest zakodowany w plikach aplikacji lub konfiguracji.
  • Klasa dziedzicząca mip::FileProfile::Observer została odpowiednio zaimplementowana.

Ładowanie profilu

Po zdefiniowaniu mip::FileProfile parametrów ProfileObserveri ConsentDelegateImplmożna teraz utworzyć wystąpienie wystąpienia. mip::FileProfile Utworzenie obiektu wymaga , aby element [mip::MipContext] miał i mip::FileProfile::Settings przechowywał wszystkie informacje o ustawieniach obiektu FileProfile.

FileProfile::Ustawienia Parametry

Konstruktor FileProfile::Settings akceptuje pięć parametrów wymienionych poniżej:

  • 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.
  • std::shared_ptr<mip::ConsentDelegate>: współużytkowany wskaźnik klasy mip::ConsentDelegate.
  • std::shared_ptr<mip::FileProfile::Observer> observer: wskaźnik udostępniony do implementacji profilu Observer (w PolicyProfilesystemach , ProtectionProfilei FileProfile).

W poniższych przykładach pokazano, jak utworzyć profileSettings obiekt 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);

FileProfile::Settings profileSettings(
    mMipContext,                                  // mipContext object
    mip::CacheStorageType::InMemory,              // use in memory storage
    std::make_shared<ConsentDelegateImpl>(),      // new consent delegate
    std::make_shared<FileProfileObserverImpl>()); // new protection profile observer

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

Poniższy fragment kodu spowoduje, że polecenie spowoduje zapisanie FileProfile wszystkich danych stanu aplikacji w programie ./mip_app_data.

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

FileProfile::Settings profileSettings(
    mMipContext,                                   // mipContext object
    mip::CacheStorageType::OnDisk,                 // use on disk storage    
    std::make_shared<ConsentDelegateImpl>(),       // new consent delegate
    std::make_shared<FileProfileObserverImpl>());  // new protection profile observer

Ładowanie profilu

Korzystając z powyższych szczegółów podejścia, użyj teraz wzorca obietnicy/przyszłości, aby załadować FileProfileelement .

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

Jeśli załadowaliśmy profil i operacja zakończyła się pomyślnie, ProfileObserver::OnLoadSuccesswywoływana jest nasza implementacja mip::FileProfile::Observer::OnLoadSuccess . Wynikowy obiekt lub wskaźnik wyjątku, a także kontekst, są przekazywane jako parametry do funkcji. Kontekst jest wskaźnikiem utworzonym std::promise w celu obsługi operacji asynchronicznych. Funkcja po prostu ustawia wartość obietnicy dla obiektu FileProfile, który został przekazany dla pierwszego parametru. Gdy funkcja main używa Future.get()metody , wynik może być przechowywany w nowym obiekcie.

//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@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);

    FileProfile::Settings profileSettings(
        mMipContext,                                   // MipContext object
        mip::CacheStorageType::OnDisk,                 // use on disk storage        
        std::make_shared<ConsentDelegateImpl>(),       // new consent delegate
        std::make_shared<FileProfileObserverImpl>());  // new file profile observer

        auto profilePromise = std::make_shared<promise<shared_ptr<FileProfile>>>();
        auto profileFuture = profilePromise->get_future();
        FileProfile::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.