1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef WEBKIT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
#define WEBKIT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
#include <string>
#include "base/memory/scoped_ptr.h"
#include "base/memory/weak_ptr.h"
#include "base/synchronization/lock.h"
#include "media/base/decryptor.h"
#include "media/base/media_keys.h"
namespace WebKit {
class WebFrame;
class WebMediaPlayerClient;
}
namespace webkit_media {
// A decryptor proxy that creates a real decryptor object on demand and
// forwards decryptor calls to it.
// TODO(xhwang): Currently we don't support run-time switching among decryptor
// objects. Fix this when needed.
// TODO(xhwang): The ProxyDecryptor is not a Decryptor. Find a better name!
class ProxyDecryptor : public media::MediaKeys {
public:
ProxyDecryptor(WebKit::WebMediaPlayerClient* web_media_player_client,
WebKit::WebFrame* web_frame,
const media::KeyAddedCB& key_added_cb,
const media::KeyErrorCB& key_error_cb,
const media::KeyMessageCB& key_message_cb,
const media::NeedKeyCB& need_key_cb);
virtual ~ProxyDecryptor();
// Requests the ProxyDecryptor to notify the decryptor when it's ready through
// the |decryptor_ready_cb| provided.
// If |decryptor_ready_cb| is null, the existing callback will be fired with
// NULL immediately and reset.
void SetDecryptorReadyCB(const media::DecryptorReadyCB& decryptor_ready_cb);
// MediaKeys implementation.
virtual bool GenerateKeyRequest(const std::string& key_system,
const std::string& type,
const uint8* init_data,
int init_data_length) OVERRIDE;
virtual void AddKey(const std::string& key_system,
const uint8* key, int key_length,
const uint8* init_data, int init_data_length,
const std::string& session_id) OVERRIDE;
virtual void CancelKeyRequest(const std::string& key_system,
const std::string& session_id) OVERRIDE;
private:
// Helper functions to create decryptors to handle the given |key_system|.
scoped_ptr<media::Decryptor> CreateDecryptor(const std::string& key_system);
#if defined(ENABLE_PEPPER_CDMS)
scoped_ptr<media::Decryptor> CreatePpapiDecryptor(
const std::string& key_system);
// Callback for cleaning up a Pepper CDM.
void DestroyHelperPlugin();
#endif // defined(ENABLE_PEPPER_CDMS)
// Callbacks for firing key events.
void KeyAdded(const std::string& key_system, const std::string& session_id);
void KeyError(const std::string& key_system,
const std::string& session_id,
media::MediaKeys::KeyError error_code,
int system_code);
void KeyMessage(const std::string& key_system,
const std::string& session_id,
const std::string& message,
const std::string& default_url);
void NeedKey(const std::string& key_system,
const std::string& session_id,
const std::string& type,
scoped_ptr<uint8[]> init_data, int init_data_size);
// Needed to create the PpapiDecryptor.
WebKit::WebMediaPlayerClient* web_media_player_client_;
WebKit::WebFrame* web_frame_;
// Callbacks for firing key events.
media::KeyAddedCB key_added_cb_;
media::KeyErrorCB key_error_cb_;
media::KeyMessageCB key_message_cb_;
media::NeedKeyCB need_key_cb_;
// Protects the |decryptor_|. Note that |decryptor_| itself should be thread
// safe as per the Decryptor interface.
base::Lock lock_;
media::DecryptorReadyCB decryptor_ready_cb_;
// The real decryptor that does decryption for the ProxyDecryptor.
// This pointer is protected by the |lock_|.
scoped_ptr<media::Decryptor> decryptor_;
base::WeakPtrFactory<ProxyDecryptor> weak_ptr_factory_;
DISALLOW_COPY_AND_ASSIGN(ProxyDecryptor);
};
} // namespace webkit_media
#endif // WEBKIT_RENDERER_MEDIA_CRYPTO_PROXY_DECRYPTOR_H_
|