OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "media/crypto/aes_decryptor.h" | 5 #include "media/crypto/aes_decryptor.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
191 } | 191 } |
192 | 192 |
193 SetKey(key_id_string, decryption_key.Pass()); | 193 SetKey(key_id_string, decryption_key.Pass()); |
194 client_->KeyAdded(key_system, session_id); | 194 client_->KeyAdded(key_system, session_id); |
195 } | 195 } |
196 | 196 |
197 void AesDecryptor::CancelKeyRequest(const std::string& key_system, | 197 void AesDecryptor::CancelKeyRequest(const std::string& key_system, |
198 const std::string& session_id) { | 198 const std::string& session_id) { |
199 } | 199 } |
200 | 200 |
201 void AesDecryptor::Decrypt(const scoped_refptr<DecoderBuffer>& encrypted, | 201 void AesDecryptor::Decrypt(StreamType stream_type, |
| 202 const scoped_refptr<DecoderBuffer>& encrypted, |
202 const DecryptCB& decrypt_cb) { | 203 const DecryptCB& decrypt_cb) { |
203 CHECK(encrypted->GetDecryptConfig()); | 204 CHECK(encrypted->GetDecryptConfig()); |
204 const std::string& key_id = encrypted->GetDecryptConfig()->key_id(); | 205 const std::string& key_id = encrypted->GetDecryptConfig()->key_id(); |
205 | 206 |
206 DecryptionKey* key = GetKey(key_id); | 207 DecryptionKey* key = GetKey(key_id); |
207 if (!key) { | 208 if (!key) { |
208 DVLOG(1) << "Could not find a matching key for the given key ID."; | 209 DVLOG(1) << "Could not find a matching key for the given key ID."; |
209 decrypt_cb.Run(kNoKey, NULL); | 210 decrypt_cb.Run(kNoKey, NULL); |
210 return; | 211 return; |
211 } | 212 } |
(...skipping 12 matching lines...) Expand all Loading... |
224 decrypt_cb.Run(kError, NULL); | 225 decrypt_cb.Run(kError, NULL); |
225 return; | 226 return; |
226 } | 227 } |
227 } | 228 } |
228 | 229 |
229 decrypted->SetTimestamp(encrypted->GetTimestamp()); | 230 decrypted->SetTimestamp(encrypted->GetTimestamp()); |
230 decrypted->SetDuration(encrypted->GetDuration()); | 231 decrypted->SetDuration(encrypted->GetDuration()); |
231 decrypt_cb.Run(kSuccess, decrypted); | 232 decrypt_cb.Run(kSuccess, decrypted); |
232 } | 233 } |
233 | 234 |
234 void AesDecryptor::CancelDecrypt() { | 235 void AesDecryptor::CancelDecrypt(StreamType stream_type) { |
| 236 // Decrypt() calls the DecryptCB synchronously so there's nothing to cancel. |
| 237 } |
| 238 |
| 239 void AesDecryptor::InitializeAudioDecoder(scoped_ptr<AudioDecoderConfig> config, |
| 240 const DecoderInitCB& init_cb, |
| 241 const KeyAddedCB& key_added_cb) { |
| 242 // AesDecryptor does not support audio decoding. |
| 243 init_cb.Run(false); |
235 } | 244 } |
236 | 245 |
237 void AesDecryptor::InitializeVideoDecoder(scoped_ptr<VideoDecoderConfig> config, | 246 void AesDecryptor::InitializeVideoDecoder(scoped_ptr<VideoDecoderConfig> config, |
238 const DecoderInitCB& init_cb, | 247 const DecoderInitCB& init_cb, |
239 const KeyAddedCB& key_added_cb) { | 248 const KeyAddedCB& key_added_cb) { |
240 // AesDecryptor does not support video decoding. | 249 // AesDecryptor does not support video decoding. |
241 init_cb.Run(false); | 250 init_cb.Run(false); |
242 } | 251 } |
243 | 252 |
| 253 void AesDecryptor::DecryptAndDecodeAudio( |
| 254 const scoped_refptr<DecoderBuffer>& encrypted, |
| 255 const AudioDecodeCB& audio_decode_cb) { |
| 256 NOTREACHED() << "AesDecryptor does not support audio decoding"; |
| 257 } |
| 258 |
244 void AesDecryptor::DecryptAndDecodeVideo( | 259 void AesDecryptor::DecryptAndDecodeVideo( |
245 const scoped_refptr<DecoderBuffer>& encrypted, | 260 const scoped_refptr<DecoderBuffer>& encrypted, |
246 const VideoDecodeCB& video_decode_cb) { | 261 const VideoDecodeCB& video_decode_cb) { |
247 NOTREACHED() << "AesDecryptor does not support video decoding"; | 262 NOTREACHED() << "AesDecryptor does not support video decoding"; |
248 } | 263 } |
249 | 264 |
250 void AesDecryptor::CancelDecryptAndDecodeVideo() { | 265 void AesDecryptor::ResetDecoder(StreamType stream_type) { |
251 NOTREACHED() << "AesDecryptor does not support video decoding"; | 266 NOTREACHED() << "AesDecryptor does not support audio/video decoding"; |
252 } | 267 } |
253 | 268 |
254 void AesDecryptor::StopVideoDecoder() { | 269 void AesDecryptor::DeinitializeDecoder(StreamType stream_type) { |
255 NOTREACHED() << "AesDecryptor does not support video decoding"; | 270 NOTREACHED() << "AesDecryptor does not support audio/video decoding"; |
256 } | 271 } |
257 | 272 |
258 void AesDecryptor::SetKey(const std::string& key_id, | 273 void AesDecryptor::SetKey(const std::string& key_id, |
259 scoped_ptr<DecryptionKey> decryption_key) { | 274 scoped_ptr<DecryptionKey> decryption_key) { |
260 base::AutoLock auto_lock(key_map_lock_); | 275 base::AutoLock auto_lock(key_map_lock_); |
261 KeyMap::iterator found = key_map_.find(key_id); | 276 KeyMap::iterator found = key_map_.find(key_id); |
262 if (found != key_map_.end()) { | 277 if (found != key_map_.end()) { |
263 delete found->second; | 278 delete found->second; |
264 key_map_.erase(found); | 279 key_map_.erase(found); |
265 } | 280 } |
(...skipping 19 matching lines...) Expand all Loading... |
285 bool AesDecryptor::DecryptionKey::Init() { | 300 bool AesDecryptor::DecryptionKey::Init() { |
286 CHECK(!secret_.empty()); | 301 CHECK(!secret_.empty()); |
287 decryption_key_.reset(crypto::SymmetricKey::Import( | 302 decryption_key_.reset(crypto::SymmetricKey::Import( |
288 crypto::SymmetricKey::AES, secret_)); | 303 crypto::SymmetricKey::AES, secret_)); |
289 if (!decryption_key_.get()) | 304 if (!decryption_key_.get()) |
290 return false; | 305 return false; |
291 return true; | 306 return true; |
292 } | 307 } |
293 | 308 |
294 } // namespace media | 309 } // namespace media |
OLD | NEW |