Chromium Code Reviews| Index: android_webview/browser/aw_media_client_android.cc |
| diff --git a/android_webview/browser/aw_media_client_android.cc b/android_webview/browser/aw_media_client_android.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..38a0cd8872a72137d780baf9018a94896110a60b |
| --- /dev/null |
| +++ b/android_webview/browser/aw_media_client_android.cc |
| @@ -0,0 +1,62 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "android_webview/browser/aw_media_client_android.h" |
| + |
| +#include <utility> |
| + |
| +#include "base/stl_util.h" |
| +#include "base/strings/string_number_conversions.h" |
| +#include "base/strings/string_util.h" |
| + |
| +namespace android_webview { |
| + |
| +namespace { |
| + |
| +const size_t kGUIDLength = 36U; |
| + |
| +std::pair<std::string, media::UUID> CreateMappingFromString( |
| + const std::string& key_system_uuid_mapping) { |
| + std::vector<std::string> tokens; |
| + Tokenize(key_system_uuid_mapping, ",", &tokens); |
| + |
| + std::string key_system; |
| + base::TrimWhitespaceASCII(tokens[0], base::TRIM_ALL, &key_system); |
| + |
| + std::vector<uint8_t> uuid; |
| + std::string guid(tokens[1]); |
|
boliu
2015/04/29 19:24:25
Is it safe to assume key_system_uuid_mapping can a
gunsch
2015/04/29 20:29:43
I was hoping you could answer that: I don't really
boliu
2015/04/29 23:15:44
It comes from a resource that individual devices c
|
| + DCHECK(guid.length() == kGUIDLength); |
| + base::RemoveChars(guid, "-", &guid); |
| + base::HexStringToBytes(guid, &uuid); |
| + |
| + return std::make_pair(key_system, uuid); |
| +} |
| + |
| +} // namespace |
| + |
| +AwMediaClientAndroid::AwMediaClientAndroid( |
| + const std::vector<std::string>& key_system_uuid_mappings) |
| + : key_system_uuid_mappings_(key_system_uuid_mappings) { |
| +} |
| + |
| +AwMediaClientAndroid::~AwMediaClientAndroid() { |
| +} |
| + |
| +void AwMediaClientAndroid::AddKeySystemUUIDMappings(KeySystemUuidMap* map) { |
| + for (const std::string& key_system_uuid_mapping : key_system_uuid_mappings_) { |
| + std::pair<std::string, media::UUID> mapping = |
| + CreateMappingFromString(key_system_uuid_mapping); |
| + (*map)[mapping.first] = mapping.second; |
|
boliu
2015/04/29 19:24:25
map->insert?
gunsch
2015/04/29 20:29:44
Done.
|
| + } |
| +} |
| + |
| +media::MediaDrmBridgeDelegate* |
| +AwMediaClientAndroid::GetMediaDrmBridgeDelegate( |
| + const media::UUID& scheme_uuid) { |
| + if (scheme_uuid == widevine_delegate_.GetUUID()) |
| + return &widevine_delegate_; |
| + return nullptr; |
|
boliu
2015/04/29 19:24:25
Pure question on my part since I don't actually kn
gunsch
2015/04/29 20:29:43
This patch shouldn't change any user-facing behavi
|
| +} |
| + |
| +} // namespace android_webview |