/* 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 Aug 25 14:02:40 2014. */ #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_12 \ "PPP_ContentDecryptor_Private;0.12" #define PPP_CONTENTDECRYPTOR_PRIVATE_INTERFACE \ PPP_CONTENTDECRYPTOR_PRIVATE_INTERFACE_0_12 /** * @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_12 { /** * Initialize for the specified key system. * * @param[in] key_system A PP_Var of type * PP_VARTYPE_STRING containing the name of the key system. */ void (*Initialize)(PP_Instance instance, struct PP_Var key_system); /** * 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. 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: CreateSession() must create a web 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] init_data_type A PP_Var of type * PP_VARTYPE_STRING containing the MIME type for init_data. * * @param[in] init_data A PP_Var of type * PP_VARTYPE_ARRAYBUFFER containing container specific * initialization data. * * @param[in] session_type A PP_SessionType that indicates the * type of session to be created. */ void (*CreateSession)(PP_Instance instance, uint32_t promise_id, struct PP_Var init_data_type, struct PP_Var init_data, PP_SessionType session_type); /** * Loads a session whose web session ID is web_session_id. * * Note: After the session is successfully loaded, the CDM must call * SessionCreated() with web_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] web_session_id A PP_Var of type * PP_VARTYPE_STRING containing the web session ID of the session * to load. */ void (*LoadSession)(PP_Instance instance, uint32_t promise_id, struct PP_Var web_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] web_session_id A PP_Var of type * PP_VARTYPE_STRING containing the web 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 web_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] web_session_id A PP_Var of type * PP_VARTYPE_STRING containing the web session ID of the session * to be closed. * */ void (*CloseSession)(PP_Instance instance, uint32_t promise_id, struct PP_Var web_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] web_session_id A PP_Var of type * PP_VARTYPE_STRING containing the web session ID of the session * to be removed. * */ void (*RemoveSession)(PP_Instance instance, uint32_t promise_id, struct PP_Var web_session_id); /** * Get the key IDs for keys in the session that the CDM knows are currently * usable to decrypt media data. * * @param[in] promise_id A reference for the promise that gets resolved or * rejected depending upon the success or failure of obtaining the key IDs. * * @param[in] web_session_id A PP_Var of type * PP_VARTYPE_STRING containing the web session ID of the session * to be queried. * */ void (*GetUsableKeyIds)(PP_Instance instance, uint32_t promise_id, struct PP_Var web_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_12 PPP_ContentDecryptor_Private; /** * @} */ #endif /* PPAPI_C_PRIVATE_PPP_CONTENT_DECRYPTOR_PRIVATE_H_ */