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

Side by Side Diff: content/renderer/media/crypto/proxy_decryptor.h

Issue 105383002: Rename EME WD call parameters (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years 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
OLDNEW
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 #ifndef CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_ 5 #ifndef CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
6 #define CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_ 6 #define CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
7 7
8 #include <map> 8 #include <map>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
(...skipping 17 matching lines...) Expand all
28 namespace content { 28 namespace content {
29 29
30 #if defined(OS_ANDROID) 30 #if defined(OS_ANDROID)
31 class RendererMediaPlayerManager; 31 class RendererMediaPlayerManager;
32 #endif // defined(OS_ANDROID) 32 #endif // defined(OS_ANDROID)
33 33
34 // ProxyDecryptor is for EME v0.1b only. It should not be used for the WD API. 34 // ProxyDecryptor is for EME v0.1b only. It should not be used for the WD API.
35 // A decryptor proxy that creates a real decryptor object on demand and 35 // A decryptor proxy that creates a real decryptor object on demand and
36 // forwards decryptor calls to it. 36 // forwards decryptor calls to it.
37 // 37 //
38 // Now that the Pepper API calls use reference ID to match responses with 38 // Now that the Pepper API calls use session ID to match responses with
39 // requests, this class maintains a mapping between reference ID and session ID. 39 // requests, this class maintains a mapping between session ID and web session
40 // Callers of this class expect session IDs in the responses. 40 // ID. Callers of this class expect web session IDs in the responses.
xhwang 2013/12/05 18:51:37 Can you briefly explain what a session ID is and w
jrummell 2013/12/06 23:42:35 Done.
41 // 41 //
42 // TODO(xhwang): Currently we don't support run-time switching among decryptor 42 // TODO(xhwang): Currently we don't support run-time switching among decryptor
43 // objects. Fix this when needed. 43 // objects. Fix this when needed.
44 // TODO(xhwang): The ProxyDecryptor is not a Decryptor. Find a better name! 44 // TODO(xhwang): The ProxyDecryptor is not a Decryptor. Find a better name!
45 class ProxyDecryptor { 45 class ProxyDecryptor {
46 public: 46 public:
47 // These are similar to the callbacks in media_keys.h, but pass back the 47 // These are similar to the callbacks in media_keys.h, but pass back the
48 // session ID rather than a reference ID. 48 // web session ID rather than a session ID.
ddorwin 2013/12/05 00:44:52 s/a/the internal/
jrummell 2013/12/06 23:42:35 Done.
49 typedef base::Callback<void(const std::string& session_id)> KeyAddedCB; 49 typedef base::Callback<void(const std::string& session_id)> KeyAddedCB;
50 typedef base::Callback<void(const std::string& session_id, 50 typedef base::Callback<void(const std::string& session_id,
51 media::MediaKeys::KeyError error_code, 51 media::MediaKeys::KeyError error_code,
52 int system_code)> KeyErrorCB; 52 int system_code)> KeyErrorCB;
53 typedef base::Callback<void(const std::string& session_id, 53 typedef base::Callback<void(const std::string& session_id,
54 const std::vector<uint8>& message, 54 const std::vector<uint8>& message,
55 const std::string& default_url)> KeyMessageCB; 55 const std::string& default_url)> KeyMessageCB;
56 56
57 ProxyDecryptor( 57 ProxyDecryptor(
58 #if defined(ENABLE_PEPPER_CDMS) 58 #if defined(ENABLE_PEPPER_CDMS)
(...skipping 20 matching lines...) Expand all
79 // May only be called after InitializeCDM() succeeds. 79 // May only be called after InitializeCDM() succeeds.
80 bool GenerateKeyRequest(const std::string& type, 80 bool GenerateKeyRequest(const std::string& type,
81 const uint8* init_data, 81 const uint8* init_data,
82 int init_data_length); 82 int init_data_length);
83 void AddKey(const uint8* key, int key_length, 83 void AddKey(const uint8* key, int key_length,
84 const uint8* init_data, int init_data_length, 84 const uint8* init_data, int init_data_length,
85 const std::string& session_id); 85 const std::string& session_id);
86 void CancelKeyRequest(const std::string& session_id); 86 void CancelKeyRequest(const std::string& session_id);
87 87
88 private: 88 private:
89 // This is reference_id <-> session_id map. 89 // This is session_id <-> web_session_id map.
ddorwin 2013/12/05 00:44:52 remove "This is ". (It's missing an article anyway
jrummell 2013/12/06 23:42:35 Done.
90 typedef std::map<uint32, std::string> SessionIdMap; 90 typedef std::map<uint32, std::string> SessionIdMap;
91 91
92 // Helper function to create MediaKeys to handle the given |key_system|. 92 // Helper function to create MediaKeys to handle the given |key_system|.
93 scoped_ptr<media::MediaKeys> CreateMediaKeys(const std::string& key_system, 93 scoped_ptr<media::MediaKeys> CreateMediaKeys(const std::string& key_system,
94 const GURL& frame_url); 94 const GURL& frame_url);
95 95
96 // Callbacks for firing session events. 96 // Callbacks for firing session events.
97 void OnSessionCreated(uint32 reference_id, const std::string& session_id); 97 void OnSessionCreated(uint32 session_id, const std::string& web_session_id);
98 void OnSessionMessage(uint32 reference_id, 98 void OnSessionMessage(uint32 session_id,
99 const std::vector<uint8>& message, 99 const std::vector<uint8>& message,
100 const std::string& default_url); 100 const std::string& default_url);
101 void OnSessionReady(uint32 reference_id); 101 void OnSessionReady(uint32 session_id);
102 void OnSessionClosed(uint32 reference_id); 102 void OnSessionClosed(uint32 session_id);
103 void OnSessionError(uint32 reference_id, 103 void OnSessionError(uint32 session_id,
104 media::MediaKeys::KeyError error_code, 104 media::MediaKeys::KeyError error_code,
105 int system_code); 105 int system_code);
106 106
107 // Helper function to determine reference_id for the provided |session_id|. 107 // Helper function to determine session_id for the provided |web_session_id|.
108 uint32 LookupReferenceId(const std::string& session_id); 108 uint32 LookupReferenceId(const std::string& web_session_id);
ddorwin 2013/12/05 00:44:52 LookupSessionId
jrummell 2013/12/06 23:42:35 Done.
109 109
110 // Helper function to determine session_id for the provided |reference_id|. 110 // Helper function to determine web_session_id for the provided |session_id|.
111 // The returned session_id is only valid on the main thread, and should be 111 // The returned web_session_id is only valid on the main thread, and should be
112 // stored by copy. 112 // stored by copy.
113 const std::string& LookupSessionId(uint32 reference_id); 113 const std::string& LookupSessionId(uint32 session_id);
ddorwin 2013/12/05 00:44:52 Lookup*Web*SessionId
jrummell 2013/12/06 23:42:35 Done.
114 114
115 base::WeakPtrFactory<ProxyDecryptor> weak_ptr_factory_; 115 base::WeakPtrFactory<ProxyDecryptor> weak_ptr_factory_;
116 116
117 #if defined(ENABLE_PEPPER_CDMS) 117 #if defined(ENABLE_PEPPER_CDMS)
118 // Callback for cleaning up a Pepper-based CDM. 118 // Callback for cleaning up a Pepper-based CDM.
119 void DestroyHelperPlugin(); 119 void DestroyHelperPlugin();
120 120
121 // Needed to create the PpapiDecryptor. 121 // Needed to create the PpapiDecryptor.
122 blink::WebMediaPlayerClient* web_media_player_client_; 122 blink::WebMediaPlayerClient* web_media_player_client_;
123 blink::WebFrame* web_frame_; 123 blink::WebFrame* web_frame_;
(...skipping 10 matching lines...) Expand all
134 KeyAddedCB key_added_cb_; 134 KeyAddedCB key_added_cb_;
135 KeyErrorCB key_error_cb_; 135 KeyErrorCB key_error_cb_;
136 KeyMessageCB key_message_cb_; 136 KeyMessageCB key_message_cb_;
137 137
138 // Protects the |decryptor_|. Note that |decryptor_| itself should be thread 138 // Protects the |decryptor_|. Note that |decryptor_| itself should be thread
139 // safe as per the Decryptor interface. 139 // safe as per the Decryptor interface.
140 base::Lock lock_; 140 base::Lock lock_;
141 141
142 media::DecryptorReadyCB decryptor_ready_cb_; 142 media::DecryptorReadyCB decryptor_ready_cb_;
143 143
144 // Reference IDs are used to uniquely track sessions so that CDM callbacks 144 // Session IDs are used to uniquely track sessions so that CDM callbacks
145 // can get mapped to the correct session ID. Reference ID should be unique 145 // can get mapped to the correct session ID. Session ID should be unique
146 // per renderer process for debugging purposes. 146 // per renderer process for debugging purposes.
147 static uint32 next_reference_id_; 147 static uint32 next_session_id_;
148 148
149 SessionIdMap sessions_; 149 SessionIdMap sessions_;
150 150
151 bool is_clear_key_; 151 bool is_clear_key_;
152 152
153 DISALLOW_COPY_AND_ASSIGN(ProxyDecryptor); 153 DISALLOW_COPY_AND_ASSIGN(ProxyDecryptor);
154 }; 154 };
155 155
156 } // namespace content 156 } // namespace content
157 157
158 #endif // CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_ 158 #endif // CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698