OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ | 5 #ifndef WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ |
6 #define WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ | 6 #define WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
12 | 12 |
13 namespace WebKit { | 13 namespace WebKit { |
14 class WebString; | 14 class WebString; |
15 } | 15 } |
16 | 16 |
17 namespace media { | |
18 class Decryptor; | |
19 class DecryptorClient; | |
20 } | |
21 | |
22 namespace webkit_media { | 17 namespace webkit_media { |
23 | 18 |
24 // Returns whether |key_sytem| is supported at all. | 19 // Returns whether |key_sytem| is supported at all. |
25 // Call IsSupportedKeySystemWithMediaMimeType() to determine whether a | 20 // Call IsSupportedKeySystemWithMediaMimeType() to determine whether a |
26 // |key_system| supports a specific type of media. | 21 // |key_system| supports a specific type of media. |
27 bool IsSupportedKeySystem(const WebKit::WebString& key_system); | 22 bool IsSupportedKeySystem(const WebKit::WebString& key_system); |
28 | 23 |
29 // Returns whether |key_sytem| supports the specified media type and codec(s). | 24 // Returns whether |key_sytem| supports the specified media type and codec(s). |
30 bool IsSupportedKeySystemWithMediaMimeType( | 25 bool IsSupportedKeySystemWithMediaMimeType( |
31 const std::string& mime_type, | 26 const std::string& mime_type, |
32 const std::vector<std::string>& codecs, | 27 const std::vector<std::string>& codecs, |
33 const std::string& key_system); | 28 const std::string& key_system); |
34 | 29 |
35 // Creates and returns a decryptor that corresponds to the |key_system|. | 30 // Returns whether AesDecryptor can be used for the given |key_system|. |
36 // Returns NULL if the |key_system| is not supported. | 31 bool CanUseAesDecryptor(const std::string& key_system); |
37 scoped_ptr<media::Decryptor> CreateDecryptor(const std::string& key_system, | 32 |
38 media::DecryptorClient* client); | 33 // Returns the plugin type given a |key_system|. |
| 34 // Returns an empty string if no plugin type is found for |key_system|. |
| 35 std::string GetPluginType(const std::string& key_system); |
39 | 36 |
40 } // namespace webkit_media | 37 } // namespace webkit_media |
41 | 38 |
42 #endif // WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ | 39 #endif // WEBKIT_MEDIA_CRYPTO_KEY_SYSTEMS_H_ |
OLD | NEW |