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
|
<!doctype html>
<html>
<head>
<meta charset=utf-8>
<title>Encrypted Media Extensions: persistent-license, retrieve and playback, ClearKey</title>
<link rel="help" href="https://w3c.github.io/encrypted-media/">
<!-- Helper scripts for Encrypted Media Extensions tests -->
<script src=/encrypted-media/util/utils.js></script>
<script src=/encrypted-media/util/fetch.js></script>
<script src=/encrypted-media/util/utf8.js></script>
<script src=/encrypted-media/util/testmediasource.js></script>
</head>
<body>
<div id='log'></div>
<div id='video'>
<video id="videoelement" width="200px"></video>
</div>
<script>
// Wait for a message from the main window with details of our task
window.addEventListener( 'message', function( event ) {
var config = event.data.config,
configuration = { initDataTypes: [ config.initDataType ],
audioCapabilities: [ { contentType: config.audioType } ],
videoCapabilities: [ { contentType: config.videoType } ],
sessionTypes: [ 'persistent-license' ] },
assertions = [ ];
var _mediaKeySession;
config.video = document.getElementById('videoelement');
function onComplete() {
window.opener.postMessage(assertions, '*');
}
function onFailure(error) {
assertions.push( { actual: false, expected: true, message: error.toString() } );
onComplete();
}
function onTimeupdate(event) {
if ( config.video.currentTime > ( config.duration || 1 ) ) {
config.video.pause();
_mediaKeySession.close()
}
}
navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] )
.then(function(access) {
return access.createMediaKeys();
}).then(function(mediaKeys) {
config.video.setMediaKeys(mediaKeys);
config.video.addEventListener('timeupdate', onTimeupdate, true);
_mediaKeySession = mediaKeys.createSession( 'persistent-license' );
_mediaKeySession.closed.then(onComplete);
return _mediaKeySession.load(event.data.sessionId);
}).then(function( success ) {
if ( !success ) throw new DOMException( 'Could not load session' );
return testmediasource(config);
}).then(function(source) {
config.video.src = URL.createObjectURL(source);
config.video.play();
})
.catch(onFailure);
} );
</script>
</body>
</html>
|