DASH Media Packaging SDK
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator
decrypt_config.h
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef MEDIA_BASE_DECRYPT_CONFIG_H_
6 #define MEDIA_BASE_DECRYPT_CONFIG_H_
7 
8 #include <stdint.h>
9 
10 #include <string>
11 #include <vector>
12 
13 #include "packager/base/memory/scoped_ptr.h"
14 #include "packager/media/base/fourccs.h"
15 
16 namespace edash_packager {
17 namespace media {
18 
30  : clear_bytes(0), cipher_bytes(0) {}
31  SubsampleEntry(uint16_t clear_bytes, uint32_t cipher_bytes)
32  : clear_bytes(clear_bytes), cipher_bytes(cipher_bytes) {}
33 
34  uint16_t clear_bytes;
35  uint32_t cipher_bytes;
36 };
37 
41  public:
43  static const size_t kDecryptionKeySize = 16;
44 
51  DecryptConfig(const std::vector<uint8_t>& key_id,
52  const std::vector<uint8_t>& iv,
53  const std::vector<SubsampleEntry>& subsamples);
54 
67  DecryptConfig(const std::vector<uint8_t>& key_id,
68  const std::vector<uint8_t>& iv,
69  const std::vector<SubsampleEntry>& subsamples,
70  FourCC protection_scheme,
71  uint8_t crypt_byte_block,
72  uint8_t skip_byte_block);
73 
74  ~DecryptConfig();
75 
76  const std::vector<uint8_t>& key_id() const { return key_id_; }
77  const std::vector<uint8_t>& iv() const { return iv_; }
78  const std::vector<SubsampleEntry>& subsamples() const { return subsamples_; }
79  FourCC protection_scheme() const { return protection_scheme_; }
80  uint8_t crypt_byte_block() const { return crypt_byte_block_; }
81  uint8_t skip_byte_block() const { return skip_byte_block_; }
82 
83  private:
84  const std::vector<uint8_t> key_id_;
85 
86  // Initialization vector.
87  const std::vector<uint8_t> iv_;
88 
89  // Subsample information. May be empty for some formats, meaning entire frame
90  // (less data ignored by data_offset_) is encrypted.
91  const std::vector<SubsampleEntry> subsamples_;
92 
93  const FourCC protection_scheme_;
94  // For pattern-based protection schemes, like CENS and CBCS.
95  const uint8_t crypt_byte_block_;
96  const uint8_t skip_byte_block_;
97 
98  DISALLOW_COPY_AND_ASSIGN(DecryptConfig);
99 };
100 
101 } // namespace media
102 } // namespace edash_packager
103 
104 #endif // MEDIA_BASE_DECRYPT_CONFIG_H_
static const size_t kDecryptionKeySize
Keys are always 128 bits.
DecryptConfig(const std::vector< uint8_t > &key_id, const std::vector< uint8_t > &iv, const std::vector< SubsampleEntry > &subsamples)