/* Copyright (c) 2012 The Chromium Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
/* From private/ppp_content_decryptor_private.idl,
* modified Mon Oct 19 13:04:26 2015.
*/
#ifndef PPAPI_C_PRIVATE_PPP_CONTENT_DECRYPTOR_PRIVATE_H_
#define PPAPI_C_PRIVATE_PPP_CONTENT_DECRYPTOR_PRIVATE_H_
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_instance.h"
#include "ppapi/c/pp_macros.h"
#include "ppapi/c/pp_resource.h"
#include "ppapi/c/pp_stdint.h"
#include "ppapi/c/pp_var.h"
#include "ppapi/c/private/pp_content_decryptor.h"
#define PPP_CONTENTDECRYPTOR_PRIVATE_INTERFACE_0_16 \
"PPP_ContentDecryptor_Private;0.16"
#define PPP_CONTENTDECRYPTOR_PRIVATE_INTERFACE \
PPP_CONTENTDECRYPTOR_PRIVATE_INTERFACE_0_16
/**
* @file
* This file defines the PPP_ContentDecryptor_Private
* interface. Note: This is a special interface, only to be used for Content
* Decryption Modules, not normal plugins.
*/
/**
* @addtogroup Interfaces
* @{
*/
/**
* PPP_ContentDecryptor_Private
structure contains the function
* pointers the decryption plugin must implement to provide services needed by
* the browser. This interface provides the plugin side support for the Content
* Decryption Module (CDM) for Encrypted Media Extensions:
* http://www.w3.org/TR/encrypted-media/
*/
struct PPP_ContentDecryptor_Private_0_16 {
/**
* Initialize for the specified key system.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of initialization.
*
* @param[in] key_system A PP_Var
of type
* PP_VARTYPE_STRING
containing the name of the key system.
* @param[in] allow_distinctive_identifier Inform the CDM that it may use a
* distinctive identifier.
* @param[in] allow_persistent_state Inform the CDM that it may use persistent
* state.
*/
void (*Initialize)(PP_Instance instance,
uint32_t promise_id,
struct PP_Var key_system,
PP_Bool allow_distinctive_identifier,
PP_Bool allow_persistent_state);
/**
* Provides a server certificate to be used to encrypt messages to the
* license server.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of setting the certificate.
*
* @param[in] server_certificate A PP_Var
of type
* PP_VARTYPE_ARRAYBUFFER
containing the certificate to be used.
*/
void (*SetServerCertificate)(PP_Instance instance,
uint32_t promise_id,
struct PP_Var server_certificate);
/**
* Creates a session and subsequently generates a request for a license.
* init_data_type
contains the MIME type of
* init_data
. init_data
is a data buffer
* containing data for use in generating the request.
*
* Note: CreateSessionAndGenerateRequest()
must create a
* session ID and provide it to the browser via SessionCreated()
* on the PPB_ContentDecryptor_Private
interface.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure when creating the session.
*
* @param[in] session_type A PP_SessionType
that indicates the
* type of session to be created.
*
* @param[in] init_data_type A PP_InitDataType
that indicates
* the Initialization Data Type for init_data.
*
* @param[in] init_data A PP_Var
of type
* PP_VARTYPE_ARRAYBUFFER
containing container specific
* initialization data.
*/
void (*CreateSessionAndGenerateRequest)(PP_Instance instance,
uint32_t promise_id,
PP_SessionType session_type,
PP_InitDataType init_data_type,
struct PP_Var init_data);
/**
* Loads a session whose session ID is session_id
.
*
* Note: After the session is successfully loaded, the CDM must call
* SessionCreated()
with session_id
on the
* PPB_ContentDecryptor_Private
interface.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of loading the session.
*
* @param[in] session_type A PP_SessionType
that indicates the
* type of session to be loaded.
*
* @param[in] session_id A PP_Var
of type
* PP_VARTYPE_STRING
containing the session ID of the session
* to load.
*/
void (*LoadSession)(PP_Instance instance,
uint32_t promise_id,
PP_SessionType session_type,
struct PP_Var session_id);
/**
* Provides a license or other message to the decryptor.
*
* When the CDM needs more information, it must call
* SessionMessage()
on the
* PPB_ContentDecryptor_Private
interface, and the browser
* must notify the web application. When the CDM has finished processing
* response
and needs no more information, it must call
* SessionReady()
on the
* PPB_ContentDecryptor_Private
interface, and the browser
* must notify the web application.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of updating the session.
*
* @param[in] session_id A PP_Var
of type
* PP_VARTYPE_STRING
containing the session ID of the session
* to be updated.
*
* @param[in] response A PP_Var
of type
* PP_VARTYPE_ARRAYBUFFER
containing the license or other
* message for the given session ID.
*/
void (*UpdateSession)(PP_Instance instance,
uint32_t promise_id,
struct PP_Var session_id,
struct PP_Var response);
/**
* Close the specified session and related resources.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of closing the session.
*
* @param[in] session_id A PP_Var
of type
* PP_VARTYPE_STRING
containing the session ID of the session
* to be closed.
*
*/
void (*CloseSession)(PP_Instance instance,
uint32_t promise_id,
struct PP_Var session_id);
/**
* Remove stored data associated with this session.
*
* @param[in] promise_id A reference for the promise that gets resolved or
* rejected depending upon the success or failure of removing the session
* data.
*
* @param[in] session_id A PP_Var
of type
* PP_VARTYPE_STRING
containing the session ID of the session
* to be removed.
*
*/
void (*RemoveSession)(PP_Instance instance,
uint32_t promise_id,
struct PP_Var session_id);
/**
* Decrypts the block and returns the unencrypted block via
* DeliverBlock()
on the
* PPB_ContentDecryptor_Private
interface. The returned block
* contains encoded data.
*
* @param[in] resource A PP_Resource
corresponding to a
* PPB_Buffer_Dev
resource that contains an encrypted data
* block.
*
* @param[in] encrypted_block_info A PP_EncryptedBlockInfo
that
* contains all auxiliary information needed for decryption of the
* encrypted_block
.
*/
void (*Decrypt)(PP_Instance instance,
PP_Resource encrypted_block,
const struct PP_EncryptedBlockInfo* encrypted_block_info);
/**
* Initializes the audio decoder using codec and settings in
* decoder_config
, and returns the result of the initialization
* request to the browser using the DecoderInitializeDone(
)
method
* on the PPB_ContentDecryptor_Private
interface.
*
* @param[in] decoder_config A PP_AudioDecoderConfig
that
* contains audio decoder settings and a request ID. The request ID is passed
* to the DecoderInitializeDone()
method on the
* PPB_ContentDecryptor_Private
interface to allow clients to
* associate the result with a audio decoder initialization request.
*
* @param[in] codec_extra_data A PP_Resource
corresponding to a
* PPB_Buffer_Dev
resource containing codec setup data required
* by some codecs. It should be set to 0 when the codec being initialized
* does not require it.
*/
void (*InitializeAudioDecoder)(
PP_Instance instance,
const struct PP_AudioDecoderConfig* decoder_config,
PP_Resource codec_extra_data);
/**
* Initializes the video decoder using codec and settings in
* decoder_config
, and returns the result of the initialization
* request to the browser using the DecoderInitializeDone()
* method on the PPB_ContentDecryptor_Private
interface.
*
* @param[in] decoder_config A PP_VideoDecoderConfig
that
* contains video decoder settings and a request ID. The request ID is passed
* to the DecoderInitializeDone()
method on the
* PPB_ContentDecryptor_Private
interface to allow clients to
* associate the result with a video decoder initialization request.
*
* @param[in] codec_extra_data A PP_Resource
corresponding to a
* PPB_Buffer_Dev
resource containing codec setup data required
* by some codecs. It should be set to 0 when the codec being initialized
* does not require it.
*/
void (*InitializeVideoDecoder)(
PP_Instance instance,
const struct PP_VideoDecoderConfig* decoder_config,
PP_Resource codec_extra_data);
/**
* De-initializes the decoder for the PP_DecryptorStreamType
* specified by decoder_type
and sets it to an uninitialized
* state. The decoder can be re-initialized after de-initialization completes
* by calling InitializeAudioDecoder
or
* InitializeVideoDecoder
.
*
* De-initialization completion is reported to the browser using the
* DecoderDeinitializeDone()
method on the
* PPB_ContentDecryptor_Private
interface.
*
* @param[in] decoder_type A PP_DecryptorStreamType
that
* specifies the decoder to de-initialize.
*
* @param[in] request_id A request ID that allows the browser to associate a
* request to de-initialize a decoder with the corresponding call to the
* DecoderDeinitializeDone()
method on the
* PPB_ContentDecryptor_Private
interface.
*/
void (*DeinitializeDecoder)(PP_Instance instance,
PP_DecryptorStreamType decoder_type,
uint32_t request_id);
/**
* Resets the decoder for the PP_DecryptorStreamType
specified
* by decoder_type
to an initialized clean state. Reset
* completion is reported to the browser using the
* DecoderResetDone()
method on the
* PPB_ContentDecryptor_Private
interface. This method can be
* used to signal a discontinuity in the encoded data stream, and is safe to
* call multiple times.
*
* @param[in] decoder_type A PP_DecryptorStreamType
that
* specifies the decoder to reset.
*
* @param[in] request_id A request ID that allows the browser to associate a
* request to reset the decoder with a corresponding call to the
* DecoderResetDone()
method on the
* PPB_ContentDecryptor_Private
interface.
*/
void (*ResetDecoder)(PP_Instance instance,
PP_DecryptorStreamType decoder_type,
uint32_t request_id);
/**
* Decrypts encrypted_buffer, decodes it, and returns the unencrypted
* uncompressed (decoded) data to the browser via the
* DeliverFrame()
or DeliverSamples()
method on the
* PPB_ContentDecryptor_Private
interface.
*
* @param[in] decoder_type A PP_DecryptorStreamType
that
* specifies the decoder to use after encrypted_buffer
is
* decrypted.
*
* @param[in] encrypted_buffer A PP_Resource
corresponding to a
* PPB_Buffer_Dev
resource that contains encrypted media data.
*
* @param[in] encrypted_block_info A PP_EncryptedBlockInfo
that
* contains all auxiliary information needed for decryption of the
* encrypted_block
.
*/
void (*DecryptAndDecode)(
PP_Instance instance,
PP_DecryptorStreamType decoder_type,
PP_Resource encrypted_buffer,
const struct PP_EncryptedBlockInfo* encrypted_block_info);
};
typedef struct PPP_ContentDecryptor_Private_0_16 PPP_ContentDecryptor_Private;
/**
* @}
*/
#endif /* PPAPI_C_PRIVATE_PPP_CONTENT_DECRYPTOR_PRIVATE_H_ */