Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
No MIP Protection SDK, o mip::ProtectionHandler expõe as funções para criptografar e descriptografar fluxos e buffers protegidos, executar verificações de acesso, obter a licença de publicação e obter atributos das informações protegidas.
Requerimentos
Criar um ProtectionHandler para trabalhar com um arquivo específico requer:
- Uma
mip::MipContext - Uma
mip::ProtectionProfile - O
mip::ProtectionEngineadicionado aoProtectionProfile - Uma classe que herda .
mip::ProtectionHandler::Observer - Uma
mip::ProtectionDescriptorou licença de publicação
Criar um gestor de proteção
mip::ProtectionHandler Os objetos são construídos para operações de proteção ou consumo . O manipulador é criado usando uma das quatro funções, dependendo do cenário.
mip::ProtectionEngine->CreateProtectionHandlerForConsumptionAsync()mip::ProtectionEngine->CreateProtectionHandlerForConsumption()mip::ProtectionEngine->CreateProtectionHandlerForPublishingAsync()mip::ProtectionEngine->CreateProtectionHandlerForPublishing()
Essas funções aceitam um mip::ProtectionHandler::PublishingSettings ou mip::ProtectionHandler::ConsumptionSettings objeto.
Criar um manipulador de publicação
A criação de um manipulador de publicação requer três etapas:
- Crie um
mip::ProtectionDescriptorobjeto. - Use o
mip::ProtectionDescriptorpara instanciarmip::ProtectionHandler::PublishingSettings. - Chame
mip::ProtectionEngine::CreateProtectionHandlerForPublishingAsync()passando oPublishingSettingsobjeto, observador e promessa.
Criar a partir do descritor
Se estiver protegendo conteúdo que ainda não foi protegido, ou ao aplicar nova proteção ao conteúdo, o que implica que ele foi descriptografado, um mip::ProtectionDescriptor deve ser construído. Uma vez construído, ele é usado para instanciar o mip::ProtectionHandler::PublishingSettings() objeto. O resultado é devolvido através do mip::ProtectionHandler::Observerficheiro .
// Create the protection descriptor, passing in a templateId.
auto descriptorBuilder = mip::ProtectionDescriptorBuilder::CreateFromTemplate(protectionOptions.templateId);
std::shared_ptr<mip::ProtectionDescriptor> descriptor = descriptorBuilder->Build();
// Define the handler promise, future, and observer.
auto handlerPromise = std::make_shared<std::promise<std::shared_ptr<ProtectionHandler>>>();
auto handlerFuture = handlerPromise->get_future();
auto handlerObserver = std::make_shared<ProtectionHandlerObserverImpl>();
// Create the PublishingSettings object using the previously-created descriptor as input.
mip::ProtectionHandler::PublishingSettings publishingSettings = mip::ProtectionHandler::PublishingSettings(descriptor);
// Create/get the publishing handler from the publishing settings, observer, and promise.
mEngine->CreateProtectionHandlerForPublishingAsync(publishingSettings, handlerObserver, handlerPromise);
auto handler = handlerFuture.get();
return handler;
Depois de criar o objeto com êxito, as ProtectionHandler operações de proteção (encriptação/desencriptação) podem ser executadas. A licença de publicação deve ser obtida do manipulador e armazenada com o conteúdo criptografado. A licença de publicação pode ser obtida chamando: handler->GetSerializedPublishingLicense();
O conteúdo protegido sem a licença de publicação correspondente não pode ser desencriptado.
Criar o manipulador de consumo
A criação de um manipulador de publicação requer três etapas:
- Extraia uma licença de publicação serializada a partir do conteúdo protegido como
std::vector<uint8_t>. - Use a licença de publicação serializada para instanciar
mip::ProtectionHandler::ConsumptionSettings. - Chame
mip::ProtectionEngine::CreateProtectionHandlerForConsumptionAsync()passando o objetoConsumptionSettings, o observador e a promessa.
Este exemplo pressupõe que a licença de publicação já tenha sido lida de alguma fonte e armazenada no std::vector<uint8_t> serializedPublishingLicense.
//TODO: Implement GetPublishingLicense()
//Snip implies that function reads PL from source file, database, stream, etc.
std::vector<uint8_t> serializedPublishingLicense = GetPublishingLicense(filePath);
// Define the handler promise, future, and observer.
auto handlerPromise = std::make_shared<std::promise<std::shared_ptr<ProtectionHandler>>>();
auto handlerFuture = handlerPromise->get_future();
shared_ptr<ProtectionHandlerObserverImpl> handlerObserver = std::make_shared<ProtectionHandlerObserverImpl>();
// Create the consumption settings object from the publishing license.
mip::ProtectionHandler::ConsumptionSettings consumptionSettings = mip::ProtectionHandler::ConsumptionSettings(serializedPublishingLicense);
// Create/get the publishing handler from the publishing settings, observer, and promise.
mEngine->CreateProtectionHandlerForConsumptionAsync(consumptionSettings, handlerObserver, handlerPromise);
auto handler = handlerFuture.get();