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

Unified Diff: media/base/decryptor.h

Issue 10539150: Add Decryptor interface. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Move decryptor.* and decryptor_client.h to src/media/base/ Created 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | media/base/decryptor.cc » ('j') | media/crypto/aes_decryptor.h » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/base/decryptor.h
diff --git a/media/crypto/aes_decryptor.h b/media/base/decryptor.h
similarity index 50%
copy from media/crypto/aes_decryptor.h
copy to media/base/decryptor.h
index 3471c53bf9b9a63580f62fc62ef2301471958e6a..53666abb3db622297aa7ac7bf3c9481bc15b50f2 100644
--- a/media/crypto/aes_decryptor.h
+++ b/media/base/decryptor.h
@@ -2,32 +2,26 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef MEDIA_CRYPTO_AES_DECRYPTOR_H_
-#define MEDIA_CRYPTO_AES_DECRYPTOR_H_
+#ifndef MEDIA_BASE_DECRYPTOR_H_
+#define MEDIA_BASE_DECRYPTOR_H_
#include <string>
#include "base/basictypes.h"
-#include "base/hash_tables.h"
#include "base/memory/ref_counted.h"
-#include "base/synchronization/lock.h"
#include "media/base/media_export.h"
-namespace crypto {
-class SymmetricKey;
-}
-
namespace media {
class DecoderBuffer;
class DecryptorClient;
-// Decrypts AES encrypted buffer into unencrypted buffer.
+// Performs key operations and decrypts encrypted buffer.
// All public methods other than Decrypt() will be called on the renderer
// thread. Therefore, these calls should be fast and nonblocking, with key
// events fired asynchronously. Decrypt() will be called on the (video/audio)
// decoder thread synchronously.
-class MEDIA_EXPORT AesDecryptor {
+class MEDIA_EXPORT Decryptor {
public:
enum KeyError {
kUnknownError = 1,
@@ -40,14 +34,14 @@ class MEDIA_EXPORT AesDecryptor {
// The AesDecryptor does not take ownership of the |client|. The |client|
// must be valid throughout the lifetime of the AesDecryptor.
- explicit AesDecryptor(DecryptorClient* client);
- ~AesDecryptor();
+ explicit Decryptor(DecryptorClient* client);
+ virtual ~Decryptor();
// Generates a key request. The result of this call will be reported via the
// client's KeyMessage() or KeyError() methods.
- void GenerateKeyRequest(const std::string& key_system,
- const uint8* init_data,
- int init_data_length);
+ virtual void GenerateKeyRequest(const std::string& key_system,
+ const uint8* init_data,
+ int init_data_length) = 0;
// Adds a |key| to the key system. The key is not limited to a decryption key.
// It can be any data that the key system accepts, such as a license.
@@ -55,44 +49,32 @@ class MEDIA_EXPORT AesDecryptor {
// |key_id|, the older key will be replaced by the newer key.
// The result of this call will be reported via the client's KeyAdded(),
// KeyMessage() or KeyError() methods.
- 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);
+ 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) = 0;
// Cancels the key request specified by |session_id|.
- void CancelKeyRequest(const std::string& key_system,
- const std::string& session_id);
+ virtual void CancelKeyRequest(const std::string& key_system,
+ const std::string& session_id) = 0;
// Decrypts the |input| buffer, which should not be NULL.
// Returns a DecoderBuffer with the decrypted data if decryption succeeded.
// Returns NULL if decryption failed.
- scoped_refptr<DecoderBuffer> Decrypt(
- const scoped_refptr<DecoderBuffer>& input);
-
- private:
- // KeyMap owns the crypto::SymmetricKey* and must delete them when they are
- // not needed any more.
- typedef base::hash_map<std::string, crypto::SymmetricKey*> KeyMap;
+ virtual scoped_refptr<DecoderBuffer> Decrypt(
+ const scoped_refptr<DecoderBuffer>& input) = 0;
- // Since only Decrypt() is called off the renderer thread, we only need to
- // protect |key_map_|, the only member variable that is shared between
- // Decrypt() and other methods.
- KeyMap key_map_; // Protected by the |key_map_lock_|.
- base::Lock key_map_lock_; // Protects the |key_map_|.
+ protected:
+ DecryptorClient* client() const;
+ private:
DecryptorClient* client_;
scherkus (not reviewing) 2012/06/19 03:03:24 I really don't like the idea of having this here o
xhwang 2012/06/19 16:29:53 Done.
- // Make session ID unique per renderer by making it static.
- // TODO(xhwang): Make session ID more strictly defined if needed:
- // https://www.w3.org/Bugs/Public/show_bug.cgi?id=16739#c0
- static uint32 next_session_id_;
-
- DISALLOW_COPY_AND_ASSIGN(AesDecryptor);
+ DISALLOW_COPY_AND_ASSIGN(Decryptor);
};
} // namespace media
-#endif // MEDIA_CRYPTO_AES_DECRYPTOR_H_
+#endif // MEDIA_BASE_DECRYPTOR_H_
« no previous file with comments | « no previous file | media/base/decryptor.cc » ('j') | media/crypto/aes_decryptor.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698