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 dlamip::FileProfile
obiektu. -
ConsentDelegateImpl
implementujemip::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 ProfileObserver
parametrów ConsentDelegateImpl
i mip::FileProfile
moż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::Settings Parameters
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 klasymip::ConsentDelegate
. -
std::shared_ptr<mip::FileProfile::Observer> observer
: wskaźnik udostępniony do implementacji profiluObserver
(wPolicyProfile
systemach ,ProtectionProfile
iFileProfile
).
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ć FileProfile
element .
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::OnLoadSuccess
wywoł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.