rx-player 3.26.2 → 3.27.0-dev.20220317

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (500) hide show
  1. package/.github/workflows/perfs.yml +22 -0
  2. package/CHANGELOG.md +33 -1
  3. package/FILES.md +5 -4
  4. package/VERSION +1 -1
  5. package/dist/_esm5.processed/compat/browser_detection.d.ts +4 -2
  6. package/dist/_esm5.processed/compat/browser_detection.js +4 -2
  7. package/dist/_esm5.processed/compat/eme/close_session.d.ts +11 -5
  8. package/dist/_esm5.processed/compat/eme/close_session.js +144 -36
  9. package/dist/_esm5.processed/compat/eme/custom_media_keys/index.d.ts +3 -5
  10. package/dist/_esm5.processed/compat/eme/custom_media_keys/index.js +27 -24
  11. package/dist/_esm5.processed/compat/eme/custom_media_keys/old_webkit_media_keys.js +53 -34
  12. package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys.js +43 -41
  13. package/dist/_esm5.processed/compat/eme/generate_key_request.d.ts +2 -3
  14. package/dist/_esm5.processed/compat/eme/generate_key_request.js +22 -26
  15. package/dist/_esm5.processed/compat/eme/load_session.d.ts +1 -2
  16. package/dist/_esm5.processed/compat/eme/load_session.js +68 -17
  17. package/dist/_esm5.processed/compat/event_listeners.js +2 -1
  18. package/dist/_esm5.processed/compat/should_favour_custom_safari_EME.js +2 -2
  19. package/dist/_esm5.processed/config.d.ts +166 -1080
  20. package/dist/_esm5.processed/config.js +17 -1119
  21. package/dist/_esm5.processed/core/abr/bandwidth_estimator.js +4 -1
  22. package/dist/_esm5.processed/core/abr/buffer_based_chooser.d.ts +28 -6
  23. package/dist/_esm5.processed/core/abr/buffer_based_chooser.js +63 -12
  24. package/dist/_esm5.processed/core/abr/network_analyzer.d.ts +1 -1
  25. package/dist/_esm5.processed/core/abr/network_analyzer.js +2 -1
  26. package/dist/_esm5.processed/core/abr/pending_requests_store.js +3 -5
  27. package/dist/_esm5.processed/core/abr/representation_estimator.d.ts +1 -1
  28. package/dist/_esm5.processed/core/abr/representation_estimator.js +2 -2
  29. package/dist/_esm5.processed/core/api/get_player_state.js +1 -1
  30. package/dist/_esm5.processed/core/api/index.d.ts +2 -1
  31. package/dist/_esm5.processed/core/api/media_element_track_choice_manager.d.ts +6 -0
  32. package/dist/_esm5.processed/core/api/media_element_track_choice_manager.js +22 -4
  33. package/dist/_esm5.processed/core/api/option_utils.d.ts +3 -1
  34. package/dist/_esm5.processed/core/api/option_utils.js +19 -6
  35. package/dist/_esm5.processed/core/api/playback_observer.js +5 -1
  36. package/dist/_esm5.processed/core/api/public_api.d.ts +82 -71
  37. package/dist/_esm5.processed/core/api/public_api.js +72 -33
  38. package/dist/_esm5.processed/core/api/track_choice_manager.d.ts +6 -6
  39. package/dist/_esm5.processed/core/{eme → decrypt}/__tests__/__global__/utils.d.ts +7 -51
  40. package/dist/_esm5.processed/core/{eme → decrypt}/__tests__/__global__/utils.js +30 -75
  41. package/dist/_esm5.processed/core/{eme → decrypt}/attach_media_keys.d.ts +12 -12
  42. package/dist/_esm5.processed/core/decrypt/attach_media_keys.js +104 -0
  43. package/dist/_esm5.processed/core/{eme/clear_eme_session.d.ts → decrypt/clear_on_stop.d.ts} +3 -4
  44. package/dist/_esm5.processed/core/decrypt/clear_on_stop.js +41 -0
  45. package/dist/_esm5.processed/core/decrypt/content_decryptor.d.ts +216 -0
  46. package/dist/_esm5.processed/core/decrypt/content_decryptor.js +866 -0
  47. package/dist/_esm5.processed/core/{eme/get_session.d.ts → decrypt/create_or_load_session.d.ts} +28 -26
  48. package/dist/_esm5.processed/core/decrypt/create_or_load_session.js +124 -0
  49. package/dist/_esm5.processed/core/{eme → decrypt}/create_session.d.ts +22 -19
  50. package/dist/_esm5.processed/core/decrypt/create_session.js +174 -0
  51. package/dist/_esm5.processed/core/decrypt/dispose_decryption_resources.d.ts +21 -0
  52. package/dist/_esm5.processed/core/decrypt/dispose_decryption_resources.js +81 -0
  53. package/dist/_esm5.processed/core/{eme → decrypt}/find_key_system.d.ts +11 -14
  54. package/dist/_esm5.processed/core/decrypt/find_key_system.js +300 -0
  55. package/dist/_esm5.processed/core/{eme → decrypt}/get_current_key_system.d.ts +0 -0
  56. package/dist/_esm5.processed/core/{eme → decrypt}/get_current_key_system.js +1 -1
  57. package/dist/_esm5.processed/core/{eme → decrypt}/get_media_keys.d.ts +13 -5
  58. package/dist/_esm5.processed/core/decrypt/get_media_keys.js +153 -0
  59. package/dist/_esm5.processed/core/{eme → decrypt}/index.d.ts +5 -6
  60. package/dist/_esm5.processed/core/{eme → decrypt}/index.js +5 -5
  61. package/dist/_esm5.processed/core/{eme → decrypt}/init_media_keys.d.ts +6 -4
  62. package/dist/_esm5.processed/core/decrypt/init_media_keys.js +82 -0
  63. package/dist/_esm5.processed/core/decrypt/session_events_listener.d.ts +77 -0
  64. package/dist/_esm5.processed/core/{eme → decrypt}/session_events_listener.js +25 -24
  65. package/dist/_esm5.processed/core/{eme → decrypt}/set_server_certificate.d.ts +15 -6
  66. package/dist/_esm5.processed/core/decrypt/set_server_certificate.js +141 -0
  67. package/dist/_esm5.processed/core/{eme → decrypt}/types.d.ts +120 -242
  68. package/dist/_esm5.processed/core/{eme → decrypt}/types.js +0 -0
  69. package/dist/_esm5.processed/core/{eme → decrypt}/utils/are_init_values_compatible.d.ts +3 -3
  70. package/dist/_esm5.processed/core/{eme → decrypt}/utils/are_init_values_compatible.js +5 -5
  71. package/dist/_esm5.processed/core/{eme → decrypt/utils}/check_key_statuses.d.ts +2 -2
  72. package/dist/_esm5.processed/core/{eme → decrypt/utils}/check_key_statuses.js +4 -3
  73. package/dist/_esm5.processed/core/{eme/utils/close_session.d.ts → decrypt/utils/clean_old_loaded_sessions.d.ts} +8 -7
  74. package/dist/_esm5.processed/core/decrypt/utils/clean_old_loaded_sessions.js +85 -0
  75. package/dist/_esm5.processed/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.d.ts +1 -1
  76. package/dist/_esm5.processed/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.js +2 -2
  77. package/dist/_esm5.processed/core/{eme → decrypt/utils}/get_drm_system_id.d.ts +0 -0
  78. package/dist/_esm5.processed/core/{eme → decrypt/utils}/get_drm_system_id.js +1 -1
  79. package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.d.ts +69 -0
  80. package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.js +99 -0
  81. package/dist/_esm5.processed/core/{eme → decrypt}/utils/is_session_usable.d.ts +0 -1
  82. package/dist/_esm5.processed/core/{eme → decrypt}/utils/is_session_usable.js +4 -5
  83. package/dist/_esm5.processed/core/decrypt/utils/key_id_comparison.d.ts +44 -0
  84. package/dist/_esm5.processed/core/decrypt/utils/key_id_comparison.js +77 -0
  85. package/dist/_esm5.processed/core/decrypt/utils/key_session_record.d.ts +104 -0
  86. package/dist/_esm5.processed/core/decrypt/utils/key_session_record.js +155 -0
  87. package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.d.ts +108 -0
  88. package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.js +303 -0
  89. package/dist/_esm5.processed/core/{eme → decrypt/utils}/media_keys_infos_store.d.ts +4 -4
  90. package/dist/_esm5.processed/core/{eme → decrypt/utils}/media_keys_infos_store.js +0 -0
  91. package/dist/_esm5.processed/core/{eme → decrypt}/utils/persistent_sessions_store.d.ts +8 -18
  92. package/dist/_esm5.processed/core/{eme → decrypt}/utils/persistent_sessions_store.js +119 -97
  93. package/dist/_esm5.processed/core/{eme/utils/init_data_container.d.ts → decrypt/utils/serializable_bytes.d.ts} +8 -5
  94. package/dist/_esm5.processed/core/{eme/utils/init_data_container.js → decrypt/utils/serializable_bytes.js} +9 -9
  95. package/dist/_esm5.processed/core/{eme → decrypt/utils}/server_certificate_store.d.ts +1 -1
  96. package/dist/_esm5.processed/core/{eme → decrypt/utils}/server_certificate_store.js +1 -1
  97. package/dist/_esm5.processed/core/fetchers/manifest/manifest_fetcher.d.ts +4 -4
  98. package/dist/_esm5.processed/core/fetchers/manifest/manifest_fetcher.js +3 -3
  99. package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher.d.ts +2 -2
  100. package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher.js +6 -2
  101. package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher_creator.js +1 -1
  102. package/dist/_esm5.processed/core/fetchers/utils/try_urls_with_backoff.js +1 -1
  103. package/dist/_esm5.processed/core/init/get_initial_time.js +1 -1
  104. package/dist/_esm5.processed/core/init/initialize_directfile.d.ts +3 -3
  105. package/dist/_esm5.processed/core/init/initialize_directfile.js +11 -17
  106. package/dist/_esm5.processed/core/init/initialize_media_source.d.ts +5 -3
  107. package/dist/_esm5.processed/core/init/initialize_media_source.js +18 -69
  108. package/dist/_esm5.processed/core/init/link_drm_and_content.d.ts +61 -0
  109. package/dist/_esm5.processed/core/init/link_drm_and_content.js +94 -0
  110. package/dist/_esm5.processed/core/init/manifest_update_scheduler.d.ts +4 -4
  111. package/dist/_esm5.processed/core/init/manifest_update_scheduler.js +2 -1
  112. package/dist/_esm5.processed/core/init/stall_avoider.js +1 -1
  113. package/dist/_esm5.processed/core/init/stream_events_emitter/are_same_stream_events.d.ts +4 -4
  114. package/dist/_esm5.processed/core/init/stream_events_emitter/stream_events_emitter.js +1 -1
  115. package/dist/_esm5.processed/core/init/stream_events_emitter/types.d.ts +2 -2
  116. package/dist/_esm5.processed/core/init/types.d.ts +2 -4
  117. package/dist/_esm5.processed/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.js +1 -1
  118. package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/html_text_segment_buffer.d.ts +3 -3
  119. package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/html_text_segment_buffer.js +3 -1
  120. package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/text_track_cues_store.js +32 -31
  121. package/dist/_esm5.processed/core/segment_buffers/implementations/text/native/native_text_segment_buffer.d.ts +4 -4
  122. package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.d.ts +17 -1
  123. package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.js +22 -5
  124. package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.d.ts +2 -1
  125. package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.js +6 -3
  126. package/dist/_esm5.processed/core/stream/events_generators.d.ts +8 -3
  127. package/dist/_esm5.processed/core/stream/events_generators.js +3 -2
  128. package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.d.ts +1 -0
  129. package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.js +3 -3
  130. package/dist/_esm5.processed/core/stream/period/create_empty_adaptation_stream.js +2 -1
  131. package/dist/_esm5.processed/core/stream/period/get_adaptation_switch_strategy.js +1 -1
  132. package/dist/_esm5.processed/core/stream/period/period_stream.d.ts +2 -1
  133. package/dist/_esm5.processed/core/stream/period/period_stream.js +3 -3
  134. package/dist/_esm5.processed/core/stream/representation/force_garbage_collection.js +5 -6
  135. package/dist/_esm5.processed/core/stream/representation/get_buffer_status.d.ts +6 -1
  136. package/dist/_esm5.processed/core/stream/representation/get_buffer_status.js +12 -9
  137. package/dist/_esm5.processed/core/stream/representation/get_needed_segments.d.ts +19 -14
  138. package/dist/_esm5.processed/core/stream/representation/get_needed_segments.js +86 -10
  139. package/dist/_esm5.processed/core/stream/representation/get_segment_priority.js +1 -1
  140. package/dist/_esm5.processed/core/stream/representation/push_media_segment.js +3 -3
  141. package/dist/_esm5.processed/core/stream/representation/representation_stream.d.ts +6 -0
  142. package/dist/_esm5.processed/core/stream/representation/representation_stream.js +19 -8
  143. package/dist/_esm5.processed/core/stream/types.d.ts +1 -1
  144. package/dist/_esm5.processed/default_config.d.ts +1114 -0
  145. package/dist/_esm5.processed/default_config.js +1145 -0
  146. package/dist/_esm5.processed/errors/request_error.js +3 -1
  147. package/dist/_esm5.processed/experimental/index.d.ts +2 -0
  148. package/dist/_esm5.processed/experimental/index.js +2 -0
  149. package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/push_data.d.ts +1 -0
  150. package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/thumbnail_loader.d.ts +2 -2
  151. package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/thumbnail_loader.js +2 -4
  152. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/probeMediaConfiguration.d.ts +1 -1
  153. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/probeMediaConfiguration.js +1 -1
  154. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.js +1 -2
  155. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.js +1 -2
  156. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/types.d.ts +3 -3
  157. package/dist/_esm5.processed/features/features_object.js +1 -1
  158. package/dist/_esm5.processed/features/initialize_features.js +1 -1
  159. package/dist/_esm5.processed/features/list/eme.d.ts +3 -3
  160. package/dist/_esm5.processed/features/list/eme.js +5 -5
  161. package/dist/_esm5.processed/features/types.d.ts +3 -3
  162. package/dist/_esm5.processed/manifest/adaptation.d.ts +2 -2
  163. package/dist/_esm5.processed/manifest/adaptation.js +3 -1
  164. package/dist/_esm5.processed/manifest/manifest.d.ts +10 -23
  165. package/dist/_esm5.processed/manifest/manifest.js +10 -74
  166. package/dist/_esm5.processed/manifest/period.d.ts +3 -3
  167. package/dist/_esm5.processed/manifest/representation.d.ts +37 -5
  168. package/dist/_esm5.processed/manifest/representation_index/types.d.ts +18 -18
  169. package/dist/_esm5.processed/manifest/types.d.ts +3 -3
  170. package/dist/_esm5.processed/parsers/manifest/dash/common/get_hdr_information.d.ts +1 -1
  171. package/dist/_esm5.processed/parsers/manifest/dash/common/get_periods_time_infos.d.ts +3 -3
  172. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/base.d.ts +6 -6
  173. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_init_segment.d.ts +3 -3
  174. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_segments_from_timeline.d.ts +2 -2
  175. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/is_period_fulfilled.js +1 -2
  176. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/list.d.ts +14 -14
  177. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/template.d.ts +17 -17
  178. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/template.js +1 -2
  179. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_elements.js +1 -1
  180. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.d.ts +28 -20
  181. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.js +20 -5
  182. package/dist/_esm5.processed/parsers/manifest/dash/common/infer_adaptation_type.d.ts +2 -2
  183. package/dist/_esm5.processed/parsers/manifest/dash/common/manifest_bounds_calculator.d.ts +1 -1
  184. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_adaptation_sets.d.ts +17 -35
  185. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_adaptation_sets.js +109 -96
  186. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_mpd.d.ts +8 -8
  187. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_mpd.js +1 -2
  188. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_periods.d.ts +18 -27
  189. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_periods.js +25 -23
  190. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representation_index.d.ts +21 -15
  191. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representation_index.js +19 -19
  192. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representations.d.ts +15 -38
  193. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representations.js +8 -8
  194. package/dist/_esm5.processed/parsers/manifest/dash/node_parser_types.d.ts +30 -30
  195. package/dist/_esm5.processed/parsers/manifest/dash/parsers_types.d.ts +3 -3
  196. package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/dash-wasm-parser.js +1 -1
  197. package/dist/_esm5.processed/parsers/manifest/metaplaylist/metaplaylist_parser.d.ts +2 -2
  198. package/dist/_esm5.processed/parsers/manifest/smooth/create_parser.d.ts +7 -7
  199. package/dist/_esm5.processed/parsers/manifest/smooth/create_parser.js +1 -0
  200. package/dist/_esm5.processed/parsers/manifest/smooth/representation_index.d.ts +8 -8
  201. package/dist/_esm5.processed/parsers/manifest/types.d.ts +28 -28
  202. package/dist/_esm5.processed/parsers/manifest/utils/clear_timeline_from_position.d.ts +3 -2
  203. package/dist/_esm5.processed/parsers/manifest/utils/clear_timeline_from_position.js +15 -5
  204. package/dist/_esm5.processed/parsers/manifest/utils/index_helpers.d.ts +2 -2
  205. package/dist/_esm5.processed/parsers/manifest/utils/update_segment_timeline.d.ts +11 -1
  206. package/dist/_esm5.processed/parsers/manifest/utils/update_segment_timeline.js +31 -19
  207. package/dist/_esm5.processed/parsers/texttracks/webvtt/html/to_html.d.ts +2 -2
  208. package/dist/_esm5.processed/parsers/texttracks/webvtt/parse_cue_block.d.ts +1 -1
  209. package/dist/_esm5.processed/public_types.d.ts +2 -2
  210. package/dist/_esm5.processed/transports/dash/add_segment_integrity_checks_to_loader.js +2 -1
  211. package/dist/_esm5.processed/transports/dash/image_pipelines.js +4 -1
  212. package/dist/_esm5.processed/transports/dash/init_segment_loader.js +1 -1
  213. package/dist/_esm5.processed/transports/dash/manifest_parser.js +1 -1
  214. package/dist/_esm5.processed/transports/dash/segment_loader.d.ts +2 -2
  215. package/dist/_esm5.processed/transports/dash/segment_loader.js +2 -2
  216. package/dist/_esm5.processed/transports/dash/segment_parser.d.ts +1 -1
  217. package/dist/_esm5.processed/transports/dash/segment_parser.js +6 -3
  218. package/dist/_esm5.processed/transports/dash/text_loader.d.ts +1 -1
  219. package/dist/_esm5.processed/transports/dash/text_loader.js +1 -1
  220. package/dist/_esm5.processed/transports/dash/text_parser.d.ts +1 -1
  221. package/dist/_esm5.processed/transports/dash/text_parser.js +8 -2
  222. package/dist/_esm5.processed/transports/local/segment_loader.d.ts +1 -2
  223. package/dist/_esm5.processed/transports/local/segment_loader.js +1 -1
  224. package/dist/_esm5.processed/transports/local/segment_parser.js +4 -1
  225. package/dist/_esm5.processed/transports/local/text_parser.js +8 -2
  226. package/dist/_esm5.processed/transports/metaplaylist/manifest_loader.d.ts +1 -1
  227. package/dist/_esm5.processed/transports/metaplaylist/pipelines.js +1 -1
  228. package/dist/_esm5.processed/transports/smooth/pipelines.js +69 -11
  229. package/dist/_esm5.processed/transports/smooth/segment_loader.d.ts +0 -1
  230. package/dist/_esm5.processed/transports/smooth/segment_loader.js +2 -2
  231. package/dist/_esm5.processed/transports/types.d.ts +58 -30
  232. package/dist/_esm5.processed/transports/utils/call_custom_manifest_loader.js +1 -1
  233. package/dist/_esm5.processed/transports/utils/generate_manifest_loader.d.ts +1 -1
  234. package/dist/_esm5.processed/utils/cancellable_sleep.js +1 -1
  235. package/dist/_esm5.processed/utils/cast_to_observable.d.ts +1 -2
  236. package/dist/_esm5.processed/utils/cast_to_observable.js +1 -1
  237. package/dist/_esm5.processed/utils/deep_merge.d.ts +12 -0
  238. package/dist/_esm5.processed/utils/deep_merge.js +53 -0
  239. package/dist/_esm5.processed/utils/reference.d.ts +29 -0
  240. package/dist/_esm5.processed/utils/reference.js +72 -24
  241. package/dist/_esm5.processed/utils/request/fetch.d.ts +4 -5
  242. package/dist/_esm5.processed/utils/request/fetch.js +8 -6
  243. package/dist/_esm5.processed/utils/request/xhr.d.ts +6 -6
  244. package/dist/_esm5.processed/utils/request/xhr.js +3 -2
  245. package/dist/_esm5.processed/utils/rx-from_cancellable_promise.d.ts +1 -2
  246. package/dist/_esm5.processed/utils/rx-from_cancellable_promise.js +7 -2
  247. package/dist/_esm5.processed/utils/task_canceller.d.ts +5 -3
  248. package/dist/_esm5.processed/utils/task_canceller.js +3 -3
  249. package/dist/rx-player.js +5242 -3190
  250. package/dist/rx-player.min.js +1 -1
  251. package/dummy +1 -0
  252. package/{dist/_esm5.processed/core/eme/dispose_eme.d.ts → experimental/index.d.ts} +1 -4
  253. package/{dist/_esm5.processed/core/eme/dispose_media_keys.d.ts → experimental/index.js} +1 -6
  254. package/package.json +33 -36
  255. package/scripts/build/templates/experimental/index.d.ts +16 -0
  256. package/scripts/build/templates/experimental/index.js +16 -0
  257. package/scripts/doc-generator/generate_header_html.js +6 -7
  258. package/scripts/doc-generator/generate_page_html.js +3 -4
  259. package/scripts/doc-generator/generate_page_list_html.js +4 -5
  260. package/scripts/doc-generator/generate_sidebar_html.js +4 -7
  261. package/scripts/doc-generator/utils.js +0 -11
  262. package/scripts/generate_demo_list.js +3 -3
  263. package/scripts/generate_documentation_list.js +3 -3
  264. package/scripts/launch_static_server.js +127 -67
  265. package/scripts/run_standalone_demo.js +1 -0
  266. package/scripts/start_demo_web_server.js +1 -0
  267. package/sonar-project.properties +1 -1
  268. package/src/README.md +6 -6
  269. package/src/compat/__tests__/fullscreen.test.ts +7 -7
  270. package/src/compat/__tests__/is_vtt_cue.test.ts +1 -1
  271. package/src/compat/__tests__/should_favour_custom_safari_EME.test.ts +45 -5
  272. package/src/compat/browser_detection.ts +4 -2
  273. package/src/compat/eme/close_session.ts +90 -56
  274. package/src/compat/eme/custom_media_keys/ie11_media_keys.ts +1 -1
  275. package/src/compat/eme/custom_media_keys/index.ts +28 -41
  276. package/src/compat/eme/custom_media_keys/old_webkit_media_keys.ts +63 -46
  277. package/src/compat/eme/custom_media_keys/webkit_media_keys.ts +51 -49
  278. package/src/compat/eme/generate_key_request.ts +25 -33
  279. package/src/compat/eme/load_session.ts +29 -31
  280. package/src/compat/event_listeners.ts +2 -1
  281. package/src/compat/should_favour_custom_safari_EME.ts +5 -2
  282. package/src/config.ts +17 -1210
  283. package/src/core/README.md +1 -1
  284. package/src/core/abr/__tests__/{get_estimate_from_buffer_levels.test.ts → buffer_based_chooser.test.ts} +94 -123
  285. package/src/core/abr/bandwidth_estimator.ts +4 -4
  286. package/src/core/abr/buffer_based_chooser.ts +85 -20
  287. package/src/core/abr/network_analyzer.ts +6 -7
  288. package/src/core/abr/pending_requests_store.ts +3 -5
  289. package/src/core/abr/representation_estimator.ts +6 -3
  290. package/src/core/api/__tests__/get_player_state.test.ts +3 -3
  291. package/src/core/api/__tests__/option_utils.test.ts +17 -17
  292. package/src/core/api/get_player_state.ts +1 -1
  293. package/src/core/api/index.ts +3 -0
  294. package/src/core/api/media_element_track_choice_manager.ts +22 -3
  295. package/src/core/api/option_utils.ts +37 -20
  296. package/src/core/api/playback_observer.ts +12 -8
  297. package/src/core/api/public_api.ts +152 -112
  298. package/src/core/api/track_choice_manager.ts +10 -9
  299. package/src/core/decrypt/README.md +22 -0
  300. package/src/core/decrypt/__tests__/__global__/get_license.test.ts +418 -0
  301. package/src/core/decrypt/__tests__/__global__/init_data.test.ts +675 -0
  302. package/src/core/{eme → decrypt}/__tests__/__global__/media_key_system_access.test.ts +99 -92
  303. package/src/core/decrypt/__tests__/__global__/media_keys.test.ts +156 -0
  304. package/src/core/decrypt/__tests__/__global__/server_certificate.test.ts +262 -0
  305. package/src/core/{eme → decrypt}/__tests__/__global__/utils.ts +36 -103
  306. package/src/core/{eme → decrypt}/attach_media_keys.ts +49 -56
  307. package/src/core/decrypt/clear_on_stop.ts +48 -0
  308. package/src/core/decrypt/content_decryptor.ts +1158 -0
  309. package/src/core/decrypt/create_or_load_session.ts +130 -0
  310. package/src/core/decrypt/create_session.ts +175 -0
  311. package/src/core/decrypt/dispose_decryption_resources.ts +39 -0
  312. package/src/core/{eme → decrypt}/find_key_system.ts +126 -134
  313. package/src/core/{eme → decrypt}/get_current_key_system.ts +1 -1
  314. package/src/core/decrypt/get_media_keys.ts +145 -0
  315. package/src/core/{eme → decrypt}/index.ts +11 -8
  316. package/src/core/decrypt/init_media_keys.ts +51 -0
  317. package/src/core/{eme → decrypt}/session_events_listener.ts +93 -55
  318. package/src/core/decrypt/set_server_certificate.ts +104 -0
  319. package/src/core/{eme → decrypt}/types.ts +129 -259
  320. package/src/core/{eme → decrypt}/utils/__tests__/are_init_values_compatible.test.ts +1 -1
  321. package/src/core/{eme → decrypt/utils}/__tests__/clean_old_loaded_sessions.test.ts +29 -71
  322. package/src/core/{eme → decrypt/utils}/__tests__/clean_old_stored_persistent_info.test.ts +6 -6
  323. package/src/core/{eme → decrypt}/utils/are_init_values_compatible.ts +9 -9
  324. package/src/core/{eme → decrypt/utils}/check_key_statuses.ts +6 -5
  325. package/{dist/_esm5.processed/core/eme/clean_old_loaded_sessions.js → src/core/decrypt/utils/clean_old_loaded_sessions.ts} +20 -20
  326. package/src/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.ts +3 -3
  327. package/src/core/{eme → decrypt/utils}/get_drm_system_id.ts +1 -1
  328. package/src/core/decrypt/utils/init_data_values_container.ts +119 -0
  329. package/src/core/{eme → decrypt}/utils/is_session_usable.ts +4 -5
  330. package/src/core/decrypt/utils/key_id_comparison.ts +82 -0
  331. package/src/core/decrypt/utils/key_session_record.ts +175 -0
  332. package/src/core/decrypt/utils/loaded_sessions_store.ts +318 -0
  333. package/src/core/{eme → decrypt/utils}/media_keys_infos_store.ts +4 -4
  334. package/src/core/{eme → decrypt}/utils/persistent_sessions_store.ts +122 -104
  335. package/src/core/{eme/utils/init_data_container.ts → decrypt/utils/serializable_bytes.ts} +8 -5
  336. package/src/core/{eme → decrypt/utils}/server_certificate_store.ts +2 -2
  337. package/src/core/fetchers/manifest/manifest_fetcher.ts +9 -9
  338. package/src/core/fetchers/segment/segment_fetcher.ts +10 -7
  339. package/src/core/fetchers/segment/segment_fetcher_creator.ts +2 -2
  340. package/src/core/fetchers/utils/try_urls_with_backoff.ts +1 -1
  341. package/src/core/init/.initialize_media_source.ts.un~ +0 -0
  342. package/src/core/init/get_initial_time.ts +2 -1
  343. package/src/core/init/initialize_directfile.ts +19 -22
  344. package/src/core/init/initialize_media_source.ts +43 -106
  345. package/src/core/init/link_drm_and_content.ts +176 -0
  346. package/src/core/init/manifest_update_scheduler.ts +12 -10
  347. package/src/core/init/stall_avoider.ts +6 -5
  348. package/src/core/init/stream_events_emitter/are_same_stream_events.ts +4 -4
  349. package/src/core/init/stream_events_emitter/stream_events_emitter.ts +2 -1
  350. package/src/core/init/stream_events_emitter/types.ts +2 -2
  351. package/src/core/init/types.ts +1 -39
  352. package/src/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.ts +2 -1
  353. package/src/core/segment_buffers/implementations/text/html/html_text_segment_buffer.ts +6 -7
  354. package/src/core/segment_buffers/implementations/text/html/text_track_cues_store.ts +32 -31
  355. package/src/core/segment_buffers/implementations/text/native/native_text_segment_buffer.ts +4 -4
  356. package/src/core/segment_buffers/inventory/segment_inventory.ts +42 -8
  357. package/src/core/stream/adaptation/adaptation_stream.ts +7 -1
  358. package/src/core/stream/events_generators.ts +9 -4
  359. package/src/core/stream/orchestrator/stream_orchestrator.ts +9 -4
  360. package/src/core/stream/period/create_empty_adaptation_stream.ts +2 -1
  361. package/src/core/stream/period/get_adaptation_switch_strategy.ts +1 -1
  362. package/src/core/stream/period/period_stream.ts +5 -2
  363. package/src/core/stream/representation/force_garbage_collection.ts +5 -7
  364. package/src/core/stream/representation/get_buffer_status.ts +28 -16
  365. package/src/core/stream/representation/get_needed_segments.ts +124 -28
  366. package/src/core/stream/representation/get_segment_priority.ts +1 -2
  367. package/src/core/stream/representation/push_media_segment.ts +3 -2
  368. package/src/core/stream/representation/representation_stream.ts +30 -7
  369. package/src/core/stream/types.ts +1 -1
  370. package/src/default_config.ts +1241 -0
  371. package/src/errors/request_error.ts +4 -1
  372. package/src/experimental/index.ts +5 -0
  373. package/src/experimental/tools/VideoThumbnailLoader/push_data.ts +1 -0
  374. package/src/experimental/tools/VideoThumbnailLoader/thumbnail_loader.ts +5 -7
  375. package/src/experimental/tools/mediaCapabilitiesProber/__tests__/probers/DRMInfos.test.ts +3 -10
  376. package/src/experimental/tools/mediaCapabilitiesProber/__tests__/probers/HDCPPolicy.test.ts +4 -4
  377. package/src/experimental/tools/mediaCapabilitiesProber/api/index.ts +1 -1
  378. package/src/experimental/tools/mediaCapabilitiesProber/api/probeMediaConfiguration.ts +3 -3
  379. package/src/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.ts +1 -2
  380. package/src/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.ts +1 -2
  381. package/src/experimental/tools/mediaCapabilitiesProber/types.ts +3 -3
  382. package/src/features/__tests__/initialize_features.test.ts +2 -2
  383. package/src/features/features_object.ts +1 -1
  384. package/src/features/initialize_features.ts +1 -1
  385. package/src/features/list/__tests__/eme.test.ts +5 -5
  386. package/src/features/list/eme.ts +5 -5
  387. package/src/features/types.ts +3 -10
  388. package/src/manifest/adaptation.ts +6 -4
  389. package/src/manifest/manifest.ts +16 -86
  390. package/src/manifest/period.ts +3 -3
  391. package/src/manifest/representation.ts +38 -5
  392. package/src/manifest/representation_index/types.ts +18 -18
  393. package/src/manifest/types.ts +3 -3
  394. package/src/parsers/manifest/dash/common/__tests__/manifest_bounds_calculator.test.ts +1 -0
  395. package/src/parsers/manifest/dash/common/get_hdr_information.ts +1 -1
  396. package/src/parsers/manifest/dash/common/get_periods_time_infos.ts +3 -3
  397. package/src/parsers/manifest/dash/common/indexes/base.ts +6 -6
  398. package/src/parsers/manifest/dash/common/indexes/get_init_segment.ts +4 -2
  399. package/src/parsers/manifest/dash/common/indexes/get_segments_from_timeline.ts +2 -2
  400. package/src/parsers/manifest/dash/common/indexes/is_period_fulfilled.ts +1 -2
  401. package/src/parsers/manifest/dash/common/indexes/list.ts +14 -14
  402. package/src/parsers/manifest/dash/common/indexes/template.ts +18 -18
  403. package/src/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_elements.ts +1 -1
  404. package/src/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.ts +51 -23
  405. package/src/parsers/manifest/dash/common/infer_adaptation_type.ts +2 -2
  406. package/src/parsers/manifest/dash/common/manifest_bounds_calculator.ts +1 -1
  407. package/src/parsers/manifest/dash/common/parse_adaptation_sets.ts +167 -134
  408. package/src/parsers/manifest/dash/common/parse_mpd.ts +9 -10
  409. package/src/parsers/manifest/dash/common/parse_periods.ts +80 -79
  410. package/src/parsers/manifest/dash/common/parse_representation_index.ts +83 -75
  411. package/src/parsers/manifest/dash/common/parse_representations.ts +44 -63
  412. package/src/parsers/manifest/dash/node_parser_types.ts +30 -30
  413. package/src/parsers/manifest/dash/parsers_types.ts +3 -3
  414. package/src/parsers/manifest/dash/wasm-parser/ts/dash-wasm-parser.ts +1 -1
  415. package/src/parsers/manifest/metaplaylist/metaplaylist_parser.ts +4 -4
  416. package/src/parsers/manifest/smooth/create_parser.ts +24 -21
  417. package/src/parsers/manifest/smooth/representation_index.ts +14 -14
  418. package/src/parsers/manifest/types.ts +28 -28
  419. package/src/parsers/manifest/utils/__tests__/update_segment_timeline.test.ts +31 -33
  420. package/src/parsers/manifest/utils/clear_timeline_from_position.ts +15 -6
  421. package/src/parsers/manifest/utils/index_helpers.ts +2 -2
  422. package/src/parsers/manifest/utils/update_segment_timeline.ts +32 -21
  423. package/src/parsers/texttracks/webvtt/html/__tests__/create_styled_element.test.ts +1 -0
  424. package/src/parsers/texttracks/webvtt/html/to_html.ts +2 -2
  425. package/src/parsers/texttracks/webvtt/parse_cue_block.ts +1 -1
  426. package/src/public_types.ts +5 -1
  427. package/src/transports/dash/add_segment_integrity_checks_to_loader.ts +2 -2
  428. package/src/transports/dash/image_pipelines.ts +4 -1
  429. package/src/transports/dash/init_segment_loader.ts +1 -1
  430. package/src/transports/dash/manifest_parser.ts +1 -1
  431. package/src/transports/dash/segment_loader.ts +7 -7
  432. package/src/transports/dash/segment_parser.ts +8 -1
  433. package/src/transports/dash/text_loader.ts +2 -2
  434. package/src/transports/dash/text_parser.ts +11 -1
  435. package/src/transports/local/segment_loader.ts +4 -4
  436. package/src/transports/local/segment_parser.ts +4 -0
  437. package/src/transports/local/text_parser.ts +8 -0
  438. package/src/transports/metaplaylist/manifest_loader.ts +1 -1
  439. package/src/transports/metaplaylist/pipelines.ts +1 -1
  440. package/src/transports/smooth/pipelines.ts +29 -16
  441. package/src/transports/smooth/segment_loader.ts +8 -8
  442. package/src/transports/types.ts +59 -30
  443. package/src/transports/utils/call_custom_manifest_loader.ts +6 -6
  444. package/src/transports/utils/generate_manifest_loader.ts +1 -1
  445. package/src/utils/__tests__/deep_merge.test.ts +48 -0
  446. package/src/utils/__tests__/flat_map.test.ts +12 -7
  447. package/src/utils/cancellable_sleep.ts +1 -1
  448. package/src/utils/cast_to_observable.ts +1 -2
  449. package/src/utils/deep_merge.ts +46 -0
  450. package/src/utils/reference.ts +116 -23
  451. package/src/utils/request/fetch.ts +17 -15
  452. package/src/utils/request/xhr.ts +11 -8
  453. package/src/utils/rx-from_cancellable_promise.ts +8 -4
  454. package/src/utils/task_canceller.ts +6 -4
  455. package/tsconfig.json +1 -2
  456. package/tsconfig.modules.json +1 -2
  457. package/dist/_esm5.processed/core/abr/get_estimate_from_buffer_levels.d.ts +0 -29
  458. package/dist/_esm5.processed/core/abr/get_estimate_from_buffer_levels.js +0 -67
  459. package/dist/_esm5.processed/core/eme/attach_media_keys.js +0 -57
  460. package/dist/_esm5.processed/core/eme/clean_old_loaded_sessions.d.ts +0 -59
  461. package/dist/_esm5.processed/core/eme/clear_eme_session.js +0 -50
  462. package/dist/_esm5.processed/core/eme/create_session.js +0 -126
  463. package/dist/_esm5.processed/core/eme/dispose_eme.js +0 -23
  464. package/dist/_esm5.processed/core/eme/dispose_media_keys.js +0 -36
  465. package/dist/_esm5.processed/core/eme/eme_manager.d.ts +0 -31
  466. package/dist/_esm5.processed/core/eme/eme_manager.js +0 -278
  467. package/dist/_esm5.processed/core/eme/find_key_system.js +0 -243
  468. package/dist/_esm5.processed/core/eme/get_media_keys.js +0 -85
  469. package/dist/_esm5.processed/core/eme/get_session.js +0 -68
  470. package/dist/_esm5.processed/core/eme/init_media_keys.js +0 -66
  471. package/dist/_esm5.processed/core/eme/session_events_listener.d.ts +0 -41
  472. package/dist/_esm5.processed/core/eme/set_server_certificate.js +0 -85
  473. package/dist/_esm5.processed/core/eme/utils/close_session.js +0 -81
  474. package/dist/_esm5.processed/core/eme/utils/init_data_store.d.ts +0 -115
  475. package/dist/_esm5.processed/core/eme/utils/init_data_store.js +0 -181
  476. package/dist/_esm5.processed/core/eme/utils/loaded_sessions_store.d.ts +0 -123
  477. package/dist/_esm5.processed/core/eme/utils/loaded_sessions_store.js +0 -173
  478. package/dist/_esm5.processed/core/init/create_eme_manager.d.ts +0 -34
  479. package/dist/_esm5.processed/core/init/create_eme_manager.js +0 -52
  480. package/src/core/abr/get_estimate_from_buffer_levels.ts +0 -85
  481. package/src/core/eme/README.md +0 -26
  482. package/src/core/eme/__tests__/__global__/get_license.test.ts +0 -414
  483. package/src/core/eme/__tests__/__global__/init_data.test.ts +0 -908
  484. package/src/core/eme/__tests__/__global__/media_keys.test.ts +0 -266
  485. package/src/core/eme/__tests__/__global__/server_certificate.test.ts +0 -364
  486. package/src/core/eme/__tests__/init_media_keys.test.ts +0 -182
  487. package/src/core/eme/clean_old_loaded_sessions.ts +0 -96
  488. package/src/core/eme/clear_eme_session.ts +0 -62
  489. package/src/core/eme/create_session.ts +0 -187
  490. package/src/core/eme/dispose_eme.ts +0 -25
  491. package/src/core/eme/dispose_media_keys.ts +0 -46
  492. package/src/core/eme/eme_manager.ts +0 -387
  493. package/src/core/eme/get_media_keys.ts +0 -141
  494. package/src/core/eme/get_session.ts +0 -135
  495. package/src/core/eme/init_media_keys.ts +0 -106
  496. package/src/core/eme/set_server_certificate.ts +0 -115
  497. package/src/core/eme/utils/close_session.ts +0 -113
  498. package/src/core/eme/utils/init_data_store.ts +0 -234
  499. package/src/core/eme/utils/loaded_sessions_store.ts +0 -235
  500. package/src/core/init/create_eme_manager.ts +0 -95
@@ -1,908 +0,0 @@
1
- /**
2
- * Copyright 2015 CANAL+ Group
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
-
17
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
18
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
19
- /* eslint-disable @typescript-eslint/no-var-requires */
20
- /* eslint-disable @typescript-eslint/no-unsafe-call */
21
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
22
- /* eslint-disable @typescript-eslint/no-unsafe-return */
23
- /* eslint-disable @typescript-eslint/no-unsafe-argument */
24
- /* eslint-disable @typescript-eslint/restrict-template-expressions */
25
- /* eslint-disable @typescript-eslint/no-explicit-any */
26
-
27
- import {
28
- EMPTY,
29
- Subject,
30
- takeUntil,
31
- } from "rxjs";
32
- import { IEncryptedEventData } from "../../../../compat/eme";
33
- import { IContentProtection } from "../../types";
34
- import {
35
- expectEncryptedEventReceived,
36
- expectInitDataIgnored,
37
- expectLicenseRequestMessage,
38
- MediaKeySessionImpl,
39
- MediaKeysImpl,
40
- // MediaKeySystemAccessImpl,
41
- mockCompat,
42
- // testEMEManagerImmediateError,
43
- } from "./utils";
44
-
45
- describe("core - eme - global tests - init data", () => {
46
- /** Default video element used in our tests. */
47
- const videoElt = document.createElement("video");
48
-
49
- const getLicenseSpy = jest.fn(() => {
50
- return new Promise(() => { /* noop */ });
51
- });
52
-
53
- /** Default keySystems configuration used in our tests. */
54
- const ksConfig = [{ type: "com.widevine.alpha", getLicense: getLicenseSpy }];
55
-
56
- beforeEach(() => {
57
- jest.resetModules();
58
- jest.restoreAllMocks();
59
- });
60
-
61
- /* eslint-disable max-len */
62
- it("should create a session and generate a request when init data is sent through the arguments", (done) => {
63
- /* eslint-enable max-len */
64
-
65
- // == mocks ==
66
- const { generateKeyRequestSpy } = mockCompat();
67
- const mediaKeySession = new MediaKeySessionImpl();
68
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
69
- .mockReturnValue(mediaKeySession);
70
-
71
- // == vars ==
72
- let eventsReceived = 0;
73
- const initDataSubject = new Subject<IContentProtection>();
74
- const initData = new Uint8Array([54, 55, 75]);
75
- const kill$ = new Subject<void>();
76
-
77
- // == test ==
78
- const EMEManager = require("../../eme_manager").default;
79
- EMEManager(videoElt, ksConfig, initDataSubject)
80
- .pipe(takeUntil(kill$))
81
- .subscribe((evt : any) => {
82
- switch (++eventsReceived) {
83
- case 1:
84
- expect(evt.type).toEqual("created-media-keys");
85
- evt.value.canAttachMediaKeys.setValue(true);
86
- break;
87
- case 2:
88
- expect(evt.type).toEqual("attached-media-keys");
89
- break;
90
- case 3:
91
- expectLicenseRequestMessage(evt,
92
- { type: "cenc",
93
- values: [ { systemId: "15",
94
- data: initData } ] });
95
- setTimeout(() => {
96
- kill$.next();
97
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
98
- expect(createSessionSpy).toHaveBeenCalledWith("temporary");
99
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
100
- expect(generateKeyRequestSpy)
101
- .toHaveBeenCalledWith(mediaKeySession, "cenc", initData);
102
- done();
103
- }, 10);
104
- break;
105
- default:
106
- throw new Error("Unexpected event");
107
- }
108
- });
109
- initDataSubject.next({ type: "cenc",
110
- values: [ { systemId: "15", data: initData } ] });
111
- });
112
-
113
- /* eslint-disable max-len */
114
- it("should ignore init data already sent through the argument", (done) => {
115
- /* eslint-enable max-len */
116
-
117
- // == mocks ==
118
- const { generateKeyRequestSpy } = mockCompat();
119
- const mediaKeySession = new MediaKeySessionImpl();
120
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
121
- .mockReturnValue(mediaKeySession);
122
-
123
- // == vars ==
124
- const initDataSubject = new Subject<IContentProtection>();
125
- let eventsReceived = 0;
126
- const initData = new Uint8Array([54, 55, 75]);
127
- const kill$ = new Subject<void>();
128
-
129
- // == test ==
130
- const EMEManager = require("../../eme_manager").default;
131
- EMEManager(videoElt, ksConfig, initDataSubject)
132
- .pipe(takeUntil(kill$))
133
- .subscribe((evt : any) => {
134
- switch (++eventsReceived) {
135
- case 1:
136
- expect(evt.type).toEqual("created-media-keys");
137
- evt.value.canAttachMediaKeys.setValue(true);
138
- break;
139
- case 2:
140
- expect(evt.type).toEqual("attached-media-keys");
141
- break;
142
- case 3:
143
- expectLicenseRequestMessage(evt,
144
- { type: "cenc",
145
- values: [ { systemId: "15",
146
- data: initData } ] });
147
- break;
148
- case 4:
149
- case 5:
150
- case 6:
151
- expectInitDataIgnored(evt,
152
- { type: "cenc",
153
- values: [ { systemId: "15",
154
- data: initData } ] });
155
- if (eventsReceived === 6) {
156
- setTimeout(() => {
157
- kill$.next();
158
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
159
- expect(createSessionSpy).toHaveBeenCalledWith("temporary");
160
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
161
- expect(generateKeyRequestSpy)
162
- .toHaveBeenCalledWith(mediaKeySession, "cenc", initData);
163
- done();
164
- }, 10);
165
- }
166
- break;
167
- default:
168
- throw new Error("Unexpected event");
169
- }
170
- });
171
- initDataSubject.next({ type: "cenc",
172
- values: [ { systemId: "15", data: initData } ] });
173
- initDataSubject.next({ type: "cenc",
174
- values: [ { systemId: "15", data: initData } ] });
175
- initDataSubject.next({ type: "cenc",
176
- values: [ { systemId: "15", data: initData } ] });
177
- initDataSubject.next({ type: "cenc",
178
- values: [ { systemId: "15", data: initData } ] });
179
- });
180
-
181
- /* eslint-disable max-len */
182
- it("should create multiple sessions for multiple sent init data when unknown", (done) => {
183
- /* eslint-enable max-len */
184
-
185
- // == mocks ==
186
- const { generateKeyRequestSpy } = mockCompat();
187
- const mediaKeySession1 = new MediaKeySessionImpl();
188
- const mediaKeySession2 = new MediaKeySessionImpl();
189
- let createSessionCallIdx = 0;
190
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
191
- .mockImplementation(() => {
192
- return createSessionCallIdx++ === 0 ? mediaKeySession1 :
193
- mediaKeySession2;
194
- });
195
-
196
- // == vars ==
197
- const initDataSubject = new Subject<IContentProtection>();
198
- let eventsReceived = 0;
199
- const initData1 = new Uint8Array([54, 55, 75]);
200
- const initData2 = new Uint8Array([87, 32]);
201
- const kill$ = new Subject<void>();
202
-
203
- // == test ==
204
- const EMEManager = require("../../eme_manager").default;
205
- EMEManager(videoElt, ksConfig, initDataSubject)
206
- .pipe(takeUntil(kill$))
207
- .subscribe((evt : any) => {
208
- switch (++eventsReceived) {
209
- case 1:
210
- expect(evt.type).toEqual("created-media-keys");
211
- evt.value.canAttachMediaKeys.setValue(true);
212
- break;
213
- case 2:
214
- expect(evt.type).toEqual("attached-media-keys");
215
- break;
216
- case 3:
217
- expectLicenseRequestMessage(evt,
218
- { type: "cenc",
219
- values: [ { systemId: "15",
220
- data: initData1 } ] });
221
- break;
222
- case 4:
223
- expectInitDataIgnored(evt,
224
- { type: "cenc",
225
- values: [ { systemId: "15",
226
- data: initData1 } ] });
227
- break;
228
- case 5:
229
- expectLicenseRequestMessage(evt,
230
- { type: "cenc",
231
- values: [ { systemId: "15",
232
- data: initData2 } ] });
233
- break;
234
- case 6:
235
- expectInitDataIgnored(evt,
236
- { type: "cenc",
237
- values: [ { systemId: "15",
238
- data: initData1 } ] });
239
- break;
240
- case 7:
241
- expectInitDataIgnored(evt,
242
- { type: "cenc",
243
- values: [ { systemId: "15",
244
- data: initData2 } ] });
245
- setTimeout(() => {
246
- kill$.next();
247
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
248
- expect(createSessionSpy).toHaveBeenNthCalledWith(1, "temporary");
249
- expect(createSessionSpy).toHaveBeenNthCalledWith(2, "temporary");
250
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
251
- expect(generateKeyRequestSpy)
252
- .toHaveBeenNthCalledWith(1, mediaKeySession1, "cenc", initData1);
253
- expect(generateKeyRequestSpy)
254
- .toHaveBeenNthCalledWith(2, mediaKeySession2, "cenc", initData2);
255
- done();
256
- }, 10);
257
- break;
258
- default:
259
- throw new Error("Unexpected event");
260
- }
261
- });
262
- initDataSubject.next({ type: "cenc",
263
- values: [ { systemId: "15", data: initData1 } ] });
264
- initDataSubject.next({ type: "cenc",
265
- values: [ { systemId: "15", data: initData1 } ] });
266
- initDataSubject.next({ type: "cenc",
267
- values: [ { systemId: "15", data: initData2 } ] });
268
- initDataSubject.next({ type: "cenc",
269
- values: [ { systemId: "15", data: initData1 } ] });
270
- initDataSubject.next({ type: "cenc",
271
- values: [ { systemId: "15", data: initData2 } ] });
272
- });
273
-
274
- /* eslint-disable max-len */
275
- it("should create multiple sessions for multiple sent init data types", (done) => {
276
- /* eslint-enable max-len */
277
-
278
- // == mocks ==
279
- const { generateKeyRequestSpy } = mockCompat();
280
- const mediaKeySessions = [ new MediaKeySessionImpl(),
281
- new MediaKeySessionImpl(),
282
- new MediaKeySessionImpl(),
283
- new MediaKeySessionImpl() ];
284
- let createSessionCallIdx = 0;
285
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
286
- .mockImplementation(() => {
287
- return mediaKeySessions[createSessionCallIdx++];
288
- });
289
-
290
- // == vars ==
291
- const initDataSubject = new Subject<IContentProtection>();
292
- let eventsReceived = 0;
293
- const initData1 = new Uint8Array([54, 55, 75]);
294
- const initData2 = new Uint8Array([87, 32]);
295
- const kill$ = new Subject<void>();
296
-
297
- // == test ==
298
- const EMEManager = require("../../eme_manager").default;
299
- EMEManager(videoElt, ksConfig, initDataSubject)
300
- .pipe(takeUntil(kill$))
301
- .subscribe((evt : any) => {
302
- switch (++eventsReceived) {
303
- case 1:
304
- expect(evt.type).toEqual("created-media-keys");
305
- evt.value.canAttachMediaKeys.setValue(true);
306
- break;
307
- case 2:
308
- expect(evt.type).toEqual("attached-media-keys");
309
- break;
310
- case 3:
311
- expectLicenseRequestMessage(evt,
312
- { type: "cenc",
313
- values: [ { systemId: "15",
314
- data: initData1 } ] });
315
- break;
316
- case 4:
317
- expectLicenseRequestMessage(evt,
318
- { type: "cenc2",
319
- values: [ { systemId: "15",
320
- data: initData1 } ] });
321
- break;
322
- case 5:
323
- expectLicenseRequestMessage(evt,
324
- { type: "cenc",
325
- values: [ { systemId: "15",
326
- data: initData2 } ] });
327
- break;
328
- case 6:
329
- expectLicenseRequestMessage(evt,
330
- { type: "cenc2",
331
- values: [ { systemId: "15",
332
- data: initData2 } ] });
333
- setTimeout(() => {
334
- kill$.next();
335
- expect(createSessionSpy).toHaveBeenCalledTimes(4);
336
- expect(createSessionSpy).toHaveBeenNthCalledWith(1, "temporary");
337
- expect(createSessionSpy).toHaveBeenNthCalledWith(2, "temporary");
338
- expect(createSessionSpy).toHaveBeenNthCalledWith(3, "temporary");
339
- expect(createSessionSpy).toHaveBeenNthCalledWith(4, "temporary");
340
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(4);
341
- expect(generateKeyRequestSpy)
342
- .toHaveBeenNthCalledWith(1, mediaKeySessions[0], "cenc", initData1);
343
- expect(generateKeyRequestSpy)
344
- .toHaveBeenNthCalledWith(2, mediaKeySessions[1], "cenc2", initData1);
345
- expect(generateKeyRequestSpy)
346
- .toHaveBeenNthCalledWith(3, mediaKeySessions[2], "cenc", initData2);
347
- expect(generateKeyRequestSpy)
348
- .toHaveBeenNthCalledWith(4, mediaKeySessions[3], "cenc2", initData2);
349
- done();
350
- }, 10);
351
- break;
352
- default:
353
- throw new Error("Unexpected event");
354
- }
355
- });
356
- initDataSubject.next({ type: "cenc",
357
- values: [ { systemId: "15", data: initData1 } ] });
358
- initDataSubject.next({ type: "cenc2",
359
- values: [ { systemId: "15", data: initData1 } ] });
360
- initDataSubject.next({ type: "cenc",
361
- values: [ { systemId: "15", data: initData2 } ] });
362
- initDataSubject.next({ type: "cenc2",
363
- values: [ { systemId: "15", data: initData2 } ] });
364
- });
365
-
366
- /* eslint-disable max-len */
367
- it("should create a session and generate a request when init data is received from the browser", (done) => {
368
- /* eslint-enable max-len */
369
-
370
- // == mocks ==
371
- const { generateKeyRequestSpy, eventTriggers, getInitDataSpy } = mockCompat();
372
- const { triggerEncrypted } = eventTriggers;
373
- const mediaKeySession = new MediaKeySessionImpl();
374
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
375
- .mockReturnValue(mediaKeySession);
376
-
377
- // == vars ==
378
- let eventsReceived = 0;
379
- const initData = new Uint8Array([54, 55, 75]);
380
- const initDataEvent = { type: "cenc",
381
- values: [ { systemId: "15",
382
- data: initData } ] };
383
- const kill$ = new Subject<void>();
384
-
385
- // == test ==
386
- const EMEManager = require("../../eme_manager").default;
387
- EMEManager(videoElt, ksConfig, EMPTY)
388
- .pipe(takeUntil(kill$))
389
- .subscribe((evt : any) => {
390
- switch (++eventsReceived) {
391
- case 1:
392
- expectEncryptedEventReceived(evt, initDataEvent);
393
- expect(getInitDataSpy).toHaveBeenCalledTimes(1);
394
- expect(getInitDataSpy).toHaveBeenCalledWith(initDataEvent);
395
- break;
396
- case 2:
397
- expect(evt.type).toEqual("created-media-keys");
398
- evt.value.canAttachMediaKeys.setValue(true);
399
- break;
400
- case 3:
401
- expect(evt.type).toEqual("attached-media-keys");
402
- break;
403
- case 4:
404
- expectLicenseRequestMessage(evt,
405
- { type: "cenc",
406
- values: [ { systemId: "15",
407
- data: initData } ] });
408
- setTimeout(() => {
409
- kill$.next();
410
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
411
- expect(createSessionSpy).toHaveBeenCalledWith("temporary");
412
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
413
- expect(generateKeyRequestSpy)
414
- .toHaveBeenCalledWith(mediaKeySession, "cenc", initData);
415
- done();
416
- }, 10);
417
- break;
418
- default:
419
- throw new Error("Unexpected event");
420
- }
421
- });
422
- triggerEncrypted.next(initDataEvent);
423
- });
424
-
425
- /* eslint-disable max-len */
426
- it("should ignore init data already received through the browser", (done) => {
427
- /* eslint-enable max-len */
428
-
429
- // == mocks ==
430
- const { generateKeyRequestSpy, eventTriggers, getInitDataSpy } = mockCompat();
431
- const { triggerEncrypted } = eventTriggers;
432
- const mediaKeySession = new MediaKeySessionImpl();
433
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
434
- .mockReturnValue(mediaKeySession);
435
-
436
- // == vars ==
437
- let eventsReceived = 0;
438
- const initData = new Uint8Array([54, 55, 75]);
439
- const initDataEvent = { type: "cenc",
440
- values: [ { systemId: "15",
441
- data: initData } ] };
442
- const kill$ = new Subject<void>();
443
-
444
- // == test ==
445
- const EMEManager = require("../../eme_manager").default;
446
- EMEManager(videoElt, ksConfig, EMPTY)
447
- .pipe(takeUntil(kill$))
448
- .subscribe((evt : any) => {
449
- switch (++eventsReceived) {
450
- case 1:
451
- case 2:
452
- case 3:
453
- case 4:
454
- expectEncryptedEventReceived(evt, initDataEvent);
455
- expect(getInitDataSpy).toHaveBeenCalledTimes(eventsReceived);
456
- expect(getInitDataSpy).toHaveBeenNthCalledWith(eventsReceived, initDataEvent);
457
- break;
458
- case 5:
459
- expect(evt.type).toEqual("created-media-keys");
460
- evt.value.canAttachMediaKeys.setValue(true);
461
- break;
462
- case 6:
463
- expect(evt.type).toEqual("attached-media-keys");
464
- break;
465
- case 7:
466
- expectLicenseRequestMessage(evt,
467
- { type: "cenc",
468
- values: [ { systemId: "15",
469
- data: initData } ] });
470
- break;
471
- case 8:
472
- case 9:
473
- case 10:
474
- expectInitDataIgnored(evt,
475
- { type: "cenc",
476
- values: [ { systemId: "15",
477
- data: initData } ] });
478
- if (eventsReceived === 10) {
479
- setTimeout(() => {
480
- kill$.next();
481
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
482
- expect(createSessionSpy).toHaveBeenCalledWith("temporary");
483
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
484
- expect(generateKeyRequestSpy)
485
- .toHaveBeenCalledWith(mediaKeySession, "cenc", initData);
486
- done();
487
- }, 10);
488
- }
489
- break;
490
- default:
491
- throw new Error("Unexpected event");
492
- }
493
- });
494
- triggerEncrypted.next(initDataEvent);
495
- triggerEncrypted.next(initDataEvent);
496
- triggerEncrypted.next(initDataEvent);
497
- triggerEncrypted.next(initDataEvent);
498
- });
499
-
500
- /* eslint-disable max-len */
501
- it("should create multiple sessions for multiple received init data when unknown", (done) => {
502
- /* eslint-enable max-len */
503
-
504
- // == mocks ==
505
- const { generateKeyRequestSpy, eventTriggers, getInitDataSpy } = mockCompat();
506
- const { triggerEncrypted } = eventTriggers;
507
- const mediaKeySession1 = new MediaKeySessionImpl();
508
- const mediaKeySession2 = new MediaKeySessionImpl();
509
- let createSessionCallIdx = 0;
510
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
511
- .mockImplementation(() => {
512
- return createSessionCallIdx++ === 0 ? mediaKeySession1 :
513
- mediaKeySession2;
514
- });
515
-
516
- // == vars ==
517
- let eventsReceived = 0;
518
- const initData1 = new Uint8Array([54, 55, 75]);
519
- const initData2 = new Uint8Array([87, 32]);
520
- const initDataEvent1 = { type: "cenc",
521
- values: [ { systemId: "15",
522
- data: initData1 } ] };
523
- const initDataEvent2 = { type: "cenc",
524
- values: [ { systemId: "15",
525
- data: initData2 } ] };
526
- const kill$ = new Subject<void>();
527
-
528
- function checkEncryptedEventReceived(
529
- evt : any,
530
- initDataEvent : IEncryptedEventData,
531
- nb : number
532
- ) {
533
- expect(evt.type).toEqual("encrypted-event-received");
534
- expect(evt.value).toEqual(initDataEvent);
535
- expect(getInitDataSpy).toHaveBeenCalledTimes(nb);
536
- expect(getInitDataSpy)
537
- .toHaveBeenNthCalledWith(nb, initDataEvent);
538
- }
539
-
540
- // == test ==
541
- const EMEManager = require("../../eme_manager").default;
542
- EMEManager(videoElt, ksConfig, EMPTY)
543
- .pipe(takeUntil(kill$))
544
- .subscribe((evt : any) => {
545
- switch (++eventsReceived) {
546
- case 1:
547
- case 2:
548
- checkEncryptedEventReceived(evt, initDataEvent1, eventsReceived);
549
- break;
550
- case 3: checkEncryptedEventReceived(evt, initDataEvent2, 3); break;
551
- case 4: checkEncryptedEventReceived(evt, initDataEvent1, 4); break;
552
- case 5: checkEncryptedEventReceived(evt, initDataEvent2, 5); break;
553
- case 6:
554
- expect(evt.type).toEqual("created-media-keys");
555
- evt.value.canAttachMediaKeys.setValue(true);
556
- break;
557
- case 7: expect(evt.type).toEqual("attached-media-keys"); break;
558
- case 8:
559
- expectLicenseRequestMessage(evt,
560
- { type: "cenc",
561
- values: [ { systemId: "15",
562
- data: initData1 } ] });
563
- break;
564
- case 9:
565
- expectInitDataIgnored(evt,
566
- { type: "cenc",
567
- values: [ { systemId: "15",
568
- data: initData1 } ] });
569
- break;
570
- case 10:
571
- expectLicenseRequestMessage(evt,
572
- { type: "cenc",
573
- values: [ { systemId: "15",
574
- data: initData2 } ] });
575
- break;
576
- case 11:
577
- expectInitDataIgnored(evt,
578
- { type: "cenc",
579
- values: [ { systemId: "15",
580
- data: initData1 } ] });
581
- break;
582
- case 12:
583
- expectInitDataIgnored(evt,
584
- { type: "cenc",
585
- values: [ { systemId: "15",
586
- data: initData2 } ] });
587
- setTimeout(() => {
588
- kill$.next();
589
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
590
- expect(createSessionSpy).toHaveBeenNthCalledWith(1, "temporary");
591
- expect(createSessionSpy).toHaveBeenNthCalledWith(2, "temporary");
592
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
593
- expect(generateKeyRequestSpy)
594
- .toHaveBeenNthCalledWith(1, mediaKeySession1, "cenc", initData1);
595
- expect(generateKeyRequestSpy)
596
- .toHaveBeenNthCalledWith(2, mediaKeySession2, "cenc", initData2);
597
- done();
598
- }, 10);
599
- break;
600
- default:
601
- throw new Error(`Unexpected event: ${evt.type}`);
602
- }
603
- });
604
- triggerEncrypted.next(initDataEvent1);
605
- triggerEncrypted.next(initDataEvent1);
606
- triggerEncrypted.next(initDataEvent2);
607
- triggerEncrypted.next(initDataEvent1);
608
- triggerEncrypted.next(initDataEvent2);
609
- });
610
-
611
- /* eslint-disable max-len */
612
- it("should create multiple sessions for multiple received init data types", (done) => {
613
- /* eslint-enable max-len */
614
-
615
- // == mocks ==
616
- const { generateKeyRequestSpy, eventTriggers, getInitDataSpy } = mockCompat();
617
- const { triggerEncrypted } = eventTriggers;
618
- const mediaKeySessions = [ new MediaKeySessionImpl(),
619
- new MediaKeySessionImpl(),
620
- new MediaKeySessionImpl(),
621
- new MediaKeySessionImpl() ];
622
- let createSessionCallIdx = 0;
623
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
624
- .mockImplementation(() => {
625
- return mediaKeySessions[createSessionCallIdx++];
626
- });
627
-
628
- // == vars ==
629
- let eventsReceived = 0;
630
- const initData1 = new Uint8Array([54, 55, 75]);
631
- const initData2 = new Uint8Array([87, 32]);
632
- const initDataEvent1 = { type: "cenc",
633
- values: [ { systemId: "15",
634
- data: initData1 } ] };
635
- const initDataEvent2 = { type: "cenc2",
636
- values: [ { systemId: "15",
637
- data: initData1 } ] };
638
- const initDataEvent3 = { type: "cenc",
639
- values: [ { systemId: "15",
640
- data: initData2 } ] };
641
- const initDataEvent4 = { type: "cenc2",
642
- values: [ { systemId: "15",
643
- data: initData2 } ] };
644
- const kill$ = new Subject<void>();
645
-
646
- function checkEncryptedEventReceived(
647
- evt : any,
648
- initDataEvent : IEncryptedEventData,
649
- nb : number
650
- ) {
651
- expect(evt.type).toEqual("encrypted-event-received");
652
- expect(evt.value).toEqual(initDataEvent);
653
- expect(getInitDataSpy).toHaveBeenCalledTimes(nb);
654
- expect(getInitDataSpy)
655
- .toHaveBeenNthCalledWith(nb, initDataEvent);
656
- }
657
-
658
- // == test ==
659
- const EMEManager = require("../../eme_manager").default;
660
- EMEManager(videoElt, ksConfig, EMPTY)
661
- .pipe(takeUntil(kill$))
662
- .subscribe((evt : any) => {
663
- switch (++eventsReceived) {
664
- case 1: checkEncryptedEventReceived(evt, initDataEvent1, 1); break;
665
- case 2: checkEncryptedEventReceived(evt, initDataEvent2, 2); break;
666
- case 3: checkEncryptedEventReceived(evt, initDataEvent3, 3); break;
667
- case 4: checkEncryptedEventReceived(evt, initDataEvent4, 4); break;
668
- case 5:
669
- expect(evt.type).toEqual("created-media-keys");
670
- evt.value.canAttachMediaKeys.setValue(true);
671
- break;
672
- case 6: expect(evt.type).toEqual("attached-media-keys"); break;
673
- case 7:
674
- expectLicenseRequestMessage(evt,
675
- { type: "cenc",
676
- values: [ { systemId: "15",
677
- data: initData1 } ] });
678
- break;
679
- case 8:
680
- expectLicenseRequestMessage(evt,
681
- { type: "cenc2",
682
- values: [ { systemId: "15",
683
- data: initData1 } ] });
684
- break;
685
- case 9:
686
- expectLicenseRequestMessage(evt,
687
- { type: "cenc",
688
- values: [ { systemId: "15",
689
- data: initData2 } ] });
690
- break;
691
- case 10:
692
- expectLicenseRequestMessage(evt,
693
- { type: "cenc2",
694
- values: [ { systemId: "15",
695
- data: initData2 } ] });
696
- setTimeout(() => {
697
- kill$.next();
698
- expect(createSessionSpy).toHaveBeenCalledTimes(4);
699
- expect(createSessionSpy).toHaveBeenNthCalledWith(1, "temporary");
700
- expect(createSessionSpy).toHaveBeenNthCalledWith(2, "temporary");
701
- expect(createSessionSpy).toHaveBeenNthCalledWith(3, "temporary");
702
- expect(createSessionSpy).toHaveBeenNthCalledWith(4, "temporary");
703
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(4);
704
- expect(generateKeyRequestSpy)
705
- .toHaveBeenNthCalledWith(1, mediaKeySessions[0], "cenc", initData1);
706
- expect(generateKeyRequestSpy)
707
- .toHaveBeenNthCalledWith(2, mediaKeySessions[1], "cenc2", initData1);
708
- expect(generateKeyRequestSpy)
709
- .toHaveBeenNthCalledWith(3, mediaKeySessions[2], "cenc", initData2);
710
- expect(generateKeyRequestSpy)
711
- .toHaveBeenNthCalledWith(4, mediaKeySessions[3], "cenc2", initData2);
712
- done();
713
- }, 10);
714
- break;
715
- default:
716
- throw new Error("Unexpected event");
717
- }
718
- });
719
- triggerEncrypted.next(initDataEvent1);
720
- triggerEncrypted.next(initDataEvent2);
721
- triggerEncrypted.next(initDataEvent3);
722
- triggerEncrypted.next(initDataEvent4);
723
- });
724
-
725
- // eslint-disable-next-line max-len
726
- it("should consider sent event through arguments and received events through the browser the same way", (done) => {
727
- // == mocks ==
728
- const { generateKeyRequestSpy, eventTriggers, getInitDataSpy } = mockCompat();
729
- const { triggerEncrypted } = eventTriggers;
730
- const mediaKeySessions = [ new MediaKeySessionImpl(),
731
- new MediaKeySessionImpl(),
732
- new MediaKeySessionImpl(),
733
- new MediaKeySessionImpl() ];
734
- let createSessionCallIdx = 0;
735
- const createSessionSpy = jest.spyOn(MediaKeysImpl.prototype, "createSession")
736
- .mockImplementation(() => {
737
- return mediaKeySessions[createSessionCallIdx++];
738
- });
739
-
740
- // == vars ==
741
- const initDataSubject = new Subject<IContentProtection>();
742
- let eventsReceived = 0;
743
- const initData1 = new Uint8Array([54, 55, 75]);
744
- const initData2 = new Uint8Array([87, 32]);
745
- const initDataEvent1 = { type: "cenc",
746
- values: [ { systemId: "15",
747
- data: initData1 } ] };
748
- const initDataEvent2 = { type: "cenc2",
749
- values: [ { systemId: "15",
750
- data: initData1 } ] };
751
- const initDataEvent3 = { type: "cenc",
752
- values: [ { systemId: "15",
753
- data: initData2 } ] };
754
- const initDataEvent4 = { type: "cenc2",
755
- values: [ { systemId: "15",
756
- data: initData2 } ] };
757
- const kill$ = new Subject<void>();
758
-
759
- function checkEncryptedEventReceived(
760
- evt : any,
761
- initDataEvent : IEncryptedEventData,
762
- nb : number
763
- ) {
764
- expect(evt.type).toEqual("encrypted-event-received");
765
- expect(evt.value).toEqual(initDataEvent);
766
- expect(getInitDataSpy).toHaveBeenCalledTimes(nb);
767
- expect(getInitDataSpy)
768
- .toHaveBeenNthCalledWith(nb, initDataEvent);
769
- }
770
-
771
- // == test ==
772
- const EMEManager = require("../../eme_manager").default;
773
- EMEManager(videoElt, ksConfig, initDataSubject)
774
- .pipe(takeUntil(kill$))
775
- .subscribe((evt : any) => {
776
- switch (++eventsReceived) {
777
- case 1: checkEncryptedEventReceived(evt, initDataEvent1, 1); break;
778
- case 2:
779
- expect(evt.type).toEqual("created-media-keys");
780
- evt.value.canAttachMediaKeys.setValue(true);
781
- break;
782
- case 3:
783
- expect(evt.type).toEqual("attached-media-keys");
784
- expect(createSessionSpy).toHaveBeenCalledTimes(0);
785
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(0);
786
- break;
787
- case 4:
788
- expectLicenseRequestMessage(evt,
789
- { type: "cenc",
790
- values: [ { systemId: "15",
791
- data: initData1 } ] });
792
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
793
- expect(createSessionSpy).toHaveBeenNthCalledWith(1, "temporary");
794
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
795
- expect(generateKeyRequestSpy)
796
- .toHaveBeenNthCalledWith(1, mediaKeySessions[0], "cenc", initData1);
797
- break;
798
- case 5:
799
- expectInitDataIgnored(evt,
800
- { type: "cenc",
801
- values: [ { systemId: "15",
802
- data: initData1 } ] });
803
- expect(getInitDataSpy).toHaveBeenCalledTimes(1);
804
- expect(createSessionSpy).toHaveBeenCalledTimes(1);
805
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(1);
806
- break;
807
- case 6:
808
- expectLicenseRequestMessage(evt,
809
- { type: "cenc2",
810
- values: [ { systemId: "15",
811
- data: initData1 } ] });
812
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
813
- expect(createSessionSpy).toHaveBeenNthCalledWith(2, "temporary");
814
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
815
- expect(generateKeyRequestSpy)
816
- .toHaveBeenNthCalledWith(2, mediaKeySessions[1], "cenc2", initData1);
817
- break;
818
- case 7:
819
- checkEncryptedEventReceived(evt, initDataEvent2, 2);
820
- expect(getInitDataSpy).toHaveBeenCalledTimes(2);
821
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
822
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
823
- break;
824
- case 8:
825
- expectInitDataIgnored(evt,
826
- { type: "cenc2",
827
- values: [ { systemId: "15",
828
- data: initData1 } ] });
829
- expect(getInitDataSpy).toHaveBeenCalledTimes(2);
830
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
831
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
832
- break;
833
- case 9:
834
- expectInitDataIgnored(evt,
835
- { type: "cenc",
836
- values: [ { systemId: "15",
837
- data: initData1 } ] });
838
- expect(getInitDataSpy).toHaveBeenCalledTimes(2);
839
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
840
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
841
- break;
842
- case 10:
843
- checkEncryptedEventReceived(evt, initDataEvent3, 3);
844
- expect(getInitDataSpy).toHaveBeenCalledTimes(3);
845
- expect(createSessionSpy).toHaveBeenCalledTimes(2);
846
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(2);
847
- break;
848
- case 11:
849
- expectLicenseRequestMessage(evt,
850
- { type: "cenc",
851
- values: [ { systemId: "15",
852
- data: initData2 } ] });
853
- expect(createSessionSpy).toHaveBeenCalledTimes(3);
854
- expect(createSessionSpy).toHaveBeenNthCalledWith(3, "temporary");
855
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(3);
856
- expect(generateKeyRequestSpy)
857
- .toHaveBeenNthCalledWith(3, mediaKeySessions[2], "cenc", initData2);
858
- break;
859
- case 12:
860
- expectInitDataIgnored(evt,
861
- { type: "cenc",
862
- values: [ { systemId: "15",
863
- data: initData2 } ] });
864
- expect(getInitDataSpy).toHaveBeenCalledTimes(3);
865
- expect(createSessionSpy).toHaveBeenCalledTimes(3);
866
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(3);
867
- break;
868
- case 13:
869
- checkEncryptedEventReceived(evt, initDataEvent4, 4);
870
- expect(getInitDataSpy).toHaveBeenCalledTimes(4);
871
- expect(createSessionSpy).toHaveBeenCalledTimes(3);
872
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(3);
873
- break;
874
- case 14:
875
- expectLicenseRequestMessage(evt,
876
- { type: "cenc2",
877
- values: [ { systemId: "15",
878
- data: initData2 } ] });
879
- setTimeout(() => {
880
- expect(createSessionSpy).toHaveBeenCalledTimes(4);
881
- expect(createSessionSpy).toHaveBeenNthCalledWith(4, "temporary");
882
- expect(generateKeyRequestSpy).toHaveBeenCalledTimes(4);
883
- expect(generateKeyRequestSpy)
884
- .toHaveBeenNthCalledWith(4, mediaKeySessions[3], "cenc2", initData2);
885
- kill$.next();
886
- done();
887
- }, 5);
888
- break;
889
- default:
890
- throw new Error("Unexpected event");
891
- }
892
- });
893
- triggerEncrypted.next(initDataEvent1);
894
- initDataSubject.next({ type: "cenc",
895
- values: [ { systemId: "15", data: initData1 } ] });
896
- setTimeout(() => {
897
- initDataSubject.next({ type: "cenc2",
898
- values: [ { systemId: "15", data: initData1 } ] });
899
- triggerEncrypted.next(initDataEvent2);
900
- initDataSubject.next({ type: "cenc",
901
- values: [ { systemId: "15", data: initData1 } ] });
902
- triggerEncrypted.next(initDataEvent3);
903
- initDataSubject.next({ type: "cenc",
904
- values: [ { systemId: "15", data: initData2 } ] });
905
- triggerEncrypted.next(initDataEvent4);
906
- }, 5);
907
- });
908
- });