Shaka Packager SDK
Public Member Functions | Static Public Member Functions | List of all members
shaka::media::PlayReadyKeySource Class Reference

A key source that uses PlayReady for encryption. More...

#include <playready_key_source.h>

Inheritance diagram for shaka::media::PlayReadyKeySource:
shaka::media::KeySource

Public Member Functions

 PlayReadyKeySource (const std::string &server_url, ProtectionSystem protection_systems)
 
virtual Status FetchKeysWithProgramIdentifier (const std::string &program_identifier)
 
KeySource implementation overrides.
Status FetchKeys (EmeInitDataType init_data_type, const std::vector< uint8_t > &init_data) override
 
Status GetKey (const std::string &stream_label, EncryptionKey *key) override
 
Status GetKey (const std::vector< uint8_t > &key_id, EncryptionKey *key) override
 
Status GetCryptoPeriodKey (uint32_t crypto_period_index, uint32_t crypto_period_duration_in_seconds, const std::string &stream_label, EncryptionKey *key) override
 

Static Public Member Functions

static std::unique_ptr< PlayReadyKeySourceCreateFromKeyAndKeyId (const std::vector< uint8_t > &key_id, const std::vector< uint8_t > &key)
 

Detailed Description

A key source that uses PlayReady for encryption.

Definition at line 20 of file playready_key_source.h.

Constructor & Destructor Documentation

◆ PlayReadyKeySource()

shaka::media::PlayReadyKeySource::PlayReadyKeySource ( const std::string &  server_url,
ProtectionSystem  protection_systems 
)

Creates a new PlayReadyKeySource from the given packaging information.

Parameters
server_urlPlayReady packaging server url.
protection_systemsis the enum indicating which PSSH should be included.

Definition at line 65 of file playready_key_source.cc.

Member Function Documentation

◆ CreateFromKeyAndKeyId()

static std::unique_ptr<PlayReadyKeySource> shaka::media::PlayReadyKeySource::CreateFromKeyAndKeyId ( const std::vector< uint8_t > &  key_id,
const std::vector< uint8_t > &  key 
)
static

Creates a new PlayReadyKeySource from the given data. Returns null if the strings are invalid. Note: GetKey on the created key source will always return the same key for all track types.

◆ FetchKeys()

Status shaka::media::PlayReadyKeySource::FetchKeys ( EmeInitDataType  init_data_type,
const std::vector< uint8_t > &  init_data 
)
overridevirtual

Fetch keys based on the specified encrypted media init data.

Parameters
init_data_typespecifies the encrypted media init data type.
init_datacontains the init data.
Returns
OK on success, an error status otherwise.

Implements shaka::media::KeySource.

Definition at line 170 of file playready_key_source.cc.

◆ GetCryptoPeriodKey()

Status shaka::media::PlayReadyKeySource::GetCryptoPeriodKey ( uint32_t  crypto_period_index,
uint32_t  crypto_period_duration_in_seconds,
const std::string &  stream_label,
EncryptionKey key 
)
overridevirtual

Get encryption key of the specified track type at the specified index.

Parameters
crypto_period_indexis the sequence number of the key rotation period for which the key is being retrieved.
crypto_period_duration_in_secondsis the duration of the crypto period in seconds.
stream_labelis the label of stream for which retrieving the key.
keyis a pointer to the EncryptionKey which will hold the retrieved key. Owner retains ownership, and may not be NULL.
Returns
OK on success, an error status otherwise.

Implements shaka::media::KeySource.

Definition at line 197 of file playready_key_source.cc.

◆ GetKey() [1/2]

Status shaka::media::PlayReadyKeySource::GetKey ( const std::string &  stream_label,
EncryptionKey key 
)
overridevirtual

Get encryption key of the specified stream label.

Parameters
stream_labelis the label of stream for which retrieving the key.
keyis a pointer to the EncryptionKey which will hold the retrieved key. Owner retains ownership, and may not be NULL.
Returns
OK on success, an error status otherwise.

Implements shaka::media::KeySource.

Definition at line 176 of file playready_key_source.cc.

◆ GetKey() [2/2]

Status shaka::media::PlayReadyKeySource::GetKey ( const std::vector< uint8_t > &  key_id,
EncryptionKey key 
)
overridevirtual

Get the encryption key specified by the CENC key ID.

Parameters
key_idis the unique identifier for the key being retreived.
keyis a pointer to the EncryptionKey which will hold the retrieved key. Owner retains ownership, and may not be NULL.
Returns
OK on success, or an error status otherwise.

Implements shaka::media::KeySource.

Definition at line 187 of file playready_key_source.cc.


The documentation for this class was generated from the following files: