OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/cdm/proxy_decryptor.h" | 5 #include "media/cdm/proxy_decryptor.h" |
6 | 6 |
7 #include <cstring> | 7 #include <cstring> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
53 is_clear_key_(false), | 53 is_clear_key_(false), |
54 weak_ptr_factory_(this) { | 54 weak_ptr_factory_(this) { |
55 DCHECK(media_permission); | 55 DCHECK(media_permission); |
56 DCHECK(!key_added_cb_.is_null()); | 56 DCHECK(!key_added_cb_.is_null()); |
57 DCHECK(!key_error_cb_.is_null()); | 57 DCHECK(!key_error_cb_.is_null()); |
58 DCHECK(!key_message_cb_.is_null()); | 58 DCHECK(!key_message_cb_.is_null()); |
59 } | 59 } |
60 | 60 |
61 ProxyDecryptor::~ProxyDecryptor() { | 61 ProxyDecryptor::~ProxyDecryptor() { |
62 // Destroy the decryptor explicitly before destroying the plugin. | 62 // Destroy the decryptor explicitly before destroying the plugin. |
63 media_keys_.reset(); | 63 media_keys_ = nullptr; |
64 } | 64 } |
65 | 65 |
66 void ProxyDecryptor::CreateCdm(CdmFactory* cdm_factory, | 66 void ProxyDecryptor::CreateCdm(CdmFactory* cdm_factory, |
67 const std::string& key_system, | 67 const std::string& key_system, |
68 const GURL& security_origin, | 68 const GURL& security_origin, |
69 const CdmContextReadyCB& cdm_context_ready_cb) { | 69 const CdmContextReadyCB& cdm_context_ready_cb) { |
70 DVLOG(1) << __FUNCTION__ << ": key_system = " << key_system; | 70 DVLOG(1) << __FUNCTION__ << ": key_system = " << key_system; |
71 DCHECK(!is_creating_cdm_); | 71 DCHECK(!is_creating_cdm_); |
72 DCHECK(!media_keys_); | 72 DCHECK(!media_keys_); |
73 | 73 |
(...skipping 15 matching lines...) Expand all Loading... |
89 base::Bind(&ProxyDecryptor::OnLegacySessionError, weak_this), | 89 base::Bind(&ProxyDecryptor::OnLegacySessionError, weak_this), |
90 base::Bind(&ProxyDecryptor::OnSessionKeysChange, weak_this), | 90 base::Bind(&ProxyDecryptor::OnSessionKeysChange, weak_this), |
91 base::Bind(&ProxyDecryptor::OnSessionExpirationUpdate, weak_this), | 91 base::Bind(&ProxyDecryptor::OnSessionExpirationUpdate, weak_this), |
92 base::Bind(&ProxyDecryptor::OnCdmCreated, weak_this, key_system, | 92 base::Bind(&ProxyDecryptor::OnCdmCreated, weak_this, key_system, |
93 security_origin, cdm_context_ready_cb)); | 93 security_origin, cdm_context_ready_cb)); |
94 } | 94 } |
95 | 95 |
96 void ProxyDecryptor::OnCdmCreated(const std::string& key_system, | 96 void ProxyDecryptor::OnCdmCreated(const std::string& key_system, |
97 const GURL& security_origin, | 97 const GURL& security_origin, |
98 const CdmContextReadyCB& cdm_context_ready_cb, | 98 const CdmContextReadyCB& cdm_context_ready_cb, |
99 scoped_ptr<MediaKeys> cdm, | 99 const scoped_refptr<MediaKeys>& cdm, |
100 const std::string& /* error_message */) { | 100 const std::string& /* error_message */) { |
101 is_creating_cdm_ = false; | 101 is_creating_cdm_ = false; |
102 | 102 |
103 if (!cdm) { | 103 if (!cdm) { |
104 cdm_context_ready_cb.Run(nullptr); | 104 cdm_context_ready_cb.Run(nullptr); |
105 } else { | 105 } else { |
106 key_system_ = key_system; | 106 key_system_ = key_system; |
107 security_origin_ = security_origin; | 107 security_origin_ = security_origin; |
108 is_clear_key_ = IsClearKey(key_system) || IsExternalClearKey(key_system); | 108 is_clear_key_ = IsClearKey(key_system) || IsExternalClearKey(key_system); |
109 media_keys_ = cdm.Pass(); | 109 media_keys_ = cdm; |
110 | 110 |
111 cdm_context_ready_cb.Run(media_keys_->GetCdmContext()); | 111 cdm_context_ready_cb.Run(media_keys_->GetCdmContext()); |
112 } | 112 } |
113 | 113 |
114 for (const auto& request : pending_requests_) | 114 for (const auto& request : pending_requests_) |
115 GenerateKeyRequestInternal(request->init_data_type, request->init_data); | 115 GenerateKeyRequestInternal(request->init_data_type, request->init_data); |
116 | 116 |
117 pending_requests_.clear(); | 117 pending_requests_.clear(); |
118 } | 118 } |
119 | 119 |
(...skipping 284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
404 bool is_persistent = | 404 bool is_persistent = |
405 session_type == PersistentSession || session_type == LoadSession; | 405 session_type == PersistentSession || session_type == LoadSession; |
406 active_sessions_.insert(std::make_pair(session_id, is_persistent)); | 406 active_sessions_.insert(std::make_pair(session_id, is_persistent)); |
407 | 407 |
408 // For LoadSession(), generate the KeyAdded event. | 408 // For LoadSession(), generate the KeyAdded event. |
409 if (session_type == LoadSession) | 409 if (session_type == LoadSession) |
410 GenerateKeyAdded(session_id); | 410 GenerateKeyAdded(session_id); |
411 } | 411 } |
412 | 412 |
413 } // namespace media | 413 } // namespace media |
OLD | NEW |