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

Side by Side Diff: ppapi/cpp/private/content_decryptor_private.h

Issue 10827280: Add PPAPI decryptor implementation. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix yet another link error, and rebase once again. Created 8 years, 4 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
« no previous file with comments | « no previous file | ppapi/cpp/private/content_decryptor_private.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef PPAPI_CPP_PRIVATE_CONTENT_DECRYPTOR_PRIVATE_H_
6 #define PPAPI_CPP_PRIVATE_CONTENT_DECRYPTOR_PRIVATE_H_
7
8 #include "ppapi/c/private/ppb_content_decryptor_private.h"
9 #include "ppapi/c/private/ppp_content_decryptor_private.h"
10
11 #include "ppapi/cpp/dev/buffer_dev.h"
12 #include "ppapi/cpp/instance_handle.h"
13 #include "ppapi/cpp/var.h"
14 #include "ppapi/cpp/var_array_buffer.h"
15
16 namespace pp {
17
18 class Instance;
19
20 class ContentDecryptor_Private {
21 public:
22 explicit ContentDecryptor_Private(Instance* instance);
23 virtual ~ContentDecryptor_Private();
24
25 // PPP_ContentDecryptor_Private functions exposed as virtual functions
26 // for you to override.
27 // TODO(tomfinegan): This could be optimized to pass pp::Var instead of
28 // strings. The change would allow the CDM wrapper to reuse vars when
29 // replying to the browser.
30 virtual bool GenerateKeyRequest(const std::string& key_system,
31 pp::VarArrayBuffer init_data) = 0;
32 virtual bool AddKey(const std::string& session_id,
33 pp::VarArrayBuffer key) = 0;
34 virtual bool CancelKeyRequest(const std::string& session_id) = 0;
35 virtual bool Decrypt(pp::Buffer_Dev encrypted_buffer,
36 int32_t request_id) = 0;
37 virtual bool DecryptAndDecode(pp::Buffer_Dev encrypted_buffer,
38 int32_t request_id) = 0;
39
40 // PPB_ContentDecryptor_Private methods for passing data from the decryptor
41 // to the browser.
42 void NeedKey(const std::string& key_system,
43 const std::string& session_id,
44 pp::VarArrayBuffer init_data);
45 void KeyAdded(const std::string& key_system,
46 const std::string& session_id);
47 void KeyMessage(const std::string& key_system,
48 const std::string& session_id,
49 pp::Buffer_Dev message,
50 const std::string& default_url);
51 void KeyError(const std::string& key_system,
52 const std::string& session_id,
53 int32_t media_error,
54 int32_t system_code);
55 void DeliverBlock(pp::Buffer_Dev decrypted_block,
56 int32_t request_id);
57 void DeliverFrame(pp::Buffer_Dev decrypted_frame,
58 int32_t request_id);
59 void DeliverSamples(pp::Buffer_Dev decrypted_samples,
60 int32_t request_id);
61
62 private:
63 InstanceHandle associated_instance_;
64 };
65
66 } // namespace pp
67
68 #endif // PPAPI_CPP_PRIVATE_CONTENT_DECRYPTOR_PRIVATE_H_
OLDNEW
« no previous file with comments | « no previous file | ppapi/cpp/private/content_decryptor_private.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698