rx-player 3.26.3-dev.2022021400 → 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 (340) hide show
  1. package/CHANGELOG.md +15 -1
  2. package/FILES.md +5 -4
  3. package/VERSION +1 -1
  4. package/dist/_esm5.processed/compat/browser_detection.d.ts +4 -2
  5. package/dist/_esm5.processed/compat/browser_detection.js +4 -2
  6. package/dist/_esm5.processed/compat/eme/close_session.d.ts +11 -5
  7. package/dist/_esm5.processed/compat/eme/close_session.js +144 -36
  8. package/dist/_esm5.processed/compat/eme/custom_media_keys/index.d.ts +3 -5
  9. package/dist/_esm5.processed/compat/eme/custom_media_keys/index.js +21 -22
  10. package/dist/_esm5.processed/compat/eme/custom_media_keys/old_webkit_media_keys.js +53 -34
  11. package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys.js +43 -41
  12. package/dist/_esm5.processed/compat/eme/generate_key_request.d.ts +2 -3
  13. package/dist/_esm5.processed/compat/eme/generate_key_request.js +22 -26
  14. package/dist/_esm5.processed/compat/eme/load_session.d.ts +1 -2
  15. package/dist/_esm5.processed/compat/eme/load_session.js +68 -17
  16. package/dist/_esm5.processed/compat/event_listeners.js +2 -1
  17. package/dist/_esm5.processed/compat/should_favour_custom_safari_EME.js +2 -2
  18. package/dist/_esm5.processed/config.d.ts +166 -1080
  19. package/dist/_esm5.processed/config.js +17 -1119
  20. package/dist/_esm5.processed/core/abr/bandwidth_estimator.js +4 -1
  21. package/dist/_esm5.processed/core/abr/network_analyzer.js +2 -1
  22. package/dist/_esm5.processed/core/api/get_player_state.js +1 -1
  23. package/dist/_esm5.processed/core/api/index.d.ts +2 -1
  24. package/dist/_esm5.processed/core/api/media_element_track_choice_manager.js +2 -1
  25. package/dist/_esm5.processed/core/api/option_utils.d.ts +3 -1
  26. package/dist/_esm5.processed/core/api/option_utils.js +19 -6
  27. package/dist/_esm5.processed/core/api/playback_observer.js +5 -1
  28. package/dist/_esm5.processed/core/api/public_api.d.ts +82 -71
  29. package/dist/_esm5.processed/core/api/public_api.js +72 -33
  30. package/dist/_esm5.processed/core/{eme → decrypt}/__tests__/__global__/utils.d.ts +7 -49
  31. package/dist/_esm5.processed/core/{eme → decrypt}/__tests__/__global__/utils.js +25 -65
  32. package/dist/_esm5.processed/core/{eme → decrypt}/attach_media_keys.d.ts +12 -12
  33. package/dist/_esm5.processed/core/decrypt/attach_media_keys.js +104 -0
  34. package/dist/_esm5.processed/core/{eme/clear_eme_session.d.ts → decrypt/clear_on_stop.d.ts} +3 -4
  35. package/dist/_esm5.processed/core/decrypt/clear_on_stop.js +41 -0
  36. package/dist/_esm5.processed/core/decrypt/content_decryptor.d.ts +216 -0
  37. package/dist/_esm5.processed/core/decrypt/content_decryptor.js +866 -0
  38. package/dist/_esm5.processed/core/{eme/get_session.d.ts → decrypt/create_or_load_session.d.ts} +28 -26
  39. package/dist/_esm5.processed/core/decrypt/create_or_load_session.js +124 -0
  40. package/dist/_esm5.processed/core/{eme → decrypt}/create_session.d.ts +22 -19
  41. package/dist/_esm5.processed/core/decrypt/create_session.js +174 -0
  42. package/dist/_esm5.processed/core/decrypt/dispose_decryption_resources.d.ts +21 -0
  43. package/dist/_esm5.processed/core/decrypt/dispose_decryption_resources.js +81 -0
  44. package/dist/_esm5.processed/core/{eme → decrypt}/find_key_system.d.ts +11 -14
  45. package/dist/_esm5.processed/core/decrypt/find_key_system.js +300 -0
  46. package/dist/_esm5.processed/core/{eme → decrypt}/get_current_key_system.d.ts +0 -0
  47. package/dist/_esm5.processed/core/{eme → decrypt}/get_current_key_system.js +1 -1
  48. package/dist/_esm5.processed/core/{eme → decrypt}/get_media_keys.d.ts +13 -5
  49. package/dist/_esm5.processed/core/decrypt/get_media_keys.js +153 -0
  50. package/dist/_esm5.processed/core/{eme → decrypt}/index.d.ts +5 -6
  51. package/dist/_esm5.processed/core/{eme → decrypt}/index.js +5 -5
  52. package/dist/_esm5.processed/core/{eme → decrypt}/init_media_keys.d.ts +6 -4
  53. package/dist/_esm5.processed/core/decrypt/init_media_keys.js +82 -0
  54. package/dist/_esm5.processed/core/decrypt/session_events_listener.d.ts +77 -0
  55. package/dist/_esm5.processed/core/{eme → decrypt}/session_events_listener.js +25 -24
  56. package/dist/_esm5.processed/core/{eme → decrypt}/set_server_certificate.d.ts +15 -6
  57. package/dist/_esm5.processed/core/decrypt/set_server_certificate.js +141 -0
  58. package/dist/_esm5.processed/core/{eme → decrypt}/types.d.ts +119 -241
  59. package/dist/_esm5.processed/core/{eme → decrypt}/types.js +0 -0
  60. package/dist/_esm5.processed/core/{eme → decrypt}/utils/are_init_values_compatible.d.ts +3 -3
  61. package/dist/_esm5.processed/core/{eme → decrypt}/utils/are_init_values_compatible.js +5 -5
  62. package/dist/_esm5.processed/core/{eme → decrypt/utils}/check_key_statuses.d.ts +2 -2
  63. package/dist/_esm5.processed/core/{eme → decrypt/utils}/check_key_statuses.js +4 -3
  64. package/dist/_esm5.processed/core/{eme/utils/close_session.d.ts → decrypt/utils/clean_old_loaded_sessions.d.ts} +8 -7
  65. package/dist/_esm5.processed/core/decrypt/utils/clean_old_loaded_sessions.js +85 -0
  66. package/dist/_esm5.processed/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.d.ts +1 -1
  67. package/dist/_esm5.processed/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.js +2 -2
  68. package/dist/_esm5.processed/core/{eme → decrypt/utils}/get_drm_system_id.d.ts +0 -0
  69. package/dist/_esm5.processed/core/{eme → decrypt/utils}/get_drm_system_id.js +1 -1
  70. package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.d.ts +69 -0
  71. package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.js +99 -0
  72. package/dist/_esm5.processed/core/{eme → decrypt}/utils/is_session_usable.d.ts +0 -1
  73. package/dist/_esm5.processed/core/{eme → decrypt}/utils/is_session_usable.js +4 -5
  74. package/dist/_esm5.processed/core/decrypt/utils/key_id_comparison.d.ts +44 -0
  75. package/dist/_esm5.processed/core/decrypt/utils/key_id_comparison.js +77 -0
  76. package/dist/_esm5.processed/core/decrypt/utils/key_session_record.d.ts +104 -0
  77. package/dist/_esm5.processed/core/decrypt/utils/key_session_record.js +155 -0
  78. package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.d.ts +108 -0
  79. package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.js +303 -0
  80. package/dist/_esm5.processed/core/{eme → decrypt/utils}/media_keys_infos_store.d.ts +4 -4
  81. package/dist/_esm5.processed/core/{eme → decrypt/utils}/media_keys_infos_store.js +0 -0
  82. package/dist/_esm5.processed/core/{eme → decrypt}/utils/persistent_sessions_store.d.ts +8 -18
  83. package/dist/_esm5.processed/core/{eme → decrypt}/utils/persistent_sessions_store.js +119 -97
  84. package/dist/_esm5.processed/core/{eme/utils/init_data_container.d.ts → decrypt/utils/serializable_bytes.d.ts} +8 -5
  85. package/dist/_esm5.processed/core/{eme/utils/init_data_container.js → decrypt/utils/serializable_bytes.js} +9 -9
  86. package/dist/_esm5.processed/core/{eme → decrypt/utils}/server_certificate_store.d.ts +1 -1
  87. package/dist/_esm5.processed/core/{eme → decrypt/utils}/server_certificate_store.js +1 -1
  88. package/dist/_esm5.processed/core/fetchers/manifest/manifest_fetcher.js +2 -2
  89. package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher.js +1 -1
  90. package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher_creator.js +1 -1
  91. package/dist/_esm5.processed/core/init/get_initial_time.js +1 -1
  92. package/dist/_esm5.processed/core/init/initialize_directfile.d.ts +1 -1
  93. package/dist/_esm5.processed/core/init/initialize_directfile.js +11 -17
  94. package/dist/_esm5.processed/core/init/initialize_media_source.d.ts +4 -2
  95. package/dist/_esm5.processed/core/init/initialize_media_source.js +18 -69
  96. package/dist/_esm5.processed/core/init/link_drm_and_content.d.ts +61 -0
  97. package/dist/_esm5.processed/core/init/link_drm_and_content.js +94 -0
  98. package/dist/_esm5.processed/core/init/manifest_update_scheduler.js +2 -1
  99. package/dist/_esm5.processed/core/init/stall_avoider.js +1 -1
  100. package/dist/_esm5.processed/core/init/stream_events_emitter/stream_events_emitter.js +1 -1
  101. package/dist/_esm5.processed/core/init/types.d.ts +2 -4
  102. package/dist/_esm5.processed/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.js +1 -1
  103. package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/html_text_segment_buffer.js +3 -1
  104. package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.d.ts +17 -1
  105. package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.js +22 -5
  106. package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.d.ts +2 -1
  107. package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.js +6 -3
  108. package/dist/_esm5.processed/core/stream/events_generators.d.ts +8 -3
  109. package/dist/_esm5.processed/core/stream/events_generators.js +3 -2
  110. package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.d.ts +1 -0
  111. package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.js +3 -3
  112. package/dist/_esm5.processed/core/stream/period/create_empty_adaptation_stream.js +2 -1
  113. package/dist/_esm5.processed/core/stream/period/get_adaptation_switch_strategy.js +1 -1
  114. package/dist/_esm5.processed/core/stream/period/period_stream.d.ts +2 -1
  115. package/dist/_esm5.processed/core/stream/period/period_stream.js +3 -3
  116. package/dist/_esm5.processed/core/stream/representation/force_garbage_collection.js +2 -2
  117. package/dist/_esm5.processed/core/stream/representation/get_buffer_status.d.ts +6 -1
  118. package/dist/_esm5.processed/core/stream/representation/get_buffer_status.js +12 -9
  119. package/dist/_esm5.processed/core/stream/representation/get_needed_segments.d.ts +19 -14
  120. package/dist/_esm5.processed/core/stream/representation/get_needed_segments.js +86 -10
  121. package/dist/_esm5.processed/core/stream/representation/get_segment_priority.js +1 -1
  122. package/dist/_esm5.processed/core/stream/representation/push_media_segment.js +3 -3
  123. package/dist/_esm5.processed/core/stream/representation/representation_stream.d.ts +6 -0
  124. package/dist/_esm5.processed/core/stream/representation/representation_stream.js +19 -8
  125. package/dist/_esm5.processed/core/stream/types.d.ts +1 -1
  126. package/dist/_esm5.processed/default_config.d.ts +1114 -0
  127. package/dist/_esm5.processed/default_config.js +1145 -0
  128. package/dist/_esm5.processed/experimental/index.d.ts +2 -0
  129. package/dist/_esm5.processed/experimental/index.js +2 -0
  130. package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/push_data.d.ts +1 -0
  131. package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/thumbnail_loader.js +1 -1
  132. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.js +1 -2
  133. package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.js +1 -2
  134. package/dist/_esm5.processed/features/features_object.js +1 -1
  135. package/dist/_esm5.processed/features/initialize_features.js +1 -1
  136. package/dist/_esm5.processed/features/list/eme.d.ts +3 -3
  137. package/dist/_esm5.processed/features/list/eme.js +5 -5
  138. package/dist/_esm5.processed/features/types.d.ts +3 -3
  139. package/dist/_esm5.processed/manifest/manifest.d.ts +1 -14
  140. package/dist/_esm5.processed/manifest/manifest.js +10 -74
  141. package/dist/_esm5.processed/manifest/representation.d.ts +35 -3
  142. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/is_period_fulfilled.js +1 -2
  143. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/template.js +1 -2
  144. package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.js +1 -1
  145. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_adaptation_sets.js +87 -75
  146. package/dist/_esm5.processed/parsers/manifest/dash/common/parse_mpd.js +1 -2
  147. package/dist/_esm5.processed/parsers/manifest/smooth/create_parser.js +1 -0
  148. package/dist/_esm5.processed/public_types.d.ts +2 -2
  149. package/dist/_esm5.processed/transports/dash/image_pipelines.js +3 -0
  150. package/dist/_esm5.processed/transports/dash/segment_parser.js +6 -3
  151. package/dist/_esm5.processed/transports/dash/text_parser.js +8 -2
  152. package/dist/_esm5.processed/transports/local/segment_parser.js +4 -1
  153. package/dist/_esm5.processed/transports/local/text_parser.js +8 -2
  154. package/dist/_esm5.processed/transports/smooth/pipelines.js +68 -10
  155. package/dist/_esm5.processed/transports/types.d.ts +22 -0
  156. package/dist/_esm5.processed/utils/deep_merge.d.ts +12 -0
  157. package/dist/_esm5.processed/utils/deep_merge.js +53 -0
  158. package/dist/_esm5.processed/utils/reference.d.ts +29 -0
  159. package/dist/_esm5.processed/utils/reference.js +72 -24
  160. package/dist/_esm5.processed/utils/request/fetch.js +1 -2
  161. package/dist/_esm5.processed/utils/request/xhr.js +1 -1
  162. package/dist/_esm5.processed/utils/rx-from_cancellable_promise.js +7 -2
  163. package/dist/_esm5.processed/utils/task_canceller.d.ts +5 -3
  164. package/dist/_esm5.processed/utils/task_canceller.js +3 -3
  165. package/dist/rx-player.js +5002 -3033
  166. package/dist/rx-player.min.js +1 -1
  167. package/dummy +1 -0
  168. package/{dist/_esm5.processed/core/eme/dispose_eme.d.ts → experimental/index.d.ts} +1 -4
  169. package/{dist/_esm5.processed/core/eme/dispose_media_keys.d.ts → experimental/index.js} +1 -6
  170. package/package.json +32 -34
  171. package/scripts/build/templates/experimental/index.d.ts +16 -0
  172. package/scripts/build/templates/experimental/index.js +16 -0
  173. package/sonar-project.properties +1 -1
  174. package/src/README.md +6 -6
  175. package/src/compat/__tests__/should_favour_custom_safari_EME.test.ts +45 -5
  176. package/src/compat/browser_detection.ts +4 -2
  177. package/src/compat/eme/close_session.ts +90 -56
  178. package/src/compat/eme/custom_media_keys/index.ts +21 -38
  179. package/src/compat/eme/custom_media_keys/old_webkit_media_keys.ts +63 -46
  180. package/src/compat/eme/custom_media_keys/webkit_media_keys.ts +51 -49
  181. package/src/compat/eme/generate_key_request.ts +25 -33
  182. package/src/compat/eme/load_session.ts +29 -31
  183. package/src/compat/event_listeners.ts +2 -1
  184. package/src/compat/should_favour_custom_safari_EME.ts +5 -2
  185. package/src/config.ts +17 -1210
  186. package/src/core/README.md +1 -1
  187. package/src/core/abr/bandwidth_estimator.ts +4 -4
  188. package/src/core/abr/network_analyzer.ts +5 -6
  189. package/src/core/api/__tests__/get_player_state.test.ts +3 -3
  190. package/src/core/api/__tests__/option_utils.test.ts +17 -17
  191. package/src/core/api/get_player_state.ts +1 -1
  192. package/src/core/api/index.ts +3 -0
  193. package/src/core/api/option_utils.ts +37 -20
  194. package/src/core/api/playback_observer.ts +12 -8
  195. package/src/core/api/public_api.ts +151 -111
  196. package/src/core/decrypt/README.md +22 -0
  197. package/src/core/decrypt/__tests__/__global__/get_license.test.ts +418 -0
  198. package/src/core/decrypt/__tests__/__global__/init_data.test.ts +675 -0
  199. package/src/core/{eme → decrypt}/__tests__/__global__/media_key_system_access.test.ts +99 -92
  200. package/src/core/decrypt/__tests__/__global__/media_keys.test.ts +156 -0
  201. package/src/core/decrypt/__tests__/__global__/server_certificate.test.ts +262 -0
  202. package/src/core/{eme → decrypt}/__tests__/__global__/utils.ts +31 -93
  203. package/src/core/{eme → decrypt}/attach_media_keys.ts +49 -56
  204. package/src/core/decrypt/clear_on_stop.ts +48 -0
  205. package/src/core/decrypt/content_decryptor.ts +1158 -0
  206. package/src/core/decrypt/create_or_load_session.ts +130 -0
  207. package/src/core/decrypt/create_session.ts +175 -0
  208. package/src/core/decrypt/dispose_decryption_resources.ts +39 -0
  209. package/src/core/{eme → decrypt}/find_key_system.ts +112 -122
  210. package/src/core/{eme → decrypt}/get_current_key_system.ts +1 -1
  211. package/src/core/decrypt/get_media_keys.ts +145 -0
  212. package/src/core/{eme → decrypt}/index.ts +11 -8
  213. package/src/core/decrypt/init_media_keys.ts +51 -0
  214. package/src/core/{eme → decrypt}/session_events_listener.ts +93 -55
  215. package/src/core/decrypt/set_server_certificate.ts +104 -0
  216. package/src/core/{eme → decrypt}/types.ts +128 -258
  217. package/src/core/{eme → decrypt}/utils/__tests__/are_init_values_compatible.test.ts +1 -1
  218. package/src/core/{eme → decrypt/utils}/__tests__/clean_old_loaded_sessions.test.ts +29 -71
  219. package/src/core/{eme → decrypt/utils}/__tests__/clean_old_stored_persistent_info.test.ts +6 -6
  220. package/src/core/{eme → decrypt}/utils/are_init_values_compatible.ts +9 -9
  221. package/src/core/{eme → decrypt/utils}/check_key_statuses.ts +6 -5
  222. package/{dist/_esm5.processed/core/eme/clean_old_loaded_sessions.js → src/core/decrypt/utils/clean_old_loaded_sessions.ts} +20 -20
  223. package/src/core/{eme → decrypt/utils}/clean_old_stored_persistent_info.ts +3 -3
  224. package/src/core/{eme → decrypt/utils}/get_drm_system_id.ts +1 -1
  225. package/src/core/decrypt/utils/init_data_values_container.ts +119 -0
  226. package/src/core/{eme → decrypt}/utils/is_session_usable.ts +4 -5
  227. package/src/core/decrypt/utils/key_id_comparison.ts +82 -0
  228. package/src/core/decrypt/utils/key_session_record.ts +175 -0
  229. package/src/core/decrypt/utils/loaded_sessions_store.ts +318 -0
  230. package/src/core/{eme → decrypt/utils}/media_keys_infos_store.ts +4 -4
  231. package/src/core/{eme → decrypt}/utils/persistent_sessions_store.ts +122 -104
  232. package/src/core/{eme/utils/init_data_container.ts → decrypt/utils/serializable_bytes.ts} +8 -5
  233. package/src/core/{eme → decrypt/utils}/server_certificate_store.ts +2 -2
  234. package/src/core/fetchers/manifest/manifest_fetcher.ts +4 -4
  235. package/src/core/fetchers/segment/segment_fetcher.ts +4 -4
  236. package/src/core/fetchers/segment/segment_fetcher_creator.ts +2 -2
  237. package/src/core/init/.initialize_media_source.ts.un~ +0 -0
  238. package/src/core/init/get_initial_time.ts +2 -1
  239. package/src/core/init/initialize_directfile.ts +17 -20
  240. package/src/core/init/initialize_media_source.ts +42 -105
  241. package/src/core/init/link_drm_and_content.ts +176 -0
  242. package/src/core/init/manifest_update_scheduler.ts +5 -3
  243. package/src/core/init/stall_avoider.ts +6 -5
  244. package/src/core/init/stream_events_emitter/stream_events_emitter.ts +2 -1
  245. package/src/core/init/types.ts +1 -39
  246. package/src/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.ts +2 -1
  247. package/src/core/segment_buffers/implementations/text/html/html_text_segment_buffer.ts +3 -4
  248. package/src/core/segment_buffers/inventory/segment_inventory.ts +42 -8
  249. package/src/core/stream/adaptation/adaptation_stream.ts +7 -1
  250. package/src/core/stream/events_generators.ts +9 -4
  251. package/src/core/stream/orchestrator/stream_orchestrator.ts +9 -4
  252. package/src/core/stream/period/create_empty_adaptation_stream.ts +2 -1
  253. package/src/core/stream/period/get_adaptation_switch_strategy.ts +1 -1
  254. package/src/core/stream/period/period_stream.ts +5 -2
  255. package/src/core/stream/representation/force_garbage_collection.ts +2 -2
  256. package/src/core/stream/representation/get_buffer_status.ts +28 -16
  257. package/src/core/stream/representation/get_needed_segments.ts +124 -28
  258. package/src/core/stream/representation/get_segment_priority.ts +1 -2
  259. package/src/core/stream/representation/push_media_segment.ts +3 -2
  260. package/src/core/stream/representation/representation_stream.ts +30 -7
  261. package/src/core/stream/types.ts +1 -1
  262. package/src/default_config.ts +1241 -0
  263. package/src/experimental/index.ts +5 -0
  264. package/src/experimental/tools/VideoThumbnailLoader/push_data.ts +1 -0
  265. package/src/experimental/tools/VideoThumbnailLoader/thumbnail_loader.ts +2 -1
  266. package/src/experimental/tools/mediaCapabilitiesProber/__tests__/probers/DRMInfos.test.ts +3 -10
  267. package/src/experimental/tools/mediaCapabilitiesProber/__tests__/probers/HDCPPolicy.test.ts +4 -4
  268. package/src/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.ts +1 -2
  269. package/src/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.ts +1 -2
  270. package/src/features/__tests__/initialize_features.test.ts +2 -2
  271. package/src/features/features_object.ts +1 -1
  272. package/src/features/initialize_features.ts +1 -1
  273. package/src/features/list/__tests__/eme.test.ts +5 -5
  274. package/src/features/list/eme.ts +5 -5
  275. package/src/features/types.ts +3 -10
  276. package/src/manifest/manifest.ts +6 -76
  277. package/src/manifest/representation.ts +36 -3
  278. package/src/parsers/manifest/dash/common/indexes/is_period_fulfilled.ts +1 -2
  279. package/src/parsers/manifest/dash/common/indexes/template.ts +1 -2
  280. package/src/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.ts +1 -1
  281. package/src/parsers/manifest/dash/common/parse_adaptation_sets.ts +109 -64
  282. package/src/parsers/manifest/dash/common/parse_mpd.ts +1 -2
  283. package/src/parsers/manifest/smooth/create_parser.ts +1 -0
  284. package/src/parsers/texttracks/webvtt/html/__tests__/create_styled_element.test.ts +1 -0
  285. package/src/public_types.ts +5 -1
  286. package/src/transports/dash/image_pipelines.ts +3 -0
  287. package/src/transports/dash/segment_parser.ts +5 -0
  288. package/src/transports/dash/text_parser.ts +8 -0
  289. package/src/transports/local/segment_parser.ts +4 -0
  290. package/src/transports/local/text_parser.ts +8 -0
  291. package/src/transports/smooth/pipelines.ts +22 -9
  292. package/src/transports/types.ts +22 -0
  293. package/src/utils/__tests__/deep_merge.test.ts +48 -0
  294. package/src/utils/deep_merge.ts +46 -0
  295. package/src/utils/reference.ts +116 -23
  296. package/src/utils/request/fetch.ts +1 -2
  297. package/src/utils/request/xhr.ts +2 -1
  298. package/src/utils/rx-from_cancellable_promise.ts +7 -2
  299. package/src/utils/task_canceller.ts +6 -4
  300. package/dist/_esm5.processed/core/eme/attach_media_keys.js +0 -57
  301. package/dist/_esm5.processed/core/eme/clean_old_loaded_sessions.d.ts +0 -59
  302. package/dist/_esm5.processed/core/eme/clear_eme_session.js +0 -50
  303. package/dist/_esm5.processed/core/eme/create_session.js +0 -126
  304. package/dist/_esm5.processed/core/eme/dispose_eme.js +0 -23
  305. package/dist/_esm5.processed/core/eme/dispose_media_keys.js +0 -36
  306. package/dist/_esm5.processed/core/eme/eme_manager.d.ts +0 -31
  307. package/dist/_esm5.processed/core/eme/eme_manager.js +0 -278
  308. package/dist/_esm5.processed/core/eme/find_key_system.js +0 -253
  309. package/dist/_esm5.processed/core/eme/get_media_keys.js +0 -85
  310. package/dist/_esm5.processed/core/eme/get_session.js +0 -68
  311. package/dist/_esm5.processed/core/eme/init_media_keys.js +0 -66
  312. package/dist/_esm5.processed/core/eme/session_events_listener.d.ts +0 -41
  313. package/dist/_esm5.processed/core/eme/set_server_certificate.js +0 -85
  314. package/dist/_esm5.processed/core/eme/utils/close_session.js +0 -81
  315. package/dist/_esm5.processed/core/eme/utils/init_data_store.d.ts +0 -115
  316. package/dist/_esm5.processed/core/eme/utils/init_data_store.js +0 -181
  317. package/dist/_esm5.processed/core/eme/utils/loaded_sessions_store.d.ts +0 -123
  318. package/dist/_esm5.processed/core/eme/utils/loaded_sessions_store.js +0 -173
  319. package/dist/_esm5.processed/core/init/create_eme_manager.d.ts +0 -34
  320. package/dist/_esm5.processed/core/init/create_eme_manager.js +0 -52
  321. package/src/core/eme/README.md +0 -26
  322. package/src/core/eme/__tests__/__global__/get_license.test.ts +0 -414
  323. package/src/core/eme/__tests__/__global__/init_data.test.ts +0 -908
  324. package/src/core/eme/__tests__/__global__/media_keys.test.ts +0 -266
  325. package/src/core/eme/__tests__/__global__/server_certificate.test.ts +0 -364
  326. package/src/core/eme/__tests__/init_media_keys.test.ts +0 -182
  327. package/src/core/eme/clean_old_loaded_sessions.ts +0 -96
  328. package/src/core/eme/clear_eme_session.ts +0 -62
  329. package/src/core/eme/create_session.ts +0 -187
  330. package/src/core/eme/dispose_eme.ts +0 -25
  331. package/src/core/eme/dispose_media_keys.ts +0 -46
  332. package/src/core/eme/eme_manager.ts +0 -387
  333. package/src/core/eme/get_media_keys.ts +0 -141
  334. package/src/core/eme/get_session.ts +0 -135
  335. package/src/core/eme/init_media_keys.ts +0 -106
  336. package/src/core/eme/set_server_certificate.ts +0 -115
  337. package/src/core/eme/utils/close_session.ts +0 -113
  338. package/src/core/eme/utils/init_data_store.ts +0 -234
  339. package/src/core/eme/utils/loaded_sessions_store.ts +0 -235
  340. package/src/core/init/create_eme_manager.ts +0 -95
package/CHANGELOG.md CHANGED
@@ -1,21 +1,35 @@
1
1
  # Changelog
2
2
 
3
- ## v3.26.3-dev.2022021400 (2022-02-14)
3
+ ## v3.27.0-dev.2022031700 (2022-03-17)
4
+
5
+ ### Features
6
+
7
+ - Add a `maxVideoBufferSize` constructor option and `{get,set}MaxVideoBufferSize` methods to limit the size of loaded video data buffered at the same time [#1041, #1054]
8
+ - DRM: Add a `"periods"` mode to the `keySystems[].singleLicensePer` `loadVideo` option, allowing to obtain decryption license for groups of Periods allowing a compromise between optimization, features and compatibility [#1028, #1061]
4
9
 
5
10
  ### Bug fixes
6
11
 
7
12
  - subtitles: Fix rare issue where subtitles could be skipped due to a rounding error [#1064]
8
13
  - DASH: fix issue where the wrong segments would be requested on $Number$-based MPD with a SegmentTimeline older than the `timeShiftBufferDepth` [#1052, #1060]
9
14
  - directfile: disable all audio tracks before enabling one to work-around Safari issue on MacOS Monterey [#1067]
15
+ - avoid performing a small seek when changing the audio track [#1080]
16
+ - api: allow switching to RELOADING state synchronously after LOADED [#1083]
17
+ - Safari Mobile: Improve decryption support on Safari mobile by relying on the vendored `WebKitMediaKeys` API [#1072]
10
18
  - avoid unnecessary warning logs when loading some initialization segments [#1049]
11
19
  - TypeScript: Add forgotten TypeScript types in the exposed segment and manifest loader APIs [#1057]
20
+ - DRM: Avoid decryption issues when a license is persisted in a `singleLicensePer` `"init-data"` mode but loaded in a `"content"` mode [#1031, #1042]
12
21
 
13
22
  ### Other improvements
14
23
 
15
24
  - DASH: always consider that the non-last Period is finished when it contains SegmentTimeline elements [#1047]
16
25
  - add better buffer cleaning logic on a browser's `QuotaExceededError` to better handle memory limitations [#1065]
26
+ - DASH: Prioritize selectionPriority attribute over a "main" Role when ordering AdaptationSets [#1082]
27
+ - directfile/Safari: use the `getStartDate` method in `getWallClockTime` when available to obtain true offseted times when playing HLS contents on Safari [#1055]
17
28
  - avoid mistakenly relying on pinkie's Promise implementation when a native one is already available [#1058]
29
+ - DRM: Improve DRM Session caches performance when `singleLicensePer` is set to `"content"`
30
+ - TypeScript: Add IBitrateEstimate, IPositionUpdate and IPlayerState types to the exported types [#1084]
18
31
  - tests: add performance tests, to better catch and avoid performance regressions [#1053, #1062]
32
+ - DRM: Refactor DRM logic for better maintainability. DRM-linked logs are now prefixed by `DRM:` instead of `EME:` like previously [#1042]
19
33
 
20
34
 
21
35
  ## v3.26.2 (2022-01-11)
package/FILES.md CHANGED
@@ -25,7 +25,7 @@ a single directory or subdirectory, in alphabetical order.
25
25
  - [src/core/abr/: The adaptive bitrate code](#core-abr)
26
26
  - [src/core/api/: The API definition](#core-api)
27
27
  - [src/core/stream/: Load the right segments](#core-stream)
28
- - [src/core/eme/: Encryption management](#core-eme)
28
+ - [src/core/decrypt/: Decryption management](#core-decrypt)
29
29
  - [src/core/fetchers/: The fetchers](#core-fetchers)
30
30
  - [src/core/segment_buffers/: The Media buffers](#core-sb)
31
31
  - [src/core/init/: Media streaming logic](#core-init)
@@ -240,10 +240,11 @@ The code there calculate which segments should be downloaded, ask for their
240
240
  download and push the segments into the `SegmentBuffers`.
241
241
 
242
242
 
243
- <a name="core-eme"></a>
244
- ### src/core/eme/: Encryption management #######################################
243
+ <a name="core-decrypt"></a>
244
+ ### src/core/decrypt/: Decryption management ###################################
245
245
 
246
- Defines functions allowing to handle encrypted contents through the EME APIs.
246
+ Defines functions allowing to handle encrypted contents through the EME browser
247
+ APIs.
247
248
 
248
249
 
249
250
  <a name="core-fetchers"></a>
package/VERSION CHANGED
@@ -1 +1 @@
1
- 3.26.3-dev.2022021400
1
+ 3.27.0-dev.2022031700
@@ -19,6 +19,8 @@ declare const isEdgeChromium: boolean;
19
19
  declare const isFirefox: boolean;
20
20
  declare const isSamsungBrowser: boolean;
21
21
  declare const isTizen: boolean;
22
- declare const isSafari: boolean;
22
+ /** `true` on Safari on a PC platform (i.e. not iPhone / iPad etc.) */
23
+ declare const isSafariDesktop: boolean;
24
+ /** `true` on Safari on an iPhone, iPad & iPod platform */
23
25
  declare const isSafariMobile: boolean;
24
- export { isEdgeChromium, isIE11, isIEOrEdge, isFirefox, isSafari, isSafariMobile, isSamsungBrowser, isTizen, };
26
+ export { isEdgeChromium, isIE11, isIEOrEdge, isFirefox, isSafariDesktop, isSafariMobile, isSamsungBrowser, isTizen, };
@@ -34,10 +34,12 @@ var isSamsungBrowser = !isNode &&
34
34
  /SamsungBrowser/.test(navigator.userAgent);
35
35
  var isTizen = !isNode &&
36
36
  /Tizen/.test(navigator.userAgent);
37
- var isSafari = !isNode && (Object.prototype.toString.call(window.HTMLElement).indexOf("Constructor") >= 0 ||
37
+ /** `true` on Safari on a PC platform (i.e. not iPhone / iPad etc.) */
38
+ var isSafariDesktop = !isNode && (Object.prototype.toString.call(window.HTMLElement).indexOf("Constructor") >= 0 ||
38
39
  ((_b = (_a = window.safari) === null || _a === void 0 ? void 0 : _a.pushNotification) === null || _b === void 0 ? void 0 : _b.toString()) ===
39
40
  "[object SafariRemoteNotification]");
41
+ /** `true` on Safari on an iPhone, iPad & iPod platform */
40
42
  var isSafariMobile = !isNode &&
41
43
  typeof navigator.platform === "string" &&
42
44
  /iPad|iPhone|iPod/.test(navigator.platform);
43
- export { isEdgeChromium, isIE11, isIEOrEdge, isFirefox, isSafari, isSafariMobile, isSamsungBrowser, isTizen, };
45
+ export { isEdgeChromium, isIE11, isIEOrEdge, isFirefox, isSafariDesktop, isSafariMobile, isSamsungBrowser, isTizen, };
@@ -13,12 +13,18 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { Observable } from "rxjs";
17
16
  import { ICustomMediaKeySession } from "./custom_media_keys";
18
17
  /**
19
- * Close session and returns and observable that emits when
20
- * the session is closed.
18
+ * Close the given `MediaKeySession` and returns a Promise resolving when the
19
+ * session is closed.
20
+ * This promise does not reject, even if we're unable to close the
21
+ * `MediaKeySession`.
22
+ *
23
+ * Note that there is a lot of browser issues linked to the impossibility to
24
+ * either close a MediaKeySession or to know if a MediaKeySession was closed.
25
+ * Due to this, the returned Promise might take some time before resolving on
26
+ * some devices.
21
27
  * @param {MediaKeySession|Object} session
22
- * @returns {Observable}
28
+ * @returns {Promise.<undefined>}
23
29
  */
24
- export default function closeSession$(session: MediaKeySession | ICustomMediaKeySession): Observable<unknown>;
30
+ export default function closeSession(session: MediaKeySession | ICustomMediaKeySession): Promise<void>;
@@ -13,43 +13,151 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { catchError, map, mergeMap, of as observableOf, race as observableRace, timer as observableTimer, } from "rxjs";
17
- import castToObservable from "../../utils/cast_to_observable";
16
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
17
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
18
+ return new (P || (P = Promise))(function (resolve, reject) {
19
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
20
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
21
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
22
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
23
+ });
24
+ };
25
+ var __generator = (this && this.__generator) || function (thisArg, body) {
26
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
27
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
28
+ function verb(n) { return function (v) { return step([n, v]); }; }
29
+ function step(op) {
30
+ if (f) throw new TypeError("Generator is already executing.");
31
+ while (_) try {
32
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
33
+ if (y = 0, t) op = [op[0] & 2, t.value];
34
+ switch (op[0]) {
35
+ case 0: case 1: t = op; break;
36
+ case 4: _.label++; return { value: op[1], done: false };
37
+ case 5: _.label++; y = op[1]; op = [0]; continue;
38
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
39
+ default:
40
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
41
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
42
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
43
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
44
+ if (t[2]) _.ops.pop();
45
+ _.trys.pop(); continue;
46
+ }
47
+ op = body.call(thisArg, _);
48
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
49
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
50
+ }
51
+ };
52
+ import log from "../../log";
53
+ import cancellableSleep from "../../utils/cancellable_sleep";
54
+ import PPromise from "../../utils/promise";
55
+ import TaskCanceller, { CancellationError, } from "../../utils/task_canceller";
18
56
  /**
19
- * Close session and returns and observable that emits when
20
- * the session is closed.
57
+ * Close the given `MediaKeySession` and returns a Promise resolving when the
58
+ * session is closed.
59
+ * This promise does not reject, even if we're unable to close the
60
+ * `MediaKeySession`.
61
+ *
62
+ * Note that there is a lot of browser issues linked to the impossibility to
63
+ * either close a MediaKeySession or to know if a MediaKeySession was closed.
64
+ * Due to this, the returned Promise might take some time before resolving on
65
+ * some devices.
21
66
  * @param {MediaKeySession|Object} session
22
- * @returns {Observable}
67
+ * @returns {Promise.<undefined>}
23
68
  */
24
- export default function closeSession$(session) {
25
- return observableRace(castToObservable(session.close()),
26
- // If the session is not closed after 1000ms, try
27
- // to call another method on session to guess if
28
- // session is closed or not.
29
- observableTimer(1000).pipe(mergeMap(function () {
30
- var tryToUpdateSession$ = castToObservable(session.update(new Uint8Array(1)));
31
- return tryToUpdateSession$.pipe(
32
- // Update has resolved, so we can't know if session is closed
33
- map(function () {
34
- throw new Error("Compat: Couldn't know if session is " +
35
- "closed");
36
- }), catchError(function (err) {
37
- // The caught error can tell if session is closed
38
- // (Chrome may throw this error)
39
- if (err instanceof Error &&
40
- err.message === "The session is already closed.") {
41
- return observableOf(null);
42
- }
43
- // The `closed` promise may resolve, even if `close()` result has not
44
- // (it may happen on Firefox). Wait for it and timeout after 1 second.
45
- // TODO There is a subtle TypeScript issue there that made casting to
46
- // a type-compatible type mandatory. If a more elegant solution can
47
- // be found, it should be preffered.
48
- var sessionIsClosed$ = castToObservable(session.closed);
49
- return observableRace(sessionIsClosed$, observableTimer(1000).pipe(map(function () {
50
- throw new Error("Compat: Couldn't know if session is " +
51
- "closed");
52
- })));
53
- }));
54
- })));
69
+ export default function closeSession(session) {
70
+ var timeoutCanceller = new TaskCanceller();
71
+ return PPromise.race([
72
+ session.close()
73
+ .then(function () { timeoutCanceller.cancel(); }),
74
+ // The `closed` promise may resolve, even if `close()` result has not
75
+ // (seen at some point on Firefox).
76
+ session.closed
77
+ .then(function () { timeoutCanceller.cancel(); }),
78
+ waitTimeoutAndCheck(),
79
+ ]);
80
+ /**
81
+ * If the session is not closed after 1000ms, try to communicate with the
82
+ * MediaKeySession and check if an error is returned.
83
+ * This is needed because on some browsers with poor EME implementation,
84
+ * knowing when a MediaKeySession is closed is actually a hard task.
85
+ *
86
+ * The returned Promise will never reject.
87
+ * @returns {Promise.<undefined>}
88
+ */
89
+ function waitTimeoutAndCheck() {
90
+ return __awaiter(this, void 0, void 0, function () {
91
+ var err_1, message;
92
+ return __generator(this, function (_a) {
93
+ switch (_a.label) {
94
+ case 0:
95
+ _a.trys.push([0, 3, , 4]);
96
+ return [4 /*yield*/, cancellableSleep(1000, timeoutCanceller.signal)];
97
+ case 1:
98
+ _a.sent();
99
+ return [4 /*yield*/, tryUpdatingSession()];
100
+ case 2:
101
+ _a.sent();
102
+ return [3 /*break*/, 4];
103
+ case 3:
104
+ err_1 = _a.sent();
105
+ if (err_1 instanceof CancellationError) { // cancelled == session closed
106
+ return [2 /*return*/];
107
+ }
108
+ message = err_1 instanceof Error ?
109
+ err_1.message :
110
+ "Unknown error made it impossible to close the session";
111
+ log.error("DRM: ".concat(message));
112
+ return [3 /*break*/, 4];
113
+ case 4: return [2 /*return*/];
114
+ }
115
+ });
116
+ });
117
+ }
118
+ /**
119
+ * Try to update `MediaKeySession` and check its error if it failed.
120
+ * If we still don't know whether it closed yet, wait a second
121
+ * timeout then quit.
122
+ *
123
+ * The returned Promise resolves if the `MediaKeySession` seems closed and
124
+ * rejects if we couldn't know or it doesn't.
125
+ * @returns {Promise.<undefined>}
126
+ */
127
+ function tryUpdatingSession() {
128
+ return __awaiter(this, void 0, void 0, function () {
129
+ var err_2;
130
+ return __generator(this, function (_a) {
131
+ switch (_a.label) {
132
+ case 0:
133
+ _a.trys.push([0, 2, , 4]);
134
+ return [4 /*yield*/, session.update(new Uint8Array(1))];
135
+ case 1:
136
+ _a.sent();
137
+ return [3 /*break*/, 4];
138
+ case 2:
139
+ err_2 = _a.sent();
140
+ if (timeoutCanceller.isUsed) { // Reminder: cancelled == session closed
141
+ return [2 /*return*/];
142
+ }
143
+ // The caught error can tell if session is closed
144
+ // (Chrome may throw this error)
145
+ // I know... Checking the error message is not the best practice ever.
146
+ if (err_2 instanceof Error &&
147
+ err_2.message === "The session is already closed.") {
148
+ return [2 /*return*/];
149
+ }
150
+ return [4 /*yield*/, cancellableSleep(1000, timeoutCanceller.signal)];
151
+ case 3:
152
+ _a.sent();
153
+ return [3 /*break*/, 4];
154
+ case 4:
155
+ if (timeoutCanceller.isUsed) { // Reminder: cancelled == session closed
156
+ return [2 /*return*/];
157
+ }
158
+ throw new Error("Compat: Couldn't know if session is closed");
159
+ }
160
+ });
161
+ });
162
+ }
55
163
  }
@@ -13,18 +13,16 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { Observable } from "rxjs";
17
16
  import CustomMediaKeySystemAccess from "./../custom_key_system_access";
18
17
  import { ICustomMediaKeys, ICustomMediaKeySession } from "./types";
19
18
  /** Generic implementation of the navigator.requestMediaKeySystemAccess API. */
20
- declare type ICompatRequestMediaKeySystemAccessFn = (keyType: string, config: MediaKeySystemConfiguration[]) => Observable<MediaKeySystemAccess | CustomMediaKeySystemAccess>;
21
- declare let requestMediaKeySystemAccess: null | ICompatRequestMediaKeySystemAccessFn;
19
+ declare type ICompatRequestMediaKeySystemAccessFn = (keyType: string, config: MediaKeySystemConfiguration[]) => Promise<MediaKeySystemAccess | CustomMediaKeySystemAccess>;
20
+ declare let requestMediaKeySystemAccess: ICompatRequestMediaKeySystemAccessFn | null;
22
21
  /**
23
22
  * Set the given MediaKeys on the given HTMLMediaElement.
24
23
  * Emits null when done then complete.
25
24
  * @param {HTMLMediaElement} elt
26
25
  * @param {Object} mediaKeys
27
- * @returns {Observable}
28
26
  */
29
- declare function setMediaKeys(elt: HTMLMediaElement, mediaKeys: MediaKeys | ICustomMediaKeys | null): Observable<unknown>;
27
+ declare let setMediaKeys: ((elt: HTMLMediaElement, mediaKeys: MediaKeys | ICustomMediaKeys | null) => unknown);
30
28
  export { requestMediaKeySystemAccess, setMediaKeys, ICustomMediaKeys, ICustomMediaKeySession, };
@@ -13,10 +13,9 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { defer as observableDefer, of as observableOf, throwError as observableThrow, } from "rxjs";
16
+ import PPromise from "pinkie";
17
17
  import { MediaError } from "../../../errors";
18
18
  import assert from "../../../utils/assert";
19
- import castToObservable from "../../../utils/cast_to_observable";
20
19
  import { isIE11 } from "../../browser_detection";
21
20
  import isNode from "../../is_node";
22
21
  import shouldFavourCustomSafariEME from "../../should_favour_custom_safari_EME";
@@ -27,7 +26,13 @@ import getOldKitWebKitMediaKeyCallbacks, { isOldWebkitMediaElement, } from "./ol
27
26
  import getWebKitMediaKeysCallbacks from "./webkit_media_keys";
28
27
  import { WebKitMediaKeysConstructor } from "./webkit_media_keys_constructor";
29
28
  var requestMediaKeySystemAccess = null;
30
- var _setMediaKeys = function defaultSetMediaKeys(mediaElement, mediaKeys) {
29
+ /**
30
+ * Set the given MediaKeys on the given HTMLMediaElement.
31
+ * Emits null when done then complete.
32
+ * @param {HTMLMediaElement} elt
33
+ * @param {Object} mediaKeys
34
+ */
35
+ var setMediaKeys = function defaultSetMediaKeys(mediaElement, mediaKeys) {
31
36
  var elt = mediaElement;
32
37
  /* eslint-disable @typescript-eslint/unbound-method */
33
38
  if (typeof elt.setMediaKeys === "function") {
@@ -58,8 +63,12 @@ var _setMediaKeys = function defaultSetMediaKeys(mediaElement, mediaKeys) {
58
63
  */
59
64
  if (isNode ||
60
65
  (navigator.requestMediaKeySystemAccess != null && !shouldFavourCustomSafariEME())) {
61
- requestMediaKeySystemAccess = function (a, b) {
62
- return castToObservable(navigator.requestMediaKeySystemAccess(a, b));
66
+ requestMediaKeySystemAccess = function () {
67
+ var args = [];
68
+ for (var _i = 0; _i < arguments.length; _i++) {
69
+ args[_i] = arguments[_i];
70
+ }
71
+ return navigator.requestMediaKeySystemAccess.apply(navigator, args);
63
72
  };
64
73
  }
65
74
  else {
@@ -70,26 +79,26 @@ else {
70
79
  var callbacks = getOldKitWebKitMediaKeyCallbacks();
71
80
  isTypeSupported_1 = callbacks.isTypeSupported;
72
81
  createCustomMediaKeys_1 = callbacks.createCustomMediaKeys;
73
- _setMediaKeys = callbacks.setMediaKeys;
82
+ setMediaKeys = callbacks.setMediaKeys;
74
83
  // This is for WebKit with prefixed EME api
75
84
  }
76
85
  else if (WebKitMediaKeysConstructor !== undefined) {
77
86
  var callbacks = getWebKitMediaKeysCallbacks();
78
87
  isTypeSupported_1 = callbacks.isTypeSupported;
79
88
  createCustomMediaKeys_1 = callbacks.createCustomMediaKeys;
80
- _setMediaKeys = callbacks.setMediaKeys;
89
+ setMediaKeys = callbacks.setMediaKeys;
81
90
  }
82
91
  else if (isIE11 && MSMediaKeysConstructor !== undefined) {
83
92
  var callbacks = getIE11MediaKeysCallbacks();
84
93
  isTypeSupported_1 = callbacks.isTypeSupported;
85
94
  createCustomMediaKeys_1 = callbacks.createCustomMediaKeys;
86
- _setMediaKeys = callbacks.setMediaKeys;
95
+ setMediaKeys = callbacks.setMediaKeys;
87
96
  }
88
97
  else if (MozMediaKeysConstructor !== undefined) {
89
98
  var callbacks = getMozMediaKeysCallbacks();
90
99
  isTypeSupported_1 = callbacks.isTypeSupported;
91
100
  createCustomMediaKeys_1 = callbacks.createCustomMediaKeys;
92
- _setMediaKeys = callbacks.setMediaKeys;
101
+ setMediaKeys = callbacks.setMediaKeys;
93
102
  }
94
103
  else {
95
104
  var MK_1 = window.MediaKeys;
@@ -117,7 +126,7 @@ else {
117
126
  }
118
127
  requestMediaKeySystemAccess = function (keyType, keySystemConfigurations) {
119
128
  if (!isTypeSupported_1(keyType)) {
120
- return observableThrow(function () { return new Error("Unsupported key type"); });
129
+ return PPromise.reject(new Error("Unsupported key type"));
121
130
  }
122
131
  for (var i = 0; i < keySystemConfigurations.length; i++) {
123
132
  var keySystemConfiguration = keySystemConfigurations[i];
@@ -142,20 +151,10 @@ else {
142
151
  }
143
152
  // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
144
153
  var customMediaKeys = createCustomMediaKeys_1(keyType);
145
- return observableOf(new CustomMediaKeySystemAccess(keyType, customMediaKeys, keySystemConfigurationResponse));
154
+ return PPromise.resolve(new CustomMediaKeySystemAccess(keyType, customMediaKeys, keySystemConfigurationResponse));
146
155
  }
147
156
  }
148
- return observableThrow(function () { return new Error("Unsupported configuration"); });
157
+ return PPromise.reject(new Error("Unsupported configuration"));
149
158
  };
150
159
  }
151
- /**
152
- * Set the given MediaKeys on the given HTMLMediaElement.
153
- * Emits null when done then complete.
154
- * @param {HTMLMediaElement} elt
155
- * @param {Object} mediaKeys
156
- * @returns {Observable}
157
- */
158
- function setMediaKeys(elt, mediaKeys) {
159
- return observableDefer(function () { return castToObservable(_setMediaKeys(elt, mediaKeys)); });
160
- }
161
160
  export { requestMediaKeySystemAccess, setMediaKeys, };
@@ -28,12 +28,11 @@ var __extends = (this && this.__extends) || (function () {
28
28
  d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
29
29
  };
30
30
  })();
31
- import { merge as observableMerge, Subject, takeUntil, } from "rxjs";
32
31
  import { base64ToBytes } from "../../../utils/base64";
33
32
  import EventEmitter from "../../../utils/event_emitter";
33
+ import noop from "../../../utils/noop";
34
34
  import PPromise from "../../../utils/promise";
35
35
  import { utf8ToStr } from "../../../utils/string_parsing";
36
- import * as events from "../../event_listeners";
37
36
  /**
38
37
  * Returns true if the given media element has old webkit methods
39
38
  * corresponding to the IOldWebkitHTMLMediaElement interface.
@@ -44,50 +43,59 @@ export function isOldWebkitMediaElement(element) {
44
43
  return typeof element
45
44
  .webkitGenerateKeyRequest === "function";
46
45
  }
46
+ /**
47
+ * MediaKeySession implementation for older versions of WebKit relying on APIs
48
+ * such as `webkitGenerateKeyRequest` `webkitAddKey` to be called on the
49
+ * HTMLMediaElement.
50
+ * @class OldWebkitMediaKeySession
51
+ */
47
52
  var OldWebkitMediaKeySession = /** @class */ (function (_super) {
48
53
  __extends(OldWebkitMediaKeySession, _super);
49
54
  function OldWebkitMediaKeySession(mediaElement, keySystem) {
50
55
  var _this = _super.call(this) || this;
51
- _this._closeSession$ = new Subject();
52
56
  _this._vid = mediaElement;
53
57
  _this._key = keySystem;
54
58
  _this.sessionId = "";
59
+ _this._closeSession = noop; // Just here to make TypeScript happy
55
60
  _this.closed = new PPromise(function (resolve) {
56
- _this._closeSession$.subscribe(resolve);
61
+ _this._closeSession = resolve;
57
62
  });
58
63
  _this.keyStatuses = new Map();
59
64
  _this.expiration = NaN;
60
- observableMerge(events.onKeyMessage$(mediaElement), events.onKeyAdded$(mediaElement), events.onKeyError$(mediaElement))
61
- .pipe(takeUntil(_this._closeSession$))
62
- .subscribe(function (evt) { return _this.trigger(evt.type, evt); });
63
- _this.update = function (license) {
64
- return new PPromise(function (resolve, reject) {
65
- try {
66
- if (_this._key.indexOf("clearkey") >= 0) {
67
- var licenseTypedArray = license instanceof ArrayBuffer ? new Uint8Array(license) :
68
- license;
69
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
70
- /* eslint-disable @typescript-eslint/no-unsafe-argument */
71
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
72
- var json = JSON.parse(utf8ToStr(licenseTypedArray));
73
- var key = base64ToBytes(json.keys[0].k);
74
- var kid = base64ToBytes(json.keys[0].kid);
75
- /* eslint-enable @typescript-eslint/no-unsafe-member-access */
76
- /* eslint-enable @typescript-eslint/no-unsafe-argument */
77
- /* eslint-enable @typescript-eslint/no-unsafe-assignment */
78
- resolve(_this._vid.webkitAddKey(_this._key, key, kid, /* sessionId */ ""));
79
- }
80
- else {
81
- resolve(_this._vid.webkitAddKey(_this._key, license, null, /* sessionId */ ""));
82
- }
83
- }
84
- catch (err) {
85
- reject(err);
86
- }
87
- });
65
+ _this._onSessionRelatedEvent = function (evt) {
66
+ _this.trigger(evt.type, evt);
88
67
  };
68
+ ["keymessage", "message", "keyadded", "ready", "keyerror", "error"]
69
+ .forEach(function (evt) { return mediaElement.addEventListener(evt, _this._onSessionRelatedEvent); });
89
70
  return _this;
90
71
  }
72
+ OldWebkitMediaKeySession.prototype.update = function (license) {
73
+ var _this = this;
74
+ return new PPromise(function (resolve, reject) {
75
+ try {
76
+ if (_this._key.indexOf("clearkey") >= 0) {
77
+ var licenseTypedArray = license instanceof ArrayBuffer ? new Uint8Array(license) :
78
+ license;
79
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
80
+ /* eslint-disable @typescript-eslint/no-unsafe-argument */
81
+ /* eslint-disable @typescript-eslint/no-unsafe-assignment */
82
+ var json = JSON.parse(utf8ToStr(licenseTypedArray));
83
+ var key = base64ToBytes(json.keys[0].k);
84
+ var kid = base64ToBytes(json.keys[0].kid);
85
+ /* eslint-enable @typescript-eslint/no-unsafe-member-access */
86
+ /* eslint-enable @typescript-eslint/no-unsafe-argument */
87
+ /* eslint-enable @typescript-eslint/no-unsafe-assignment */
88
+ resolve(_this._vid.webkitAddKey(_this._key, key, kid, /* sessionId */ ""));
89
+ }
90
+ else {
91
+ resolve(_this._vid.webkitAddKey(_this._key, license, null, /* sessionId */ ""));
92
+ }
93
+ }
94
+ catch (err) {
95
+ reject(err);
96
+ }
97
+ });
98
+ };
91
99
  OldWebkitMediaKeySession.prototype.generateRequest = function (_initDataType, initData) {
92
100
  var _this = this;
93
101
  return new PPromise(function (resolve) {
@@ -98,17 +106,28 @@ var OldWebkitMediaKeySession = /** @class */ (function (_super) {
98
106
  OldWebkitMediaKeySession.prototype.close = function () {
99
107
  var _this = this;
100
108
  return new PPromise(function (resolve) {
101
- _this._closeSession$.next();
102
- _this._closeSession$.complete();
109
+ _this._unbindSession();
110
+ _this._closeSession();
103
111
  resolve();
104
112
  });
105
113
  };
114
+ /**
115
+ * Load a Persistent MediaKeySession.
116
+ * Do nothing here because this implementation doesn't handle them.
117
+ * @returns {Promise.<boolean>}
118
+ */
106
119
  OldWebkitMediaKeySession.prototype.load = function () {
120
+ // Not implemented. Always return false as in "no session with that id".
107
121
  return PPromise.resolve(false);
108
122
  };
109
123
  OldWebkitMediaKeySession.prototype.remove = function () {
110
124
  return PPromise.resolve();
111
125
  };
126
+ OldWebkitMediaKeySession.prototype._unbindSession = function () {
127
+ var _this = this;
128
+ ["keymessage", "message", "keyadded", "ready", "keyerror", "error"]
129
+ .forEach(function (evt) { return _this._vid.removeEventListener(evt, _this._onSessionRelatedEvent); });
130
+ };
112
131
  return OldWebkitMediaKeySession;
113
132
  }(EventEmitter));
114
133
  var OldWebKitCustomMediaKeys = /** @class */ (function () {