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

Side by Side Diff: media/base/media_keys.h

Issue 265993002: Add Promises for EME (Chromium side) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: latest CDM_5 Created 6 years, 7 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
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 MEDIA_BASE_MEDIA_KEYS_H_ 5 #ifndef MEDIA_BASE_MEDIA_KEYS_H_
6 #define MEDIA_BASE_MEDIA_KEYS_H_ 6 #define MEDIA_BASE_MEDIA_KEYS_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/callback.h" 12 #include "base/callback.h"
13 #include "base/memory/scoped_ptr.h" 13 #include "base/memory/scoped_ptr.h"
14 #include "media/base/media_export.h" 14 #include "media/base/media_export.h"
15 15
16 namespace media { 16 namespace media {
17 17
18 class Decryptor; 18 class Decryptor;
19 19
20 template <typename T>
21 class CdmPromise;
22
23 typedef CdmPromise<std::string> CdmNewSessionPromise;
24 typedef CdmPromise<void> CdmChangeSessionPromise;
ddorwin 2014/05/13 22:44:02 As earlier, "ChangeSession" is odd, and maybe not
jrummell 2014/05/15 22:38:09 Now SimpleCdmPromise (and NewSessionCdmPromise).
25
20 // Performs media key operations. 26 // Performs media key operations.
21 // 27 //
22 // All key operations are called on the renderer thread. Therefore, these calls 28 // All key operations are called on the renderer thread. Therefore, these calls
23 // should be fast and nonblocking; key events should be fired asynchronously. 29 // should be fast and nonblocking; key events should be fired asynchronously.
24 class MEDIA_EXPORT MediaKeys { 30 class MEDIA_EXPORT MediaKeys {
25 public: 31 public:
26 // Reported to UMA, so never reuse a value! 32 // Reported to UMA, so never reuse a value!
27 // Must be kept in sync with blink::WebMediaPlayerClient::MediaKeyErrorCode 33 // Must be kept in sync with blink::WebMediaPlayerClient::MediaKeyErrorCode
28 // (enforced in webmediaplayer_impl.cc). 34 // (enforced in webmediaplayer_impl.cc).
29 enum KeyError { 35 enum KeyError {
30 kUnknownError = 1, 36 kUnknownError = 1,
31 kClientError, 37 kClientError,
32 // The commented v0.1b values below have never been used. 38 // The commented v0.1b values below have never been used.
33 // kServiceError, 39 // kServiceError,
34 kOutputError = 4, 40 kOutputError = 4,
35 // kHardwareChangeError, 41 // kHardwareChangeError,
36 // kDomainError, 42 // kDomainError,
37 kMaxKeyError // Must be last and greater than any legit value. 43 kMaxKeyError // Must be last and greater than any legit value.
38 }; 44 };
39 45
46 // Must be kept in sync with cdm::MediaKeyException (enforced in
ddorwin 2014/05/13 22:44:02 This shouldn't be necessary. This must be a supers
jrummell 2014/05/15 22:38:09 Updated. Using a switch statement in clear_key_cdm
47 // clear_key_cdm.cc).
48 enum MediaKeysException {
49 MEDIA_KEYS_EXCEPTION_NO_MODIFICATION_ALLOWED_ERROR = 7,
50 MEDIA_KEYS_EXCEPTION_NOT_FOUND_ERROR = 8,
51 MEDIA_KEYS_EXCEPTION_NOT_SUPPORTED_ERROR = 9,
52 MEDIA_KEYS_EXCEPTION_INVALID_STATE_ERROR = 11,
53 MEDIA_KEYS_EXCEPTION_SYNTAX_ERROR = 12,
54 MEDIA_KEYS_EXCEPTION_INVALID_MODIFICATION_ERROR = 13,
55 MEDIA_KEYS_EXCEPTION_INVALID_ACCESS_ERROR = 15,
56 MEDIA_KEYS_EXCEPTION_SECURITY_ERROR = 18,
57 MEDIA_KEYS_EXCEPTION_ABORT_ERROR = 20,
58 MEDIA_KEYS_EXCEPTION_QUOTA_EXCEEDED_ERROR = 22,
59 MEDIA_KEYS_EXCEPTION_TIMEOUT_ERROR = 23,
60 MEDIA_KEYS_EXCEPTION_UNKNOWN_ERROR = 30,
ddorwin 2014/05/13 22:44:02 We don't actually need fixed integers for these si
jrummell 2014/05/15 22:38:09 Done.
61 MEDIA_KEYS_EXCEPTION_DATA_ERROR = 31,
62 MEDIA_KEYS_EXCEPTION_VERSION_ERROR = 32,
63 MEDIA_KEYS_EXCEPTION_NOT_READABLE_ERROR = 33,
64 MEDIA_KEYS_EXCEPTION_OPERATION_ERROR = 34,
65 MEDIA_KEYS_EXCEPTION_CLIENT_ERROR = 100,
66 MEDIA_KEYS_EXCEPTION_OUTPUT_ERROR = 101
67 };
68
69 // Type of license required when creating/loading a session.
70 // Must be kept in sync with the values specified in the spec:
ddorwin 2014/05/13 22:44:02 What do you mean in sync? The integer values shoul
jrummell 2014/05/15 22:38:09 Changed.
71 // https://dvcs.w3.org/hg/html-media/raw-file/default/encrypted-media/encrypte d-media.html#extensions
72 // Must be kept in sync with cdm::SessionType (enforced in clear_key_cdm.cc).
ddorwin 2014/05/13 22:44:02 ditto
jrummell 2014/05/15 22:38:09 Done.
73 enum SessionType {
74 SESSION_TYPE_TEMPORARY = 0,
75 SESSION_TYPE_PERSISTENT = 1
76 };
77
40 const static uint32 kInvalidSessionId = 0; 78 const static uint32 kInvalidSessionId = 0;
41 79
42 MediaKeys(); 80 MediaKeys();
43 virtual ~MediaKeys(); 81 virtual ~MediaKeys();
44 82
45 // Creates a session with the |content_type| and |init_data| provided. 83 // Creates a session with the |init_data_type|, |init_data| and |session_type|
46 // Returns true if a session is successfully created, false otherwise. 84 // provided.
47 // Note: UpdateSession() and ReleaseSession() should only be called after 85 // Note: UpdateSession() and ReleaseSession() should only be called after
48 // SessionCreatedCB is fired. 86 // |promise| is resolved.
49 // TODO(jrummell): Remove return value when prefixed API is removed. 87 virtual void CreateSession(const std::string& init_data_type,
50 // See http://crbug.com/342510
51 virtual bool CreateSession(uint32 session_id,
52 const std::string& content_type,
53 const uint8* init_data, 88 const uint8* init_data,
54 int init_data_length) = 0; 89 int init_data_length,
90 SessionType session_type,
91 scoped_ptr<CdmNewSessionPromise> promise) = 0;
55 92
56 // Loads a session with the |web_session_id| provided. 93 // Loads a session with the |web_session_id| provided.
57 // Note: UpdateSession() and ReleaseSession() should only be called after 94 // Note: UpdateSession() and ReleaseSession() should only be called after
58 // SessionCreatedCB is fired. 95 // |promise| is resolved.
59 virtual void LoadSession(uint32 session_id, 96 virtual void LoadSession(const std::string& web_session_id,
60 const std::string& web_session_id) = 0; 97 scoped_ptr<CdmNewSessionPromise> promise) = 0;
61 98
62 // Updates a session specified by |session_id| with |response|. 99 // Updates a session specified by |web_session_id| with |response|.
63 virtual void UpdateSession(uint32 session_id, 100 virtual void UpdateSession(const std::string& web_session_id,
64 const uint8* response, 101 const uint8* response,
65 int response_length) = 0; 102 int response_length,
103 scoped_ptr<CdmChangeSessionPromise> promise) = 0;
66 104
67 // Releases the session specified by |session_id|. 105 // Releases the session specified by |web_session_id|.
68 virtual void ReleaseSession(uint32 session_id) = 0; 106 virtual void ReleaseSession(const std::string& web_session_id,
107 scoped_ptr<CdmChangeSessionPromise> promise) = 0;
69 108
70 // Gets the Decryptor object associated with the MediaKeys. Returns NULL if 109 // Gets the Decryptor object associated with the MediaKeys. Returns NULL if
71 // no Decryptor object is associated. The returned object is only guaranteed 110 // no Decryptor object is associated. The returned object is only guaranteed
72 // to be valid during the MediaKeys' lifetime. 111 // to be valid during the MediaKeys' lifetime.
73 virtual Decryptor* GetDecryptor(); 112 virtual Decryptor* GetDecryptor();
74 113
75 private: 114 private:
76 DISALLOW_COPY_AND_ASSIGN(MediaKeys); 115 DISALLOW_COPY_AND_ASSIGN(MediaKeys);
77 }; 116 };
78 117
79 // Key event callbacks. See the spec for details: 118 // Key event callbacks. See the spec for details:
80 // https://dvcs.w3.org/hg/html-media/raw-file/default/encrypted-media/encrypted- media.html#event-summary 119 // https://dvcs.w3.org/hg/html-media/raw-file/default/encrypted-media/encrypted- media.html#event-summary
81 typedef base::Callback< 120 typedef base::Callback<void(const std::string& web_session_id,
82 void(uint32 session_id, const std::string& web_session_id)>
83 SessionCreatedCB;
84
85 typedef base::Callback<void(uint32 session_id,
86 const std::vector<uint8>& message, 121 const std::vector<uint8>& message,
87 const std::string& destination_url)> 122 const std::string& destination_url)>
88 SessionMessageCB; 123 SessionMessageCB;
89 124
90 typedef base::Callback<void(uint32 session_id)> SessionReadyCB; 125 typedef base::Callback<void(const std::string& web_session_id)> SessionReadyCB;
91 126
92 typedef base::Callback<void(uint32 session_id)> SessionClosedCB; 127 typedef base::Callback<void(const std::string& web_session_id)> SessionClosedCB;
93 128
94 typedef base::Callback<void(uint32 session_id, 129 typedef base::Callback<void(const std::string& web_session_id,
95 media::MediaKeys::KeyError error_code, 130 MediaKeys::MediaKeysException exception_code,
96 uint32 system_code)> SessionErrorCB; 131 uint32 system_code,
132 const std::string& error_message)> SessionErrorCB;
97 133
98 } // namespace media 134 } // namespace media
99 135
100 #endif // MEDIA_BASE_MEDIA_KEYS_H_ 136 #endif // MEDIA_BASE_MEDIA_KEYS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698