Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(244)

Side by Side Diff: content/renderer/media/crypto/renderer_cdm_manager.cc

Issue 665563002: Add MediaKeys::GetCdmId(). (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git/+/master
Patch Set: Make GetCdmId() pure virtual. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « content/renderer/media/crypto/renderer_cdm_manager.h ('k') | media/base/cdm_factory.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "content/renderer/media/crypto/renderer_cdm_manager.h" 5 #include "content/renderer/media/crypto/renderer_cdm_manager.h"
6 6
7 #include "base/stl_util.h" 7 #include "base/stl_util.h"
8 #include "content/common/media/cdm_messages.h" 8 #include "content/common/media/cdm_messages.h"
9 #include "content/renderer/media/crypto/proxy_media_keys.h" 9 #include "content/renderer/media/crypto/proxy_media_keys.h"
10 10
11 namespace content { 11 namespace content {
12 12
13 // Maximum sizes for various EME API parameters. These are checks to prevent 13 // Maximum sizes for various EME API parameters. These are checks to prevent
14 // unnecessarily large messages from being passed around, and the sizes 14 // unnecessarily large messages from being passed around, and the sizes
15 // are somewhat arbitrary as the EME spec doesn't specify any limits. 15 // are somewhat arbitrary as the EME spec doesn't specify any limits.
16 const size_t kMaxWebSessionIdLength = 512; 16 const size_t kMaxWebSessionIdLength = 512;
17 const size_t kMaxSessionMessageLength = 10240; // 10 KB 17 const size_t kMaxSessionMessageLength = 10240; // 10 KB
18 18
19 RendererCdmManager::RendererCdmManager(RenderFrame* render_frame) 19 RendererCdmManager::RendererCdmManager(RenderFrame* render_frame)
20 : RenderFrameObserver(render_frame), 20 : RenderFrameObserver(render_frame),
21 next_cdm_id_(kInvalidCdmId + 1) { 21 next_cdm_id_(media::MediaKeys::kInvalidCdmId + 1) {
22 } 22 }
23 23
24 RendererCdmManager::~RendererCdmManager() { 24 RendererCdmManager::~RendererCdmManager() {
25 DCHECK(proxy_media_keys_map_.empty()) 25 DCHECK(proxy_media_keys_map_.empty())
26 << "RendererCdmManager is owned by RenderFrameImpl and is destroyed only " 26 << "RendererCdmManager is owned by RenderFrameImpl and is destroyed only "
27 "after all ProxyMediaKeys are destroyed and unregistered."; 27 "after all ProxyMediaKeys are destroyed and unregistered.";
28 } 28 }
29 29
30 bool RendererCdmManager::OnMessageReceived(const IPC::Message& msg) { 30 bool RendererCdmManager::OnMessageReceived(const IPC::Message& msg) {
31 bool handled = true; 31 bool handled = true;
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
120 uint32 session_id, 120 uint32 session_id,
121 media::MediaKeys::KeyError error_code, 121 media::MediaKeys::KeyError error_code,
122 uint32 system_code) { 122 uint32 system_code) {
123 ProxyMediaKeys* media_keys = GetMediaKeys(cdm_id); 123 ProxyMediaKeys* media_keys = GetMediaKeys(cdm_id);
124 if (media_keys) 124 if (media_keys)
125 media_keys->OnSessionError(session_id, error_code, system_code); 125 media_keys->OnSessionError(session_id, error_code, system_code);
126 } 126 }
127 127
128 int RendererCdmManager::RegisterMediaKeys(ProxyMediaKeys* media_keys) { 128 int RendererCdmManager::RegisterMediaKeys(ProxyMediaKeys* media_keys) {
129 int cdm_id = next_cdm_id_++; 129 int cdm_id = next_cdm_id_++;
130 DCHECK_NE(cdm_id, kInvalidCdmId); 130 DCHECK_NE(cdm_id, media::MediaKeys::kInvalidCdmId);
131 DCHECK(!ContainsKey(proxy_media_keys_map_, cdm_id)); 131 DCHECK(!ContainsKey(proxy_media_keys_map_, cdm_id));
132 proxy_media_keys_map_[cdm_id] = media_keys; 132 proxy_media_keys_map_[cdm_id] = media_keys;
133 return cdm_id; 133 return cdm_id;
134 } 134 }
135 135
136 void RendererCdmManager::UnregisterMediaKeys(int cdm_id) { 136 void RendererCdmManager::UnregisterMediaKeys(int cdm_id) {
137 DCHECK(ContainsKey(proxy_media_keys_map_, cdm_id)); 137 DCHECK(ContainsKey(proxy_media_keys_map_, cdm_id));
138 proxy_media_keys_map_.erase(cdm_id); 138 proxy_media_keys_map_.erase(cdm_id);
139 } 139 }
140 140
141 ProxyMediaKeys* RendererCdmManager::GetMediaKeys(int cdm_id) { 141 ProxyMediaKeys* RendererCdmManager::GetMediaKeys(int cdm_id) {
142 std::map<int, ProxyMediaKeys*>::iterator iter = 142 std::map<int, ProxyMediaKeys*>::iterator iter =
143 proxy_media_keys_map_.find(cdm_id); 143 proxy_media_keys_map_.find(cdm_id);
144 return (iter != proxy_media_keys_map_.end()) ? iter->second : NULL; 144 return (iter != proxy_media_keys_map_.end()) ? iter->second : NULL;
145 } 145 }
146 146
147 } // namespace content 147 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/media/crypto/renderer_cdm_manager.h ('k') | media/base/cdm_factory.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698