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

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

Issue 295103015: Separate RendererCdmManager from RendererMediaPlayerManager. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase again Created 6 years, 6 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 | Annotate | Revision Log
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_ANDROID_PROXY_MEDIA_KEYS_H_ 5 #ifndef CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_MEDIA_KEYS_H_
6 #define CONTENT_RENDERER_MEDIA_ANDROID_PROXY_MEDIA_KEYS_H_ 6 #define CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_MEDIA_KEYS_H_
7 7
8 #include "base/basictypes.h" 8 #include "base/basictypes.h"
9 #include "media/base/media_keys.h" 9 #include "media/base/media_keys.h"
10 10
11 class GURL; 11 class GURL;
12 12
13 namespace content { 13 namespace content {
14 14
15 class RendererMediaPlayerManager; 15 class RendererCdmManager;
16 16
17 // A MediaKeys proxy that wraps the EME part of RendererMediaPlayerManager. 17 // A MediaKeys proxy that wraps the EME part of RendererCdmManager.
18 // TODO(xhwang): Instead of accessing RendererMediaPlayerManager directly, let
19 // RendererMediaPlayerManager return a MediaKeys object that can be used by
20 // ProxyDecryptor directly. Then we can remove this class!
21 class ProxyMediaKeys : public media::MediaKeys { 18 class ProxyMediaKeys : public media::MediaKeys {
22 public: 19 public:
23 static scoped_ptr<ProxyMediaKeys> Create( 20 static scoped_ptr<ProxyMediaKeys> Create(
24 const std::string& key_system, 21 const std::string& key_system,
25 const GURL& security_origin, 22 const GURL& security_origin,
26 RendererMediaPlayerManager* manager, 23 RendererCdmManager* manager,
27 const media::SessionCreatedCB& session_created_cb, 24 const media::SessionCreatedCB& session_created_cb,
28 const media::SessionMessageCB& session_message_cb, 25 const media::SessionMessageCB& session_message_cb,
29 const media::SessionReadyCB& session_ready_cb, 26 const media::SessionReadyCB& session_ready_cb,
30 const media::SessionClosedCB& session_closed_cb, 27 const media::SessionClosedCB& session_closed_cb,
31 const media::SessionErrorCB& session_error_cb); 28 const media::SessionErrorCB& session_error_cb);
32 29
33 virtual ~ProxyMediaKeys(); 30 virtual ~ProxyMediaKeys();
34 31
35 // MediaKeys implementation. 32 // MediaKeys implementation.
36 virtual bool CreateSession(uint32 session_id, 33 virtual bool CreateSession(uint32 session_id,
(...skipping 14 matching lines...) Expand all
51 const GURL& destination_url); 48 const GURL& destination_url);
52 void OnSessionReady(uint32 session_id); 49 void OnSessionReady(uint32 session_id);
53 void OnSessionClosed(uint32 session_id); 50 void OnSessionClosed(uint32 session_id);
54 void OnSessionError(uint32 session_id, 51 void OnSessionError(uint32 session_id,
55 media::MediaKeys::KeyError error_code, 52 media::MediaKeys::KeyError error_code,
56 uint32 system_code); 53 uint32 system_code);
57 54
58 int GetCdmId() const; 55 int GetCdmId() const;
59 56
60 private: 57 private:
61 ProxyMediaKeys(RendererMediaPlayerManager* manager, 58 ProxyMediaKeys(RendererCdmManager* manager,
62 const media::SessionCreatedCB& session_created_cb, 59 const media::SessionCreatedCB& session_created_cb,
63 const media::SessionMessageCB& session_message_cb, 60 const media::SessionMessageCB& session_message_cb,
64 const media::SessionReadyCB& session_ready_cb, 61 const media::SessionReadyCB& session_ready_cb,
65 const media::SessionClosedCB& session_closed_cb, 62 const media::SessionClosedCB& session_closed_cb,
66 const media::SessionErrorCB& session_error_cb); 63 const media::SessionErrorCB& session_error_cb);
67 64
68 void InitializeCdm(const std::string& key_system, 65 void InitializeCdm(const std::string& key_system,
69 const GURL& security_origin); 66 const GURL& security_origin);
70 67
71 // CDM ID should be unique per renderer process. 68 // CDM ID should be unique per renderer frame.
72 // TODO(xhwang): Use uint32 to prevent undefined overflow behavior. 69 // TODO(xhwang): Use uint32 to prevent undefined overflow behavior.
70 // TODO(xhwang): Let the |manager_| generate CDM IDs.
73 static int next_cdm_id_; 71 static int next_cdm_id_;
74 72
75 RendererMediaPlayerManager* manager_; 73 RendererCdmManager* manager_;
76 int cdm_id_; 74 int cdm_id_;
77 media::SessionCreatedCB session_created_cb_; 75 media::SessionCreatedCB session_created_cb_;
78 media::SessionMessageCB session_message_cb_; 76 media::SessionMessageCB session_message_cb_;
79 media::SessionReadyCB session_ready_cb_; 77 media::SessionReadyCB session_ready_cb_;
80 media::SessionClosedCB session_closed_cb_; 78 media::SessionClosedCB session_closed_cb_;
81 media::SessionErrorCB session_error_cb_; 79 media::SessionErrorCB session_error_cb_;
82 80
83 DISALLOW_COPY_AND_ASSIGN(ProxyMediaKeys); 81 DISALLOW_COPY_AND_ASSIGN(ProxyMediaKeys);
84 }; 82 };
85 83
86 } // namespace content 84 } // namespace content
87 85
88 #endif // CONTENT_RENDERER_MEDIA_ANDROID_PROXY_MEDIA_KEYS_H_ 86 #endif // CONTENT_RENDERER_MEDIA_CRYPTO_PROXY_MEDIA_KEYS_H_
OLDNEW
« no previous file with comments | « content/renderer/media/crypto/proxy_decryptor.cc ('k') | content/renderer/media/crypto/proxy_media_keys.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698