OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2013 Apple Inc. All rights reserved. | 2 * Copyright (C) 2013 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 10 matching lines...) Expand all Loading... | |
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF | 22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF |
23 * THE POSSIBILITY OF SUCH DAMAGE. | 23 * THE POSSIBILITY OF SUCH DAMAGE. |
24 */ | 24 */ |
25 | 25 |
26 #include "config.h" | 26 #include "config.h" |
27 #include "modules/encryptedmedia/MediaKeys.h" | 27 #include "modules/encryptedmedia/MediaKeys.h" |
28 | 28 |
29 #include "bindings/v8/ExceptionState.h" | 29 #include "bindings/v8/ExceptionState.h" |
30 #include "core/dom/ContextLifecycleObserver.h" | 30 #include "core/dom/ContextLifecycleObserver.h" |
31 #include "core/dom/Document.h" | |
31 #include "core/dom/ExecutionContext.h" | 32 #include "core/dom/ExecutionContext.h" |
32 #include "core/events/ThreadLocalEventNames.h" | 33 #include "core/events/ThreadLocalEventNames.h" |
33 #include "core/html/HTMLMediaElement.h" | 34 #include "core/html/HTMLMediaElement.h" |
34 #include "modules/encryptedmedia/MediaKeyMessageEvent.h" | 35 #include "modules/encryptedmedia/MediaKeyMessageEvent.h" |
36 #include "modules/encryptedmedia/MediaKeysClient.h" | |
37 #include "modules/encryptedmedia/MediaKeysController.h" | |
35 #include "platform/ContentType.h" | 38 #include "platform/ContentType.h" |
36 #include "platform/Logging.h" | 39 #include "platform/Logging.h" |
37 #include "platform/MIMETypeRegistry.h" | 40 #include "platform/MIMETypeRegistry.h" |
38 #include "platform/UUID.h" | 41 #include "platform/UUID.h" |
39 #include "public/platform/Platform.h" | 42 #include "public/platform/Platform.h" |
40 #include "public/platform/WebContentDecryptionModule.h" | 43 #include "public/platform/WebContentDecryptionModule.h" |
41 #include "wtf/HashSet.h" | 44 #include "wtf/HashSet.h" |
42 | 45 |
43 namespace WebCore { | 46 namespace WebCore { |
44 | 47 |
(...skipping 18 matching lines...) Expand all Loading... | |
63 } | 66 } |
64 | 67 |
65 // 2. If keySystem is not one of the user agent's supported Key Systems, thr ow a NotSupportedError and abort these steps. | 68 // 2. If keySystem is not one of the user agent's supported Key Systems, thr ow a NotSupportedError and abort these steps. |
66 if (!isKeySystemSupportedWithContentType(keySystem, "")) { | 69 if (!isKeySystemSupportedWithContentType(keySystem, "")) { |
67 exceptionState.throwDOMException(NotSupportedError, "The '" + keySystem + "' key system is not supported."); | 70 exceptionState.throwDOMException(NotSupportedError, "The '" + keySystem + "' key system is not supported."); |
68 return nullptr; | 71 return nullptr; |
69 } | 72 } |
70 | 73 |
71 // 3. Let cdm be the content decryption module corresponding to keySystem. | 74 // 3. Let cdm be the content decryption module corresponding to keySystem. |
72 // 4. Load cdm if necessary. | 75 // 4. Load cdm if necessary. |
73 OwnPtr<blink::WebContentDecryptionModule> cdm = adoptPtr(blink::Platform::cu rrent()->createContentDecryptionModule(keySystem)); | 76 Document* document = toDocument(context); |
77 ASSERT(document); | |
acolwell GONE FROM CHROMIUM
2014/03/17 23:34:45
nit: No need for an ASSERT here since you'll NPE o
jrummell
2014/03/18 17:05:31
Done.
| |
78 MediaKeysController* controller = MediaKeysController::from(document->page() ); | |
79 ASSERT(controller); | |
acolwell GONE FROM CHROMIUM
2014/03/17 23:34:45
ditto.
jrummell
2014/03/18 17:05:31
Done.
| |
80 OwnPtr<blink::WebContentDecryptionModule> cdm = adoptPtr(controller->createC ontentDecryptionModule(context, keySystem)); | |
eseidel
2014/03/17 23:48:03
Is this really the pattern for web/platform apis,
jrummell
2014/03/18 17:05:31
Moved the adoptPtr() to MediaKeysClientImpl (where
| |
74 if (!cdm) { | 81 if (!cdm) { |
75 exceptionState.throwDOMException(NotSupportedError, "A content decryptio n module could not be loaded for the '" + keySystem + "' key system."); | 82 exceptionState.throwDOMException(NotSupportedError, "A content decryptio n module could not be loaded for the '" + keySystem + "' key system."); |
76 return nullptr; | 83 return nullptr; |
77 } | 84 } |
78 | 85 |
79 // 5. Create a new MediaKeys object. | 86 // 5. Create a new MediaKeys object. |
80 // 5.1 Let the keySystem attribute be keySystem. | 87 // 5.1 Let the keySystem attribute be keySystem. |
81 // 6. Return the new object to the caller. | 88 // 6. Return the new object to the caller. |
82 return adoptRefWillBeNoop(new MediaKeys(context, keySystem, cdm.release())); | 89 return adoptRefWillBeNoop(new MediaKeys(context, keySystem, cdm.release())); |
83 } | 90 } |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
199 | 206 |
200 void MediaKeys::contextDestroyed() | 207 void MediaKeys::contextDestroyed() |
201 { | 208 { |
202 ContextLifecycleObserver::contextDestroyed(); | 209 ContextLifecycleObserver::contextDestroyed(); |
203 | 210 |
204 // We don't need the CDM anymore. | 211 // We don't need the CDM anymore. |
205 m_cdm.clear(); | 212 m_cdm.clear(); |
206 } | 213 } |
207 | 214 |
208 } | 215 } |
OLD | NEW |