Chromium Code Reviews| 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 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 126 pending_requests_.push_back( | 126 pending_requests_.push_back( |
| 127 new PendingGenerateKeyRequestData(init_data_type, init_data_vector)); | 127 new PendingGenerateKeyRequestData(init_data_type, init_data_vector)); |
| 128 return; | 128 return; |
| 129 } | 129 } |
| 130 | 130 |
| 131 GenerateKeyRequestInternal(init_data_type, init_data_vector); | 131 GenerateKeyRequestInternal(init_data_type, init_data_vector); |
| 132 } | 132 } |
| 133 | 133 |
| 134 // Returns true if |data| is prefixed with |header| and has data after the | 134 // Returns true if |data| is prefixed with |header| and has data after the |
| 135 // |header|. | 135 // |header|. |
| 136 bool HasHeader(const std::vector<uint8>& data, const std::string& header) { | 136 static bool HasHeader(const std::vector<uint8>& data, |
| 137 const std::string& header) { | |
| 137 return data.size() > header.size() && | 138 return data.size() > header.size() && |
| 138 std::equal(header.begin(), header.end(), data.begin()); | 139 std::equal(header.begin(), header.end(), data.begin()); |
| 139 } | 140 } |
| 140 | 141 |
| 141 // Removes the first |length| items from |data|. | 142 // Removes the first |length| items from |data|. |
| 142 void StripHeader(std::vector<uint8>& data, size_t length) { | 143 static void StripHeader(std::vector<uint8>& data, size_t length) { |
| 143 data.erase(data.begin(), data.begin() + length); | 144 data.erase(data.begin(), data.begin() + length); |
| 144 } | 145 } |
| 145 | 146 |
| 146 void ProxyDecryptor::GenerateKeyRequestInternal( | 147 void ProxyDecryptor::GenerateKeyRequestInternal( |
| 147 EmeInitDataType init_data_type, | 148 EmeInitDataType init_data_type, |
| 148 const std::vector<uint8>& init_data) { | 149 const std::vector<uint8>& init_data) { |
| 149 DVLOG(1) << __FUNCTION__; | 150 DVLOG(1) << __FUNCTION__; |
| 150 DCHECK(!is_creating_cdm_); | 151 DCHECK(!is_creating_cdm_); |
| 151 | 152 |
| 152 if (!media_keys_) { | 153 if (!media_keys_) { |
| (...skipping 231 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 384 // This will include all other CDM4 errors and any error generated | 385 // This will include all other CDM4 errors and any error generated |
| 385 // by CDM5 or later. | 386 // by CDM5 or later. |
| 386 error_code = MediaKeys::kUnknownError; | 387 error_code = MediaKeys::kUnknownError; |
| 387 break; | 388 break; |
| 388 } | 389 } |
| 389 key_error_cb_.Run(session_id, error_code, system_code); | 390 key_error_cb_.Run(session_id, error_code, system_code); |
| 390 } | 391 } |
| 391 | 392 |
| 392 void ProxyDecryptor::SetSessionId(SessionCreationType session_type, | 393 void ProxyDecryptor::SetSessionId(SessionCreationType session_type, |
| 393 const std::string& session_id) { | 394 const std::string& session_id) { |
| 395 // LoadSession() returns empty |session_id| if the session is not found, so | |
| 396 // convert this into an error. | |
| 397 if (session_type == LoadSession && session_id.empty()) { | |
| 398 OnLegacySessionError(session_id, MediaKeys::INVALID_ACCESS_ERROR, 0, | |
| 399 "Incorrect session id specified for LoadSession()."); | |
|
ddorwin
2015/07/10 00:35:12
* s/Incorrect/Unknown/ or something like that.
* L
| |
| 400 return; | |
| 401 } | |
| 402 | |
| 394 // Loaded sessions are considered persistent. | 403 // Loaded sessions are considered persistent. |
| 395 bool is_persistent = | 404 bool is_persistent = |
| 396 session_type == PersistentSession || session_type == LoadSession; | 405 session_type == PersistentSession || session_type == LoadSession; |
| 397 active_sessions_.insert(std::make_pair(session_id, is_persistent)); | 406 active_sessions_.insert(std::make_pair(session_id, is_persistent)); |
| 398 | 407 |
| 399 // For LoadSession(), generate the KeyAdded event. | 408 // For LoadSession(), generate the KeyAdded event. |
| 400 if (session_type == LoadSession) | 409 if (session_type == LoadSession) |
| 401 GenerateKeyAdded(session_id); | 410 GenerateKeyAdded(session_id); |
| 402 } | 411 } |
| 403 | 412 |
| 404 } // namespace media | 413 } // namespace media |
| OLD | NEW |