| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/base/android/android_cdm_factory.h" | 5 #include "media/base/android/android_cdm_factory.h" |
| 6 | 6 |
| 7 #include "base/strings/string_number_conversions.h" | 7 #include "base/strings/string_number_conversions.h" |
| 8 #include "media/base/android/media_drm_bridge.h" | 8 #include "media/base/android/media_drm_bridge.h" |
| 9 #include "media/base/bind_to_current_loop.h" | 9 #include "media/base/bind_to_current_loop.h" |
| 10 #include "media/base/cdm_config.h" | 10 #include "media/base/cdm_config.h" |
| 11 #include "media/base/key_systems.h" | 11 #include "media/base/key_systems.h" |
| 12 #include "third_party/widevine/cdm/widevine_cdm_common.h" | 12 #include "third_party/widevine/cdm/widevine_cdm_common.h" |
| 13 #include "url/gurl.h" | 13 #include "url/gurl.h" |
| 14 | 14 |
| 15 namespace media { | 15 namespace media { |
| 16 | 16 |
| 17 AndroidCdmFactory::AndroidCdmFactory(const CreateFetcherCB& create_fetcher_cb) | 17 AndroidCdmFactory::AndroidCdmFactory(const CreateFetcherCB& create_fetcher_cb) |
| 18 : create_fetcher_cb_(create_fetcher_cb) {} | 18 : create_fetcher_cb_(create_fetcher_cb) {} |
| 19 | 19 |
| 20 AndroidCdmFactory::~AndroidCdmFactory() {} | 20 AndroidCdmFactory::~AndroidCdmFactory() {} |
| 21 | 21 |
| 22 void AndroidCdmFactory::Create( | 22 void AndroidCdmFactory::Create( |
| 23 const std::string& key_system, | 23 const std::string& key_system, |
| 24 const GURL& security_origin, | 24 const GURL& security_origin, |
| 25 const CdmConfig& cdm_config, | 25 const CdmConfig& cdm_config, |
| 26 const SessionMessageCB& session_message_cb, | 26 const SessionMessageCB& session_message_cb, |
| 27 const SessionClosedCB& session_closed_cb, | 27 const SessionClosedCB& session_closed_cb, |
| 28 const LegacySessionErrorCB& legacy_session_error_cb, | |
| 29 const SessionKeysChangeCB& session_keys_change_cb, | 28 const SessionKeysChangeCB& session_keys_change_cb, |
| 30 const SessionExpirationUpdateCB& session_expiration_update_cb, | 29 const SessionExpirationUpdateCB& session_expiration_update_cb, |
| 31 const CdmCreatedCB& cdm_created_cb) { | 30 const CdmCreatedCB& cdm_created_cb) { |
| 32 // Bound |cdm_created_cb| so we always fire it asynchronously. | 31 // Bound |cdm_created_cb| so we always fire it asynchronously. |
| 33 CdmCreatedCB bound_cdm_created_cb = BindToCurrentLoop(cdm_created_cb); | 32 CdmCreatedCB bound_cdm_created_cb = BindToCurrentLoop(cdm_created_cb); |
| 34 | 33 |
| 35 if (!security_origin.is_valid()) { | 34 if (!security_origin.is_valid()) { |
| 36 bound_cdm_created_cb.Run(nullptr, "Invalid origin."); | 35 bound_cdm_created_cb.Run(nullptr, "Invalid origin."); |
| 37 return; | 36 return; |
| 38 } | 37 } |
| (...skipping 19 matching lines...) Expand all Loading... |
| 58 error_message = | 57 error_message = |
| 59 key_system + | 58 key_system + |
| 60 " may require use_video_overlay_for_embedded_encrypted_video"; | 59 " may require use_video_overlay_for_embedded_encrypted_video"; |
| 61 NOTREACHED() << error_message; | 60 NOTREACHED() << error_message; |
| 62 bound_cdm_created_cb.Run(nullptr, error_message); | 61 bound_cdm_created_cb.Run(nullptr, error_message); |
| 63 return; | 62 return; |
| 64 } | 63 } |
| 65 | 64 |
| 66 scoped_refptr<MediaDrmBridge> cdm(MediaDrmBridge::Create( | 65 scoped_refptr<MediaDrmBridge> cdm(MediaDrmBridge::Create( |
| 67 key_system, security_level, create_fetcher_cb_, session_message_cb, | 66 key_system, security_level, create_fetcher_cb_, session_message_cb, |
| 68 session_closed_cb, legacy_session_error_cb, session_keys_change_cb, | 67 session_closed_cb, session_keys_change_cb, session_expiration_update_cb)); |
| 69 session_expiration_update_cb)); | |
| 70 if (!cdm) { | 68 if (!cdm) { |
| 71 error_message = "MediaDrmBridge cannot be created for " + key_system + | 69 error_message = "MediaDrmBridge cannot be created for " + key_system + |
| 72 " with security level " + base::IntToString(security_level); | 70 " with security level " + base::IntToString(security_level); |
| 73 LOG(ERROR) << error_message; | 71 LOG(ERROR) << error_message; |
| 74 bound_cdm_created_cb.Run(nullptr, error_message); | 72 bound_cdm_created_cb.Run(nullptr, error_message); |
| 75 return; | 73 return; |
| 76 } | 74 } |
| 77 | 75 |
| 78 // Success! | 76 // Success! |
| 79 bound_cdm_created_cb.Run(cdm, ""); | 77 bound_cdm_created_cb.Run(cdm, ""); |
| 80 } | 78 } |
| 81 | 79 |
| 82 } // namespace media | 80 } // namespace media |
| OLD | NEW |