Microsoft Information Protection SDK - Waarnemers voor bestands-SDK
De Bestands-SDK bevat twee waarnemersklassen. Waarnemerleden zijn virtueel en kunnen worden overschreven om callbacks van gebeurtenissen af te handelen.
Wanneer een asynchrone bewerking is voltooid, wordt de OnXxx()
lidfunctie die overeenkomt met het resultaat aangeroepen. Voorbeelden zijn OnLoadSuccess()
, OnLoadFailure()
en OnAddEngineSuccess()
voor mip::FileProfile::Observer
.
In de onderstaande voorbeelden ziet u het promise/future-patroon, dat ook wordt gebruikt door de SDK-voorbeelden en kan worden uitgebreid om het gewenste callbackgedrag te implementeren.
Implementatie van waarnemersbestandsprofiel
In het volgende voorbeeld hebben we een klasse gemaakt die ProfileObserver
is afgeleid van mip::FileProfile::Observer
. De lidfuncties zijn overschreven voor het gebruik van het toekomstige/beloftepatroon dat in de voorbeelden wordt gebruikt.
Opmerking: de onderstaande voorbeelden zijn slechts gedeeltelijk geïmplementeerd en bevatten geen onderdrukkingen voor de mip::FileEngine
gerelateerde waarnemers.
profile_observer.h
In de koptekst definiëren ProfileObserver
we, afgeleid van mip::FileProfile::Observer
, en overschrijven we vervolgens elk van de lidfuncties.
class ProfileObserver final : public mip::FileProfile::Observer {
public:
ProfileObserver() { }
void OnLoadSuccess(const std::shared_ptr<mip::FileProfile>& profile, const std::shared_ptr<void>& context) override;
void OnLoadFailure(const std::exception_ptr& error, const std::shared_ptr<void>& context) override;
//TODO: Implement mip::FileEngine related observers.
};
profile_observer.cpp
In de implementatie zelf definiëren we een actie die moet worden uitgevoerd voor elke waarnemersfunctie.
Elk lid accepteert twee parameters. De eerste is een gedeelde aanwijzer naar de klasse die we in de functie verwerken. ProfileObserver::OnLoadSuccess
zou verwachten dat een mip::FileProfile
. ProfileObserver::OnAddEngineSuccess
zou verwachten mip::FileEngine
.
De tweede is een gedeelde aanwijzer naar de context. In onze implementatie is de context een verwijzing naar een std::promise
, doorgegeven door verwijzing als std::shared_ptr<void>
. De eerste regel van de functie cast dit naar std::promise
en vervolgens opgeslagen in een object met de naam promise
.
Ten slotte wordt de toekomst gereed gemaakt door het promise->set_value()
object in te stellen en door te mip::FileProfile
geven.
#include "profile_observer.h"
#include <future>
//Called when FileProfile is successfully loaded
void ProfileObserver::OnLoadSuccess(const std::shared_ptr<mip::FileProfile>& profile, const std::shared_ptr<void>& context) {
//cast context to promise
auto promise =
std::static_pointer_cast<std::promise<std::shared_ptr<mip::FileProfile>>>(context);
//set promise value to profile
promise->set_value(profile);
}
//Called when FileProfile fails to load
void ProfileObserver::OnLoadFailure(const std::exception_ptr& error, const std::shared_ptr<void>& context) {
auto promise = std::static_pointer_cast<std::promise<std::shared_ptr<mip::FileProfile>>>(context);
promise->set_exception(error);
}
//TODO: Implement mip::FileEngine related observers.
Wanneer we een SDK-klasse instantiëren of een functie gebruiken die asynchrone bewerkingen uitvoert, geven we de waarnemers-implementatie door aan de instellingenconstructor of asynchrone functie zelf. Bij het instantiëren van het mip::FileProfile::Settings
object neemt de constructor deel mip::FileProfile::Observer
aan als een van de parameters. In het onderstaande voorbeeld ziet u onze aangepaste ProfileObserver
, die wordt gebruikt in een mip::FileProfile::Settings
constructor.
Implementatie van FileHandler-waarnemer
Net als bij de waarnemer van het profiel implementeert de mip::FileHandler
klasse voor mip::FileHandler::Observers
het verwerken van asynchrone gebeurtenismeldingen tijdens bestandsbewerkingen. De implementatie is vergelijkbaar met die hierboven beschreven. FileHandlerObserver
is gedeeltelijk gedefinieerd hieronder.
file_handler_observer.h
#include "mip/file/file_handler.h"
class FileHandlerObserver final : public mip::FileHandler::Observer {
public:
void OnCreateFileHandlerSuccess(
const std::shared_ptr<mip::FileHandler>& fileHandler,
const std::shared_ptr<void>& context) override;
void OnCreateFileHandlerFailure(
const std::exception_ptr& error,
const std::shared_ptr<void>& context) override;
//TODO: override remaining member functions inherited from mip::FileHandler::Observer
};
file_handler_observer.cpp
Dit voorbeeld is slechts de eerste twee functies, maar de resterende functies gebruiken een vergelijkbaar patroon als deze en .ProfileObserver
#include "file_handler_observer.h"
void FileHandlerObserver::OnCreateFileHandlerSuccess(const std::shared_ptr<mip::FileHandler>& fileHandler, const std::shared_ptr<void>& context) {
auto promise = std::static_pointer_cast<std::promise<std::shared_ptr<mip::FileHandler>>>(context);
promise->set_value(fileHandler);
}
void FileHandlerObserver::OnCreateFileHandlerFailure(const std::exception_ptr& error, const std::shared_ptr<void>& context) {
auto promise = std::static_pointer_cast<std::promise<std::shared_ptr<mip::FileHandler>>>(context);
promise->set_exception(error);
}
//TODO: override remaining member functions inherited from mip::FileHandler::Observer