@techsee/techsee-media-service 999.19.3-alphasap → 999.19.6-nodejs20

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 (213) hide show
  1. package/README.md +27 -28
  2. package/lib/LocalStreamManager.d.ts +1 -0
  3. package/lib/LocalStreamManager.d.ts.map +1 -1
  4. package/lib/LocalStreamManager.js +82 -84
  5. package/lib/LocalStreamManager.js.map +1 -1
  6. package/lib/MediaConstants.d.ts +20 -3
  7. package/lib/MediaConstants.d.ts.map +1 -1
  8. package/lib/MediaConstants.js +31 -13
  9. package/lib/MediaConstants.js.map +1 -1
  10. package/lib/MediaContracts.d.ts +7 -1
  11. package/lib/MediaContracts.d.ts.map +1 -1
  12. package/lib/MediaContracts.js +1 -4
  13. package/lib/MediaContracts.js.map +1 -1
  14. package/lib/MediaPublisher.d.ts +1 -0
  15. package/lib/MediaPublisher.d.ts.map +1 -1
  16. package/lib/MediaPublisher.js +7 -10
  17. package/lib/MediaPublisher.js.map +1 -1
  18. package/lib/MediaServiceBase.d.ts +1 -0
  19. package/lib/MediaServiceBase.d.ts.map +1 -1
  20. package/lib/MediaServiceBase.js +169 -198
  21. package/lib/MediaServiceBase.js.map +1 -1
  22. package/lib/MediaSession/MediaServer.d.ts +1 -0
  23. package/lib/MediaSession/MediaServer.d.ts.map +1 -1
  24. package/lib/MediaSession/MediaServer.js +62 -74
  25. package/lib/MediaSession/MediaServer.js.map +1 -1
  26. package/lib/MediaSession/MediaSessionBase.d.ts +1 -0
  27. package/lib/MediaSession/MediaSessionBase.d.ts.map +1 -1
  28. package/lib/MediaSession/MediaSessionBase.js +19 -23
  29. package/lib/MediaSession/MediaSessionBase.js.map +1 -1
  30. package/lib/MediaSession/SessionOpentok.d.ts +1 -0
  31. package/lib/MediaSession/SessionOpentok.d.ts.map +1 -1
  32. package/lib/MediaSession/SessionOpentok.js +51 -80
  33. package/lib/MediaSession/SessionOpentok.js.map +1 -1
  34. package/lib/MediaSession/SessionTurn.d.ts +1 -0
  35. package/lib/MediaSession/SessionTurn.d.ts.map +1 -1
  36. package/lib/MediaSession/SessionTurn.js +109 -151
  37. package/lib/MediaSession/SessionTurn.js.map +1 -1
  38. package/lib/MediaSession/TurnConstants.d.ts +1 -0
  39. package/lib/MediaSession/TurnConstants.d.ts.map +1 -1
  40. package/lib/MediaSession/TurnConstants.js +1 -16
  41. package/lib/MediaSession/TurnConstants.js.map +1 -1
  42. package/lib/MediaSubscriber.d.ts +1 -0
  43. package/lib/MediaSubscriber.d.ts.map +1 -1
  44. package/lib/MediaSubscriber.js +37 -43
  45. package/lib/MediaSubscriber.js.map +1 -1
  46. package/lib/MediaUtils/Compatibility.d.ts +3 -0
  47. package/lib/MediaUtils/Compatibility.d.ts.map +1 -1
  48. package/lib/MediaUtils/Compatibility.js +76 -34
  49. package/lib/MediaUtils/Compatibility.js.map +1 -1
  50. package/lib/MediaUtils/MediaDomUtils.d.ts +4 -2
  51. package/lib/MediaUtils/MediaDomUtils.d.ts.map +1 -1
  52. package/lib/MediaUtils/MediaDomUtils.js +64 -62
  53. package/lib/MediaUtils/MediaDomUtils.js.map +1 -1
  54. package/lib/MediaUtils/MediaTracer.d.ts +1 -0
  55. package/lib/MediaUtils/MediaTracer.d.ts.map +1 -1
  56. package/lib/MediaUtils/MediaTracer.js +2 -5
  57. package/lib/MediaUtils/MediaTracer.js.map +1 -1
  58. package/lib/MediaUtils/index.d.ts +2 -0
  59. package/lib/MediaUtils/index.d.ts.map +1 -0
  60. package/lib/MediaUtils/index.js +6 -0
  61. package/lib/MediaUtils/index.js.map +1 -0
  62. package/lib/MultiParty/DetectWebRtcService.d.ts +17 -14
  63. package/lib/MultiParty/DetectWebRtcService.d.ts.map +1 -1
  64. package/lib/MultiParty/DetectWebRtcService.js +98 -54
  65. package/lib/MultiParty/DetectWebRtcService.js.map +1 -1
  66. package/lib/MultiParty/MediaCapabilitiesService.d.ts +18 -0
  67. package/lib/MultiParty/MediaCapabilitiesService.d.ts.map +1 -0
  68. package/lib/MultiParty/MediaCapabilitiesService.js +158 -0
  69. package/lib/MultiParty/MediaCapabilitiesService.js.map +1 -0
  70. package/lib/MultiParty/MediaCapabilitiesUtils.d.ts +6 -0
  71. package/lib/MultiParty/MediaCapabilitiesUtils.d.ts.map +1 -0
  72. package/lib/MultiParty/MediaCapabilitiesUtils.js +123 -0
  73. package/lib/MultiParty/MediaCapabilitiesUtils.js.map +1 -0
  74. package/lib/MultiParty/MediaTracer.d.ts +4 -0
  75. package/lib/MultiParty/MediaTracer.d.ts.map +1 -0
  76. package/lib/MultiParty/MediaTracer.js +10 -0
  77. package/lib/MultiParty/MediaTracer.js.map +1 -0
  78. package/lib/MultiParty/MultiPartyService.d.ts +49 -0
  79. package/lib/MultiParty/MultiPartyService.d.ts.map +1 -0
  80. package/lib/MultiParty/MultiPartyService.js +30 -0
  81. package/lib/MultiParty/MultiPartyService.js.map +1 -0
  82. package/lib/MultiParty/MultiPartyServiceFactory.d.ts +4 -0
  83. package/lib/MultiParty/MultiPartyServiceFactory.d.ts.map +1 -0
  84. package/lib/MultiParty/MultiPartyServiceFactory.js +13 -0
  85. package/lib/MultiParty/MultiPartyServiceFactory.js.map +1 -0
  86. package/lib/MultiParty/MultipartyServiceEventTypes.d.ts +89 -0
  87. package/lib/MultiParty/MultipartyServiceEventTypes.d.ts.map +1 -0
  88. package/lib/MultiParty/MultipartyServiceEventTypes.js +16 -0
  89. package/lib/MultiParty/MultipartyServiceEventTypes.js.map +1 -0
  90. package/lib/MultiParty/index.d.ts +7 -0
  91. package/lib/MultiParty/index.d.ts.map +1 -0
  92. package/lib/MultiParty/index.js +25 -0
  93. package/lib/MultiParty/index.js.map +1 -0
  94. package/lib/MultiParty/opentok/OpentokMultiPartyService.d.ts +38 -0
  95. package/lib/MultiParty/opentok/OpentokMultiPartyService.d.ts.map +1 -0
  96. package/lib/MultiParty/opentok/OpentokMultiPartyService.js +492 -0
  97. package/lib/MultiParty/opentok/OpentokMultiPartyService.js.map +1 -0
  98. package/lib/MultiParty/opentok/OpentokPublisher.d.ts +34 -0
  99. package/lib/MultiParty/opentok/OpentokPublisher.d.ts.map +1 -0
  100. package/lib/MultiParty/opentok/OpentokPublisher.js +121 -0
  101. package/lib/MultiParty/opentok/OpentokPublisher.js.map +1 -0
  102. package/lib/MultiParty/opentok/OpentokPublisherEventMapper.d.ts +20 -0
  103. package/lib/MultiParty/opentok/OpentokPublisherEventMapper.d.ts.map +1 -0
  104. package/lib/MultiParty/opentok/OpentokPublisherEventMapper.js +49 -0
  105. package/lib/MultiParty/opentok/OpentokPublisherEventMapper.js.map +1 -0
  106. package/lib/MultiParty/opentok/OpentokScreenPublisher.d.ts +6 -0
  107. package/lib/MultiParty/opentok/OpentokScreenPublisher.d.ts.map +1 -0
  108. package/lib/MultiParty/opentok/OpentokScreenPublisher.js +48 -0
  109. package/lib/MultiParty/opentok/OpentokScreenPublisher.js.map +1 -0
  110. package/lib/MultiParty/opentok/OpentokSubscriber.d.ts +2 -0
  111. package/lib/MultiParty/opentok/OpentokSubscriber.d.ts.map +1 -0
  112. package/lib/MultiParty/opentok/OpentokSubscriber.js +26 -0
  113. package/lib/MultiParty/opentok/OpentokSubscriber.js.map +1 -0
  114. package/lib/MultiParty/opentok/OpentokVideoPublisher.d.ts +19 -0
  115. package/lib/MultiParty/opentok/OpentokVideoPublisher.d.ts.map +1 -0
  116. package/lib/MultiParty/opentok/OpentokVideoPublisher.js +182 -0
  117. package/lib/MultiParty/opentok/OpentokVideoPublisher.js.map +1 -0
  118. package/lib/MultiParty/opentok/trace.d.ts +3 -0
  119. package/lib/MultiParty/opentok/trace.d.ts.map +1 -0
  120. package/lib/MultiParty/opentok/trace.js +18 -0
  121. package/lib/MultiParty/opentok/trace.js.map +1 -0
  122. package/lib/MultiParty/opentok.d.ts +463 -0
  123. package/lib/MultiParty/types.d.ts +33 -0
  124. package/lib/MultiParty/types.d.ts.map +1 -0
  125. package/lib/MultiParty/types.js +3 -0
  126. package/lib/MultiParty/types.js.map +1 -0
  127. package/lib/MultiParty/utils.d.ts +10 -0
  128. package/lib/MultiParty/utils.d.ts.map +1 -0
  129. package/lib/MultiParty/utils.js +17 -0
  130. package/lib/MultiParty/utils.js.map +1 -0
  131. package/lib/TechseeMediaStream.d.ts +1 -0
  132. package/lib/TechseeMediaStream.d.ts.map +1 -1
  133. package/lib/TechseeMediaStream.js +9 -12
  134. package/lib/TechseeMediaStream.js.map +1 -1
  135. package/lib/qos/raw-qos.d.ts +29 -0
  136. package/lib/qos/raw-qos.d.ts.map +1 -0
  137. package/lib/qos/raw-qos.js +84 -145
  138. package/lib/qos/raw-qos.js.map +1 -1
  139. package/lib/webrtc-ie-shim.d.ts +4 -0
  140. package/lib/webrtc-ie-shim.d.ts.map +1 -0
  141. package/lib/webrtc-ie-shim.js +1896 -2950
  142. package/lib/webrtc-ie-shim.js.map +1 -1
  143. package/package.json +66 -60
  144. package/lib/MultiParty/Contracts.d.ts +0 -11
  145. package/lib/MultiParty/Contracts.d.ts.map +0 -1
  146. package/lib/MultiParty/Contracts.js +0 -6
  147. package/lib/MultiParty/Contracts.js.map +0 -1
  148. package/lib/MultiParty/MediaCapabilitiesHelper.d.ts +0 -12
  149. package/lib/MultiParty/MediaCapabilitiesHelper.d.ts.map +0 -1
  150. package/lib/MultiParty/MediaCapabilitiesHelper.js +0 -167
  151. package/lib/MultiParty/MediaCapabilitiesHelper.js.map +0 -1
  152. package/lib/MultiParty/MultiParty.d.ts +0 -21
  153. package/lib/MultiParty/MultiParty.d.ts.map +0 -1
  154. package/lib/MultiParty/MultiParty.js +0 -155
  155. package/lib/MultiParty/MultiParty.js.map +0 -1
  156. package/lib/MultiParty/MultipartyFactory.d.ts +0 -2
  157. package/lib/MultiParty/MultipartyFactory.d.ts.map +0 -1
  158. package/lib/MultiParty/MultipartyFactory.js +0 -15
  159. package/lib/MultiParty/MultipartyFactory.js.map +0 -1
  160. package/lib/MultiParty/OpentokMultiparty.d.ts +0 -24
  161. package/lib/MultiParty/OpentokMultiparty.d.ts.map +0 -1
  162. package/lib/MultiParty/OpentokMultiparty.js +0 -408
  163. package/lib/MultiParty/OpentokMultiparty.js.map +0 -1
  164. package/lib/oldCode/constants.js +0 -20
  165. package/lib/oldCode/constants.js.map +0 -1
  166. package/lib/oldCode/event-emitter.js +0 -39
  167. package/lib/oldCode/event-emitter.js.map +0 -1
  168. package/lib/oldCode/index.js +0 -64
  169. package/lib/oldCode/index.js.map +0 -1
  170. package/lib/oldCode/opentok/session.js +0 -310
  171. package/lib/oldCode/opentok/session.js.map +0 -1
  172. package/lib/oldCode/opentok/stream.js +0 -310
  173. package/lib/oldCode/opentok/stream.js.map +0 -1
  174. package/lib/oldCode/publisher.js +0 -143
  175. package/lib/oldCode/publisher.js.map +0 -1
  176. package/lib/oldCode/service.js +0 -395
  177. package/lib/oldCode/service.js.map +0 -1
  178. package/lib/oldCode/session.js +0 -110
  179. package/lib/oldCode/session.js.map +0 -1
  180. package/lib/oldCode/stream.js +0 -195
  181. package/lib/oldCode/stream.js.map +0 -1
  182. package/lib/oldCode/subscriber.js +0 -90
  183. package/lib/oldCode/subscriber.js.map +0 -1
  184. package/lib/oldCode/tracer.d.ts +0 -36
  185. package/lib/oldCode/tracer.d.ts.map +0 -1
  186. package/lib/oldCode/tracer.js +0 -161
  187. package/lib/oldCode/tracer.js.map +0 -1
  188. package/lib/oldCode/utils/ImageFixer.d.ts +0 -1
  189. package/lib/oldCode/utils/ImageFixer.d.ts.map +0 -1
  190. package/lib/oldCode/utils/ImageFixer.js +0 -59
  191. package/lib/oldCode/utils/ImageFixer.js.map +0 -1
  192. package/lib/oldCode/webrtc/constants.js +0 -114
  193. package/lib/oldCode/webrtc/constants.js.map +0 -1
  194. package/lib/oldCode/webrtc/helper.js +0 -173
  195. package/lib/oldCode/webrtc/helper.js.map +0 -1
  196. package/lib/oldCode/webrtc/session-kms.js +0 -558
  197. package/lib/oldCode/webrtc/session-kms.js.map +0 -1
  198. package/lib/oldCode/webrtc/session-loopback.js +0 -336
  199. package/lib/oldCode/webrtc/session-loopback.js.map +0 -1
  200. package/lib/oldCode/webrtc/session-turn.js +0 -880
  201. package/lib/oldCode/webrtc/session-turn.js.map +0 -1
  202. package/lib/oldCode/webrtc/session-turn.v2.js +0 -583
  203. package/lib/oldCode/webrtc/session-turn.v2.js.map +0 -1
  204. package/lib/oldCode/webrtc/session.js +0 -52
  205. package/lib/oldCode/webrtc/session.js.map +0 -1
  206. package/lib/oldCode/webrtc/stream.js +0 -674
  207. package/lib/oldCode/webrtc/stream.js.map +0 -1
  208. package/lib/oldCode/webrtc/temasys/adapter-loader.js +0 -12
  209. package/lib/oldCode/webrtc/temasys/adapter-loader.js.map +0 -1
  210. package/lib/oldCode/webrtc/temasys/adapter.js +0 -5861
  211. package/lib/oldCode/webrtc/temasys/adapter.js.map +0 -1
  212. package/lib/oldCode/webrtc/webrtc-ie-shim.js +0 -3007
  213. package/lib/oldCode/webrtc/webrtc-ie-shim.js.map +0 -1
package/README.md CHANGED
@@ -1,25 +1,25 @@
1
1
  # @techsee/techsee-media-service
2
2
 
3
3
  **General Info**
4
- This package is a starting point for creating Techsee Media SDK.
4
+ This package is a starting point for creating Techsee Media SDK.
5
5
  It contains basic framework for creating applications that utilizes media abilities.
6
6
  It can be video and/or audio, with or without streaming over WebRTC protocol.
7
- The framework currently supports: Video+Voip over Techsee Video (Turn) + IE Plugin and OpenTOK + IE Plugin.
7
+ The framework currently supports: Video+Voip over Techsee Video (Turn) + IE Plugin and OpenTOK + IE Plugin.
8
8
 
9
9
  You can see a very simple demo, which demonstrates how to create very basic MediaService implementation and use it for rendering video in react component.
10
- Clone the repository, run `npm i`, then run `npm run demo`. The source code of the demo, can be found in ./demo folder.
10
+ Clone the repository, run `npm i`, then run `npm run demo`. The source code of the demo, can be found in ./demo folder.
11
11
 
12
12
  ---
13
13
 
14
14
  Some basic framework principles are described below, which will help you to work with media framework.
15
15
 
16
16
  **Framework actors**
17
- `MediaStreamTrack` - WebRTC object, the most basic media unit.
18
- It can be video track (WebCam or ScreenShare), or audio track (Microphone stream).
19
-
17
+ `MediaStreamTrack` - WebRTC object, the most basic media unit.
18
+ It can be video track (WebCam or ScreenShare), or audio track (Microphone stream).
19
+
20
20
  `MediaStream` - WebRTC object that just organizes multiple `MediaStreamTracks` into single group.
21
21
  The same `MediaStreamTrack` can belong to multiple `MediaStreams`.
22
- In Techsee Media Service implementation, `MediaStream` can not contain more than one `MediaStreamTrack` and it used only because HTML5 video element works with `MediaStream` object.
22
+ In Techsee Media Service implementation, `MediaStream` can not contain more than one `MediaStreamTrack` and it used only because HTML5 video element works with `MediaStream` object.
23
23
 
24
24
  `TechseeMediaStream` - This is a logical wrapper for WebRTC `MediaStreamTrack` and manages some additional information regarding the specific `MediaStreamTrack`.
25
25
  For example this object has the type of the `MediaStreamTrack` (USER_VIDEO, AGENT_AUDIO...etc), has indication if track is local or remote.
@@ -27,58 +27,57 @@ For example this object has the type of the `MediaStreamTrack` (USER_VIDEO, AGEN
27
27
  `MediaSubscriber` - Techsee logical unit, that responsible to render `MediaStreams` into DOM.
28
28
  In simple words this object creates video element in html, and renders `MediaStream` into it, when stream is ready.
29
29
  `MediaSubscriber` is created for specific `MediaStream`, and whenever that stream created, the subscriber will start playing it.
30
- The subscriber will notify it's consumers about the state changes through `onStateChanged` method.
30
+ The subscriber will notify it's consumers about the state changes through `onStateChanged` method.
31
31
 
32
32
  `MediaSession` - Techsee logical unit, that used to stream video over WebRTC protocol. This object is responsible to handle all aspect of peers connectivity, including signaling, or third party service handling, like OpenTok.
33
33
  When connection with peer established, this service registers `MediaStreamTracks` that received from peer and publishes local streams the connected peer.
34
34
  Current implementation contains `MediaSessionBase` object, which have basic abstractions for all types of sessions. `SessionTurn` which handles the Techsee video sessions over TURN server.
35
35
  `SessionOpentok` which handles the session connectivity over OpenTok third party service.
36
-
36
+
37
37
  `RTCPeerConnection` - WebRTC object that represents connection with single peer, when SessionTurn is used for session. The same peer is used to send and/or receive media information.
38
38
 
39
- `OTPeerConnection` - Design time only Typescript abstraction, which represents the connectivity with peer over OpenTok session.
39
+ `OTPeerConnection` - Design time only Typescript abstraction, which represents the connectivity with peer over OpenTok session.
40
40
 
41
41
  `MediaPublisher` - Techsee logical unit which organizes local MediaStreamTracks into single MediaStream for publishing.
42
42
 
43
43
  `MediaService` - Techsee logical unit. Represents the Facade of the framework and glues all of the above together.
44
44
  Current implementation provides `MediaServiceBase` abstract object that contains all base logic and tools for displaying media locally or streaming it over WebRTC.
45
- Each application should create its concrete `MediaService` and fill specific application logic gaps.
45
+ Each application should create its concrete `MediaService` and fill specific application logic gaps.
46
46
  For example, currently exist `DashboardMediaService` in `techsee-app` and `MobileMediaService` in `techee-mobile`.
47
47
 
48
48
  ---
49
49
 
50
50
  **Consuming media service - High Level Flow**
51
-
51
+
52
52
  In order to be able to use media service, first you need to create and instance of it and initialize it.
53
- Depending on application, the constructor parameters can be different, but MediaServiceBase need to get the following in it's constructor:
53
+ Depending on application, the constructor parameters can be different, but MediaServiceBase need to get the following in it's constructor:
54
54
 
55
55
  `let mediaService = new SomeSpecificMediaService(environment, webRtcInfo);`
56
-
57
- * **environment: IMediaEnvironment** - Service which will help understand in which environment the media service is currently running.
58
- * **webRtcSupportInfo: ClientWebRtcInfo** - Information about WebRTC support on currently running device
59
56
 
57
+ - **environment: IMediaEnvironment** - Service which will help understand in which environment the media service is currently running.
58
+ - **webRtcSupportInfo: ClientWebRtcInfo** - Information about WebRTC support on currently running device
60
59
 
61
60
  When instance of specific MediaService was created, it should be initialized with `mediaService.initMediaService(serviceOptions)` method.
62
61
  See `MediaServiceOptions` for options details. The method returns promise that resolved when initialization is done.
63
62
  Initialization process, detects what media support currently running device have.
64
63
  It checks if video can be played (natively or using IE plugins), if device have mic and so on...
65
- After initialization promise resolved, the device information get be accessed through `mediaService.deviceSupportInfo`.
64
+ After initialization promise resolved, the device information get be accessed through `mediaService.deviceSupportInfo`.
66
65
 
67
- ***Note:*** Before promise returned by `mediaService.initMediaService(serviceOptions)` was not resolved, you not able to call `mediaService.initLocalMediaStreams(serviceOptions)`,
66
+ **_Note:_** Before promise returned by `mediaService.initMediaService(serviceOptions)` was not resolved, you not able to call `mediaService.initLocalMediaStreams(serviceOptions)`,
68
67
  but you can create media subscribers if needed by calling `mediaService.createSubscriber(subscriberParams)`.
69
68
 
70
69
  If audio stream is needed during the session, `mediaService.enableVoipDuringSession()` method should be called before initializing local streams.
71
- After initialization was done and promise was resolved `mediaService.initLocalMediaStreams(serviceOptions)` can be called when video/audio streams should be created.
70
+ After initialization was done and promise was resolved `mediaService.initLocalMediaStreams(serviceOptions)` can be called when video/audio streams should be created.
72
71
  This method will start the local MediaStream creation process, and Camera/ScreenShare approval dialog will popup if there permission currently exists.
73
72
  `initLocalMediaStreams` method is called by controller which displays local media stream on mobile, and in MediaSession, when `peerConnection ` is created.
74
- `initLocalMediaStreams` synchronizes the calls and insures there only one instance of stream exists, and both sides receives the same one.
75
-
76
- As mentioned before, `mediaService.createSubscriber(subscriberParams)` can be called even before initialization, so whenever you have the `div` container that should hold video element,
77
- you can create the subscriber, by providing `KnownMediaStream` and `div` as container. Whenever the stream is ready, it will be played automatically by `MediaSubscriber`.
78
- `MediaSubscriber` will create `video` element, add it to `div` container and will insure it plays.
79
- `MediaSubscriber` has 'onStateChanged' method, which can be used for being notified on state changes of the subscriber.
80
- It will notify when it starts or stops playing the video, or when it has been muted or unmuted. In event listener you can inspect properties of the subscriber to see in which state it currently exists.
81
- In addition, `MediaSubscriber` has `onDispose` event handler, which will be called after `MediaSubscriber` was disposed and will never play video again, so references to it can be removed in order to avoid memory leaks.
73
+ `initLocalMediaStreams` synchronizes the calls and insures there only one instance of stream exists, and both sides receives the same one.
74
+
75
+ As mentioned before, `mediaService.createSubscriber(subscriberParams)` can be called even before initialization, so whenever you have the `div` container that should hold video element,
76
+ you can create the subscriber, by providing `KnownMediaStream` and `div` as container. Whenever the stream is ready, it will be played automatically by `MediaSubscriber`.
77
+ `MediaSubscriber` will create `video` element, add it to `div` container and will insure it plays.
78
+ `MediaSubscriber` has 'onStateChanged' method, which can be used for being notified on state changes of the subscriber.
79
+ It will notify when it starts or stops playing the video, or when it has been muted or unmuted. In event listener you can inspect properties of the subscriber to see in which state it currently exists.
80
+ In addition, `MediaSubscriber` has `onDispose` event handler, which will be called after `MediaSubscriber` was disposed and will never play video again, so references to it can be removed in order to avoid memory leaks.
82
81
 
83
82
  **Connecting to WebRTC Media Session - High Level Flow**
84
83
 
@@ -86,4 +85,4 @@ After initialization promise was resolved, `mediaService.connectToSession(sessio
86
85
  Connection to session can be done before media streams were initialized, if your use case requires it.
87
86
  In case of of Techsee Live implementation, connection to session is done only when Terms and camera access approved by the user.
88
87
  Depending on configuration passed in initialization method, `SessionTurn` or `SessionOpentok` will be created to manage the media session peers.
89
- Whenever WebRTC peer will be connected, MediaSession instance will ask from `mediaService` for MediaStream that should be published to connected peer.
88
+ Whenever WebRTC peer will be connected, MediaSession instance will ask from `mediaService` for MediaStream that should be published to connected peer.
@@ -37,3 +37,4 @@ export declare class LocalStreamManager {
37
37
  private parseMediaErrorThenThrow;
38
38
  }
39
39
  export {};
40
+ //# sourceMappingURL=LocalStreamManager.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/LocalStreamManager.ts"],"names":[],"mappings":"AAOA,OAAO,EAAC,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AAEjD,OAAO,EACH,iBAAiB,EACjB,qBAAqB,EACrB,2BAA2B,EAE3B,yBAAyB,EAE5B,MAAM,kBAAkB,CAAC;AAY1B,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,MAAM;QACZ,qBAAqB,EAAE,QAAQ,CAAC,yBAAyB,CAAC,CAAC;QAC3D,wBAAwB,EAAE,QAAQ,CAAC,yBAAyB,CAAC,CAAC;QAC9D,2BAA2B,EAAE,QAAQ,CAAC,qBAAqB,CAAC,CAAC;QAC7D,0BAA0B,EAAE,OAAO,CAAC;KACvC;CACJ;AAeD,UAAU,eAAe;IACrB,KAAK,EAAE,QAAQ,CAAC;QAAE,IAAI,CAAC,EAAE,eAAe,CAAC;QAAC,KAAK,CAAC,EAAE,eAAe,CAAA;KAAE,CAAC,CAAC;IACrE,KAAK,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IACjC,YAAY,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,kBAAkB;IAC3B,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,eAAe,CAAgE;gBAE3E,WAAW,EAAE,iBAAiB;IAO1C,IAAI,cAAc,oBAEjB;IAED,kBAAkB,CAAC,WAAW,EAAE,qBAAqB,GAAG,OAAO,CAAC,yBAAyB,CAAC;IA2C1F,qBAAqB,CAAC,WAAW,EAAE,2BAA2B,GAAG,OAAO,CAAC,yBAAyB,CAAC;IA4CnG,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBvC,yBAAyB,IAAI,OAAO,CAAC,IAAI,CAAC;IAqB1C,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAShC,OAAO,CAAC,0BAA0B;IAwDlC,OAAO,CAAC,6BAA6B;IAsBrC,OAAO,CAAC,mCAAmC;IAoD3C,iBAAiB,CAAC,cAAc,EAAE;QAAC,KAAK,EAAE,eAAe,EAAE,CAAC;QAAC,KAAK,EAAE,eAAe,EAAE,CAAA;KAAC;IAStF,OAAO,CAAC,oBAAoB;IAuE5B,OAAO,CAAC,wBAAwB;CAwCnC","file":"LocalStreamManager.d.ts","sourcesContent":["import assign from 'lodash/assign';\nimport get from 'lodash/get';\nimport last from 'lodash/last';\nimport first from 'lodash/first';\nimport cloneDeep from 'lodash/cloneDeep';\nimport {Promise} from 'bluebird';\n\nimport {Nullable} from '@techsee/techsee-common';\n\nimport {\n IMediaEnvironment,\n LocalMediaConstraints,\n LocalVideoStreamConstraints,\n MediaRequestFailResult,\n MediaRequestSuccessResult,\n VideoStreamResolution\n} from './MediaContracts';\n\nimport {\n CameraTypes,\n ConstraintType,\n DEFAULT_VIDEO_CONSTRAINT_TYPE,\n DEFAULT_VIDEO_RESOLUTION,\n LocalVideoSourceType,\n MediaRequestErrorCode\n} from './MediaConstants';\nimport {getMediaTracer} from './MediaUtils/MediaTracer';\n\ndeclare global {\n interface Window {\n latestUserMediaStream: Nullable<MediaRequestSuccessResult>;\n latestDesktopMediaStream: Nullable<MediaRequestSuccessResult>;\n latestLocalMediaConstraints: Nullable<LocalMediaConstraints>;\n mediaStreamAlreadyReplaced: boolean;\n }\n}\n\ndeclare const window: Window;\n\nwindow.latestUserMediaStream = null;\nlet userMediaPromise: Nullable<Promise<MediaRequestSuccessResult>> = null;\n\nwindow.latestDesktopMediaStream = null;\nlet desktopMediaPromise: Nullable<Promise<MediaRequestSuccessResult>> = null;\n\nwindow.mediaStreamAlreadyReplaced = false;\nwindow.latestLocalMediaConstraints = null;\n\nconst trace = getMediaTracer('LocalStreamManager');\n\ninterface IGroupedDevices {\n video: Nullable<{ back?: MediaDeviceInfo; front?: MediaDeviceInfo }>;\n audio: Nullable<MediaDeviceInfo>;\n camerasCount: number;\n}\n\nexport class LocalStreamManager {\n private environment: IMediaEnvironment;\n private _groupedDevices: IGroupedDevices = {video: null, audio: null, camerasCount: 0};\n\n constructor(environment: IMediaEnvironment) {\n this.environment = environment;\n\n this.parseMediaErrorThenThrow = this.parseMediaErrorThenThrow.bind(this);\n this.clearAllStreams = this.clearAllStreams.bind(this);\n }\n\n get groupedDevices() {\n return this._groupedDevices;\n }\n\n getUserMediaStream(constraints: LocalMediaConstraints): Promise<MediaRequestSuccessResult> {\n trace.info('getUserMediaStream', constraints);\n if (userMediaPromise) {\n return userMediaPromise;\n }\n\n if (window.latestUserMediaStream) {\n const videoTrack = window.latestUserMediaStream.mediaStream.getVideoTracks();\n\n if (videoTrack.length > 0 && videoTrack[0].readyState === 'live') {\n return Promise.resolve({...window.latestUserMediaStream, isNew: false});\n }\n\n this.destroyUserMediaStream();\n }\n\n userMediaPromise = new Promise((resolve, reject) => {\n const catchHandler = (err: any): void => {\n userMediaPromise = null;\n window.latestUserMediaStream = null;\n trace.error('getUserMedia error', err);\n reject(err);\n };\n\n try {\n this.getHighestResolutionStream(false, constraints)\n .then((streamResult: MediaRequestSuccessResult) => {\n userMediaPromise = null;\n window.latestUserMediaStream = streamResult;\n window.latestLocalMediaConstraints = cloneDeep(constraints);\n window.latestLocalMediaConstraints.audio = (streamResult.constraint && streamResult.constraint.audio) as boolean;\n\n resolve({...window.latestUserMediaStream, isNew: true});\n })\n .catch(catchHandler);\n } catch (err) {\n catchHandler(err);\n }\n });\n\n return userMediaPromise;\n }\n\n getDesktopMediaStream(constraints: LocalVideoStreamConstraints): Promise<MediaRequestSuccessResult> {\n if (desktopMediaPromise) {\n return desktopMediaPromise;\n }\n\n trace.info('getDesktopMediaStream', constraints);\n\n if (window.latestDesktopMediaStream) {\n const track = window.latestDesktopMediaStream.mediaStream.getVideoTracks();\n\n if (track.length > 0 && track[0].readyState === 'live') {\n //return Promise.resolve();\n return Promise.resolve({...window.latestDesktopMediaStream, isNew: false});\n }\n this.destroyDesktopMediaStream().catch((error: any) => {\n trace.error('Error destroying desktop media stream', error);\n });\n\n }\n\n desktopMediaPromise = new Promise((resolve, reject) => {\n const mediaCatchHandler = (err: any): void => {\n desktopMediaPromise = null;\n window.latestDesktopMediaStream = null;\n trace.error('getDisplayMedia error', err);\n reject(err);\n };\n\n try {\n this.getHighestResolutionStream(true, {video: constraints, audio: false})\n .then((streamResult: MediaRequestSuccessResult) => {\n desktopMediaPromise = null;\n window.latestDesktopMediaStream = streamResult;\n\n resolve({...window.latestDesktopMediaStream, isNew: true});\n }).catch(mediaCatchHandler);\n } catch (err) {\n mediaCatchHandler(err);\n }\n });\n\n return desktopMediaPromise;\n }\n\n destroyUserMediaStream(): Promise<void> {\n const streamResult = window.latestUserMediaStream;\n\n userMediaPromise = null;\n window.latestUserMediaStream = null;\n window.latestLocalMediaConstraints = null;\n window.mediaStreamAlreadyReplaced = false;\n\n if (streamResult && streamResult.mediaStream) {\n try {\n streamResult.mediaStream.getTracks().forEach((track: MediaStreamTrack) => {\n track.stop();\n });\n\n trace.info('destroyUserMediaStream - stop all tracks');\n } catch (e) {\n trace.info('destroyUserMediaStream - Failed to stop all tracks', e);\n }\n }\n\n return Promise.resolve();\n }\n\n destroyDesktopMediaStream(): Promise<void> {\n const streamResult = window.latestDesktopMediaStream;\n\n window.latestDesktopMediaStream = null;\n desktopMediaPromise = null;\n\n if (streamResult && streamResult.mediaStream) {\n try {\n streamResult.mediaStream.getTracks().forEach((track: MediaStreamTrack) => {\n track.stop();\n });\n\n trace.info('destroyDesktopMediaStream - stop all tracks');\n } catch (e) {\n trace.info('destroyDesktopMediaStream - Failed to stop all tracks', e);\n }\n }\n\n return Promise.resolve();\n }\n\n clearAllStreams(): Promise<void> {\n trace.info('LocalStreamManager Clearing all streams');\n\n return Promise.all([\n this.destroyDesktopMediaStream(),\n this.destroyUserMediaStream()\n ]).then(() => undefined);\n }\n\n private getHighestResolutionStream(isDesktopMedia: boolean, constraints?: LocalMediaConstraints): Promise<MediaRequestSuccessResult> {\n const constraintsCandidates = this.getParsedConstraints(isDesktopMedia, constraints);\n\n trace.info('getHighestResolutionStream - constraintsCandidates:', constraintsCandidates);\n\n if (constraintsCandidates.length === 0) {\n return Promise.reject(new Error('No constraints to retrieve the stream'));\n }\n\n return new Promise((resolve, reject) => {\n let lastSuccessfulResult: Nullable<MediaRequestSuccessResult> = null;\n let lastFailedResult: Nullable<MediaRequestFailResult> = null;\n let isStreamRequestFulfilled = false;\n\n (Promise as any).reduce(constraintsCandidates, (total: any, candidate: MediaStreamConstraints) => {\n if (isStreamRequestFulfilled) {\n return;\n }\n\n const constraintType = get(constraints, 'video.videoResolution.constraintType') || get(constraints, 'video.videoResolution[0].constraintType');\n\n return this.getStreamPromiseByParsedConstraints(candidate, isDesktopMedia)\n .then((stream: MediaStream) => {\n lastSuccessfulResult = {\n mediaStream: stream,\n constraint: candidate,\n constraintType,\n isNew: true\n };\n trace.info('getHighestResolutionStream Success', lastSuccessfulResult);\n isStreamRequestFulfilled = true;\n resolve(lastSuccessfulResult);\n })\n .catch((failResult: MediaRequestFailResult) => {\n lastFailedResult = failResult;\n\n if (lastFailedResult.errorCode === MediaRequestErrorCode.PermissionDenied) {\n isStreamRequestFulfilled = true;\n reject(lastFailedResult);\n }\n });\n }, 0)\n .then(() => {\n if (!isStreamRequestFulfilled) {\n if (!lastFailedResult) {\n lastFailedResult = {\n errorCode: MediaRequestErrorCode.GeneralError,\n message: 'Suitable stream cannot be created'\n };\n }\n reject(lastFailedResult);\n }\n });\n });\n }\n\n private getUserMediaStreamMediaDevice(constraints: MediaStreamConstraints, isDesktopMedia: boolean) {\n let streamPromise = null;\n\n if (!isDesktopMedia) {\n streamPromise = navigator.mediaDevices.getUserMedia(constraints);\n } else {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n //@ts-ignore\n streamPromise = navigator.mediaDevices.getDisplayMedia\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n //@ts-ignore\n ? navigator.mediaDevices.getDisplayMedia(constraints)\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n //@ts-ignore\n : navigator.getDisplayMedia(constraints);\n }\n\n return streamPromise;\n }\n\n // eslint-disable-next-line consistent-return,@typescript-eslint/ban-ts-comment\n // @ts-ignore\n private getStreamPromiseByParsedConstraints(constraints: MediaStreamConstraints, isDesktopMedia: boolean): Promise<MediaStream> {\n trace.info('getStreamPromiseByParsedConstraints', constraints);\n\n try {\n return this.getUserMediaStreamMediaDevice(constraints, isDesktopMedia).catch((err: any) => {\n let streamPromise = null;\n\n trace.info('getStreamPromiseByParsedConstraints - get user stream error', err.name);\n\n // Android (Galaxy esp.) have a bug that when using facingMode it might cause NotReadableError. So\n // we should try again but without facingMode. The exception to the rule is when we don't have specific\n // device to use (like in IOS13 bug, as can be seen in MediaServiceBase.ts), in that case, we might end\n // up using the front camera, which is a privacy concern and the preference is to fallback from video\n if (err && (err.name === 'NotReadableError') && get(constraints, 'video.facingMode') &&\n get(constraints, 'video.deviceId')) {\n\n const newConstraints = constraints;\n\n trace.info(`getStreamPromiseByParsedConstraints - NotReadableError - Failed to get video user media stream with facingMode=${get(constraints, 'video.facingMode')}`, err.name);\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n delete newConstraints.video.facingMode;\n ((newConstraints.video as MediaTrackConstraints).deviceId as ConstrainDOMStringParameters) = {\n exact: (constraints.video as MediaTrackConstraints).deviceId\n } as any as ConstrainDOMStringParameters;\n\n streamPromise = this.getStreamPromiseByParsedConstraints(newConstraints, isDesktopMedia);\n } else if (err && err.name && constraints.audio && !constraints.video) {\n trace.info('getStreamPromiseByParsedConstraints - audioStreamFailed - Failed to get audio user media stream', err.name);\n\n return this.parseMediaErrorThenThrow({name: 'audioStreamFailed'});\n } else if (err && err.name && constraints.audio) {\n const newConstraints = constraints;\n\n trace.info('getStreamPromiseByParsedConstraints - Failed to get video and audio user media stream, try to get video media stream only', err.name);\n\n newConstraints.audio = false;\n streamPromise = this.getStreamPromiseByParsedConstraints(newConstraints, isDesktopMedia);\n } else if (err && !streamPromise) {\n trace.info('getStreamPromiseByParsedConstraints - Failed to get video user media stream', err && err.name);\n\n streamPromise = Promise.reject(err);\n }\n\n return streamPromise && streamPromise.catch(this.parseMediaErrorThenThrow);\n });\n } catch (e) {\n this.parseMediaErrorThenThrow(e);\n }\n }\n\n setGroupedDevices(groupedDevices: {video: MediaDeviceInfo[]; audio: MediaDeviceInfo[]}) {\n trace.info('setGroupedDevices', groupedDevices);\n this._groupedDevices = {video: groupedDevices.video\n ? {[CameraTypes.BACK]: last(groupedDevices.video), [CameraTypes.FRONT]: first(groupedDevices.video)}\n : null,\n audio: last(groupedDevices.audio) || null,\n camerasCount: groupedDevices.video.length};\n }\n\n private getParsedConstraints(isDesktopMedia: boolean, streamConstraints?: LocalMediaConstraints): MediaStreamConstraints[] {\n const constraintCandidates: MediaStreamConstraints[] = [];\n\n //TODO - Alex: need to understand which constraints not compatible with screen share\n if (isDesktopMedia) {\n return [{video: true}];\n }\n\n if (!streamConstraints) {\n return constraintCandidates;\n }\n\n const baseConstraints: MediaStreamConstraints = {};\n\n baseConstraints.audio = typeof streamConstraints.audio === 'boolean' ? streamConstraints.audio : undefined;\n\n if (!streamConstraints.video) {\n return [baseConstraints];\n }\n\n const cameraType = (streamConstraints.video !== 'boolean') &&\n (streamConstraints.video as LocalVideoStreamConstraints).videoSourceType;\n\n baseConstraints.video = {\n facingMode: cameraType && cameraType === LocalVideoSourceType.CAMERA_FRONT\n ? 'user'\n : 'environment',\n frameRate: {ideal: 15, max: 30}\n };\n\n const deviceId = get(this._groupedDevices, `video.${cameraType === LocalVideoSourceType.CAMERA_FRONT\n ? CameraTypes.FRONT\n : CameraTypes.BACK}.deviceId`);\n\n if (deviceId) {\n baseConstraints.video.deviceId = deviceId;\n\n if (this._groupedDevices.camerasCount > 1) {\n baseConstraints.video.facingMode = {exact: baseConstraints.video.facingMode} as any as ConstrainDOMStringParameters;\n }\n }\n\n const assignConstraint = (videoResolution: VideoStreamResolution): void => {\n const [width, height] = videoResolution.resolution.split('x');\n const constraintCandidate = assign({}, baseConstraints);\n\n constraintCandidate.video = assign({}, baseConstraints.video, {\n width: _constraintByType(width, videoResolution.constraintType),\n height: _constraintByType(height, videoResolution.constraintType)\n });\n constraintCandidates.push(constraintCandidate);\n };\n\n if ((baseConstraints.video && typeof streamConstraints.video === 'boolean') ||\n !((streamConstraints.video as LocalVideoStreamConstraints).videoResolution instanceof Array)) {\n\n const defaultResolution: VideoStreamResolution = {\n resolution: DEFAULT_VIDEO_RESOLUTION,\n constraintType: DEFAULT_VIDEO_CONSTRAINT_TYPE\n };\n\n assignConstraint(defaultResolution);\n\n return constraintCandidates;\n }\n\n (streamConstraints.video as any).videoResolution.forEach(assignConstraint);\n\n return constraintCandidates;\n }\n\n private parseMediaErrorThenThrow(error: any): MediaRequestFailResult {\n if (error && error.errorCode) {\n throw error;\n }\n\n trace.error('Get media stream error.', error);\n const errorName = error && error.name ? error.name : '';\n\n const permissionErrorNames = [\n 'NotAllowedError',\n 'PermissionDismissedError',\n 'PermissionDeniedError'\n\n ];\n\n // const generalError = [\n // 'NotFoundError',\n // 'DevicesNotFoundError',\n // 'NotReadableError',\n // 'TrackStartError'\n // ];\n\n const constraintsErrors = [\n 'OverconstrainedError',\n 'ConstraintNotSatisfiedError'\n\n ];\n\n const isErrorOfType = (errorsArr: string[]) => errorsArr.filter((err: string) => err === errorName).length > 0;\n\n if (isErrorOfType(permissionErrorNames)) {\n throw {errorCode: MediaRequestErrorCode.PermissionDenied, message: errorName};\n }\n\n if (isErrorOfType(constraintsErrors)) {\n throw {errorCode: MediaRequestErrorCode.Overconstrained, message: errorName};\n }\n\n throw {errorCode: MediaRequestErrorCode.GeneralError, message: errorName};\n }\n}\n\nfunction _constraintByType(value: any, type: ConstraintType): any {\n switch (type) {\n case ConstraintType.MIN:\n return {min: value};\n default:\n return {ideal: value};\n }\n}\n"]}
1
+ {"version":3,"file":"LocalStreamManager.d.ts","sourceRoot":"","sources":["../src/LocalStreamManager.ts"],"names":[],"mappings":"AASA,OAAO,EAAC,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AAEjD,OAAO,EACH,iBAAiB,EACjB,qBAAqB,EACrB,2BAA2B,EAE3B,yBAAyB,EAE5B,MAAM,kBAAkB,CAAC;AAY1B,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,MAAM;QACZ,qBAAqB,EAAE,QAAQ,CAAC,yBAAyB,CAAC,CAAC;QAC3D,wBAAwB,EAAE,QAAQ,CAAC,yBAAyB,CAAC,CAAC;QAC9D,2BAA2B,EAAE,QAAQ,CAAC,qBAAqB,CAAC,CAAC;QAC7D,0BAA0B,EAAE,OAAO,CAAC;KACvC;CACJ;AAeD,UAAU,eAAe;IACrB,KAAK,EAAE,QAAQ,CAAC;QAAC,IAAI,CAAC,EAAE,eAAe,CAAC;QAAC,KAAK,CAAC,EAAE,eAAe,CAAA;KAAC,CAAC,CAAC;IACnE,KAAK,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IACjC,YAAY,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,kBAAkB;IAC3B,OAAO,CAAC,WAAW,CAAoB;IAEvC,OAAO,CAAC,eAAe,CAAgE;gBAE3E,WAAW,EAAE,iBAAiB;IAO1C,IAAI,cAAc,oBAEjB;IAED,kBAAkB,CAAC,WAAW,EAAE,qBAAqB,GAAG,OAAO,CAAC,yBAAyB,CAAC;IA4C1F,qBAAqB,CAAC,WAAW,EAAE,2BAA2B,GAAG,OAAO,CAAC,yBAAyB,CAAC;IA4CnG,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBvC,yBAAyB,IAAI,OAAO,CAAC,IAAI,CAAC;IAqB1C,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAMhC,OAAO,CAAC,0BAA0B;IAkElC,OAAO,CAAC,6BAA6B;IAoBrC,OAAO,CAAC,mCAAmC;IA0E3C,iBAAiB,CAAC,cAAc,EAAE;QAAC,KAAK,EAAE,eAAe,EAAE,CAAC;QAAC,KAAK,EAAE,eAAe,EAAE,CAAA;KAAC;IAWtF,OAAO,CAAC,oBAAoB;IA6E5B,OAAO,CAAC,wBAAwB;CA+BnC"}
@@ -1,19 +1,17 @@
1
1
  "use strict";
2
-
3
- var __assign = undefined && undefined.__assign || function () {
4
- __assign = Object.assign || function (t) {
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
5
4
  for (var s, i = 1, n = arguments.length; i < n; i++) {
6
5
  s = arguments[i];
7
- for (var p in s) {
8
- if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
9
- }
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
10
8
  }
11
9
  return t;
12
10
  };
13
11
  return __assign.apply(this, arguments);
14
12
  };
15
- var __importDefault = undefined && undefined.__importDefault || function (mod) {
16
- return mod && mod.__esModule ? mod : { "default": mod };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
17
15
  };
18
16
  Object.defineProperty(exports, "__esModule", { value: true });
19
17
  exports.LocalStreamManager = void 0;
@@ -31,8 +29,8 @@ window.latestDesktopMediaStream = null;
31
29
  var desktopMediaPromise = null;
32
30
  window.mediaStreamAlreadyReplaced = false;
33
31
  window.latestLocalMediaConstraints = null;
34
- var trace = MediaTracer_1.getMediaTracer('LocalStreamManager');
35
- var LocalStreamManager = /** @class */function () {
32
+ var trace = (0, MediaTracer_1.getMediaTracer)('LocalStreamManager');
33
+ var LocalStreamManager = (function () {
36
34
  function LocalStreamManager(environment) {
37
35
  this._groupedDevices = { video: null, audio: null, camerasCount: 0 };
38
36
  this.environment = environment;
@@ -40,7 +38,7 @@ var LocalStreamManager = /** @class */function () {
40
38
  this.clearAllStreams = this.clearAllStreams.bind(this);
41
39
  }
42
40
  Object.defineProperty(LocalStreamManager.prototype, "groupedDevices", {
43
- get: function get() {
41
+ get: function () {
44
42
  return this._groupedDevices;
45
43
  },
46
44
  enumerable: false,
@@ -60,21 +58,25 @@ var LocalStreamManager = /** @class */function () {
60
58
  this.destroyUserMediaStream();
61
59
  }
62
60
  userMediaPromise = new bluebird_1.Promise(function (resolve, reject) {
63
- var catchHandler = function catchHandler(err) {
61
+ var catchHandler = function (err) {
64
62
  userMediaPromise = null;
65
63
  window.latestUserMediaStream = null;
66
64
  trace.error('getUserMedia error', err);
67
65
  reject(err);
68
66
  };
69
67
  try {
70
- _this.getHighestResolutionStream(false, constraints).then(function (streamResult) {
68
+ _this.getHighestResolutionStream(false, constraints)
69
+ .then(function (streamResult) {
71
70
  userMediaPromise = null;
72
71
  window.latestUserMediaStream = streamResult;
73
- window.latestLocalMediaConstraints = cloneDeep_1.default(constraints);
74
- window.latestLocalMediaConstraints.audio = streamResult.constraint && streamResult.constraint.audio;
72
+ window.latestLocalMediaConstraints = (0, cloneDeep_1.default)(constraints);
73
+ window.latestLocalMediaConstraints.audio = (streamResult.constraint &&
74
+ streamResult.constraint.audio);
75
75
  resolve(__assign(__assign({}, window.latestUserMediaStream), { isNew: true }));
76
- }).catch(catchHandler);
77
- } catch (err) {
76
+ })
77
+ .catch(catchHandler);
78
+ }
79
+ catch (err) {
78
80
  catchHandler(err);
79
81
  }
80
82
  });
@@ -89,7 +91,6 @@ var LocalStreamManager = /** @class */function () {
89
91
  if (window.latestDesktopMediaStream) {
90
92
  var track = window.latestDesktopMediaStream.mediaStream.getVideoTracks();
91
93
  if (track.length > 0 && track[0].readyState === 'live') {
92
- //return Promise.resolve();
93
94
  return bluebird_1.Promise.resolve(__assign(__assign({}, window.latestDesktopMediaStream), { isNew: false }));
94
95
  }
95
96
  this.destroyDesktopMediaStream().catch(function (error) {
@@ -97,19 +98,22 @@ var LocalStreamManager = /** @class */function () {
97
98
  });
98
99
  }
99
100
  desktopMediaPromise = new bluebird_1.Promise(function (resolve, reject) {
100
- var mediaCatchHandler = function mediaCatchHandler(err) {
101
+ var mediaCatchHandler = function (err) {
101
102
  desktopMediaPromise = null;
102
103
  window.latestDesktopMediaStream = null;
103
104
  trace.error('getDisplayMedia error', err);
104
105
  reject(err);
105
106
  };
106
107
  try {
107
- _this.getHighestResolutionStream(true, { video: constraints, audio: false }).then(function (streamResult) {
108
+ _this.getHighestResolutionStream(true, { video: constraints, audio: false })
109
+ .then(function (streamResult) {
108
110
  desktopMediaPromise = null;
109
111
  window.latestDesktopMediaStream = streamResult;
110
112
  resolve(__assign(__assign({}, window.latestDesktopMediaStream), { isNew: true }));
111
- }).catch(mediaCatchHandler);
112
- } catch (err) {
113
+ })
114
+ .catch(mediaCatchHandler);
115
+ }
116
+ catch (err) {
113
117
  mediaCatchHandler(err);
114
118
  }
115
119
  });
@@ -127,7 +131,8 @@ var LocalStreamManager = /** @class */function () {
127
131
  track.stop();
128
132
  });
129
133
  trace.info('destroyUserMediaStream - stop all tracks');
130
- } catch (e) {
134
+ }
135
+ catch (e) {
131
136
  trace.info('destroyUserMediaStream - Failed to stop all tracks', e);
132
137
  }
133
138
  }
@@ -143,7 +148,8 @@ var LocalStreamManager = /** @class */function () {
143
148
  track.stop();
144
149
  });
145
150
  trace.info('destroyDesktopMediaStream - stop all tracks');
146
- } catch (e) {
151
+ }
152
+ catch (e) {
147
153
  trace.info('destroyDesktopMediaStream - Failed to stop all tracks', e);
148
154
  }
149
155
  }
@@ -151,9 +157,7 @@ var LocalStreamManager = /** @class */function () {
151
157
  };
152
158
  LocalStreamManager.prototype.clearAllStreams = function () {
153
159
  trace.info('LocalStreamManager Clearing all streams');
154
- return bluebird_1.Promise.all([this.destroyDesktopMediaStream(), this.destroyUserMediaStream()]).then(function () {
155
- return undefined;
156
- });
160
+ return bluebird_1.Promise.all([this.destroyDesktopMediaStream(), this.destroyUserMediaStream()]).then(function () { return undefined; });
157
161
  };
158
162
  LocalStreamManager.prototype.getHighestResolutionStream = function (isDesktopMedia, constraints) {
159
163
  var _this = this;
@@ -166,12 +170,15 @@ var LocalStreamManager = /** @class */function () {
166
170
  var lastSuccessfulResult = null;
167
171
  var lastFailedResult = null;
168
172
  var isStreamRequestFulfilled = false;
169
- bluebird_1.Promise.reduce(constraintsCandidates, function (total, candidate) {
173
+ bluebird_1.Promise
174
+ .reduce(constraintsCandidates, function (total, candidate) {
170
175
  if (isStreamRequestFulfilled) {
171
176
  return;
172
177
  }
173
- var constraintType = get_1.default(constraints, 'video.videoResolution.constraintType') || get_1.default(constraints, 'video.videoResolution[0].constraintType');
174
- return _this.getStreamPromiseByParsedConstraints(candidate, isDesktopMedia).then(function (stream) {
178
+ var constraintType = (0, get_1.default)(constraints, 'video.videoResolution.constraintType') ||
179
+ (0, get_1.default)(constraints, 'video.videoResolution[0].constraintType');
180
+ return _this.getStreamPromiseByParsedConstraints(candidate, isDesktopMedia)
181
+ .then(function (stream) {
175
182
  lastSuccessfulResult = {
176
183
  mediaStream: stream,
177
184
  constraint: candidate,
@@ -181,14 +188,16 @@ var LocalStreamManager = /** @class */function () {
181
188
  trace.info('getHighestResolutionStream Success', lastSuccessfulResult);
182
189
  isStreamRequestFulfilled = true;
183
190
  resolve(lastSuccessfulResult);
184
- }).catch(function (failResult) {
191
+ })
192
+ .catch(function (failResult) {
185
193
  lastFailedResult = failResult;
186
194
  if (lastFailedResult.errorCode === MediaConstants_1.MediaRequestErrorCode.PermissionDenied) {
187
195
  isStreamRequestFulfilled = true;
188
196
  reject(lastFailedResult);
189
197
  }
190
198
  });
191
- }, 0).then(function () {
199
+ }, 0)
200
+ .then(function () {
192
201
  if (!isStreamRequestFulfilled) {
193
202
  if (!lastFailedResult) {
194
203
  lastFailedResult = {
@@ -205,21 +214,16 @@ var LocalStreamManager = /** @class */function () {
205
214
  var streamPromise = null;
206
215
  if (!isDesktopMedia) {
207
216
  streamPromise = navigator.mediaDevices.getUserMedia(constraints);
208
- } else {
209
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
210
- //@ts-ignore
217
+ }
218
+ else {
211
219
  streamPromise = navigator.mediaDevices.getDisplayMedia
212
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
213
- //@ts-ignore
214
- ? navigator.mediaDevices.getDisplayMedia(constraints)
215
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
216
- //@ts-ignore
217
- : navigator.getDisplayMedia(constraints);
220
+ ?
221
+ navigator.mediaDevices.getDisplayMedia(constraints)
222
+ :
223
+ navigator.getDisplayMedia(constraints);
218
224
  }
219
225
  return streamPromise;
220
226
  };
221
- // eslint-disable-next-line consistent-return,@typescript-eslint/ban-ts-comment
222
- // @ts-ignore
223
227
  LocalStreamManager.prototype.getStreamPromiseByParsedConstraints = function (constraints, isDesktopMedia) {
224
228
  var _this = this;
225
229
  trace.info('getStreamPromiseByParsedConstraints', constraints);
@@ -227,47 +231,51 @@ var LocalStreamManager = /** @class */function () {
227
231
  return this.getUserMediaStreamMediaDevice(constraints, isDesktopMedia).catch(function (err) {
228
232
  var streamPromise = null;
229
233
  trace.info('getStreamPromiseByParsedConstraints - get user stream error', err.name);
230
- // Android (Galaxy esp.) have a bug that when using facingMode it might cause NotReadableError. So
231
- // we should try again but without facingMode. The exception to the rule is when we don't have specific
232
- // device to use (like in IOS13 bug, as can be seen in MediaServiceBase.ts), in that case, we might end
233
- // up using the front camera, which is a privacy concern and the preference is to fallback from video
234
- if (err && err.name === 'NotReadableError' && get_1.default(constraints, 'video.facingMode') && get_1.default(constraints, 'video.deviceId')) {
234
+ if (err &&
235
+ err.name === 'NotReadableError' &&
236
+ (0, get_1.default)(constraints, 'video.facingMode') &&
237
+ (0, get_1.default)(constraints, 'video.deviceId')) {
235
238
  var newConstraints = constraints;
236
- trace.info("getStreamPromiseByParsedConstraints - NotReadableError - Failed to get video user media stream with facingMode=" + get_1.default(constraints, 'video.facingMode'), err.name);
237
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
238
- // @ts-ignore
239
+ trace.info("getStreamPromiseByParsedConstraints - NotReadableError - Failed to get video user media stream with facingMode=".concat((0, get_1.default)(constraints, 'video.facingMode')), err.name);
239
240
  delete newConstraints.video.facingMode;
240
241
  newConstraints.video.deviceId = {
241
242
  exact: constraints.video.deviceId
242
243
  };
243
244
  streamPromise = _this.getStreamPromiseByParsedConstraints(newConstraints, isDesktopMedia);
244
- } else if (err && err.name && constraints.audio && !constraints.video) {
245
+ }
246
+ else if (err && err.name && constraints.audio && !constraints.video) {
245
247
  trace.info('getStreamPromiseByParsedConstraints - audioStreamFailed - Failed to get audio user media stream', err.name);
246
248
  return _this.parseMediaErrorThenThrow({ name: 'audioStreamFailed' });
247
- } else if (err && err.name && constraints.audio) {
249
+ }
250
+ else if (err && err.name && constraints.audio) {
248
251
  var newConstraints = constraints;
249
252
  trace.info('getStreamPromiseByParsedConstraints - Failed to get video and audio user media stream, try to get video media stream only', err.name);
250
253
  newConstraints.audio = false;
251
254
  streamPromise = _this.getStreamPromiseByParsedConstraints(newConstraints, isDesktopMedia);
252
- } else if (err && !streamPromise) {
255
+ }
256
+ else if (err && !streamPromise) {
253
257
  trace.info('getStreamPromiseByParsedConstraints - Failed to get video user media stream', err && err.name);
254
258
  streamPromise = bluebird_1.Promise.reject(err);
255
259
  }
256
260
  return streamPromise && streamPromise.catch(_this.parseMediaErrorThenThrow);
257
261
  });
258
- } catch (e) {
259
- this.parseMediaErrorThenThrow(e);
262
+ }
263
+ catch (e) {
264
+ return this.parseMediaErrorThenThrow(e);
260
265
  }
261
266
  };
262
267
  LocalStreamManager.prototype.setGroupedDevices = function (groupedDevices) {
263
268
  var _a;
264
269
  trace.info('setGroupedDevices', groupedDevices);
265
- this._groupedDevices = { video: groupedDevices.video ? (_a = {}, _a[MediaConstants_1.CameraTypes.BACK] = last_1.default(groupedDevices.video), _a[MediaConstants_1.CameraTypes.FRONT] = first_1.default(groupedDevices.video), _a) : null, audio: last_1.default(groupedDevices.audio) || null,
266
- camerasCount: groupedDevices.video.length };
270
+ this._groupedDevices = {
271
+ video: groupedDevices.video
272
+ ? (_a = {}, _a[MediaConstants_1.CameraTypes.BACK] = (0, last_1.default)(groupedDevices.video), _a[MediaConstants_1.CameraTypes.FRONT] = (0, first_1.default)(groupedDevices.video), _a) : null,
273
+ audio: (0, last_1.default)(groupedDevices.audio) || null,
274
+ camerasCount: groupedDevices.video.length
275
+ };
267
276
  };
268
277
  LocalStreamManager.prototype.getParsedConstraints = function (isDesktopMedia, streamConstraints) {
269
278
  var constraintCandidates = [];
270
- //TODO - Alex: need to understand which constraints not compatible with screen share
271
279
  if (isDesktopMedia) {
272
280
  return [{ video: true }];
273
281
  }
@@ -279,30 +287,32 @@ var LocalStreamManager = /** @class */function () {
279
287
  if (!streamConstraints.video) {
280
288
  return [baseConstraints];
281
289
  }
282
- var cameraType = streamConstraints.video !== 'boolean' && streamConstraints.video.videoSourceType;
290
+ var cameraType = streamConstraints.video !== 'boolean' &&
291
+ streamConstraints.video.videoSourceType;
283
292
  baseConstraints.video = {
284
293
  facingMode: cameraType && cameraType === MediaConstants_1.LocalVideoSourceType.CAMERA_FRONT ? 'user' : 'environment',
285
294
  frameRate: { ideal: 15, max: 30 }
286
295
  };
287
- var deviceId = get_1.default(this._groupedDevices, "video." + (cameraType === MediaConstants_1.LocalVideoSourceType.CAMERA_FRONT ? MediaConstants_1.CameraTypes.FRONT : MediaConstants_1.CameraTypes.BACK) + ".deviceId");
296
+ var deviceId = (0, get_1.default)(this._groupedDevices, "video.".concat(cameraType === MediaConstants_1.LocalVideoSourceType.CAMERA_FRONT ? MediaConstants_1.CameraTypes.FRONT : MediaConstants_1.CameraTypes.BACK, ".deviceId"));
288
297
  if (deviceId) {
289
298
  baseConstraints.video.deviceId = deviceId;
290
299
  if (this._groupedDevices.camerasCount > 1) {
291
- baseConstraints.video.facingMode = { exact: baseConstraints.video.facingMode };
300
+ baseConstraints.video.facingMode = {
301
+ exact: baseConstraints.video.facingMode
302
+ };
292
303
  }
293
304
  }
294
- var assignConstraint = function assignConstraint(videoResolution) {
295
- var _a = videoResolution.resolution.split('x'),
296
- width = _a[0],
297
- height = _a[1];
298
- var constraintCandidate = assign_1.default({}, baseConstraints);
299
- constraintCandidate.video = assign_1.default({}, baseConstraints.video, {
305
+ var assignConstraint = function (videoResolution) {
306
+ var _a = videoResolution.resolution.split('x'), width = _a[0], height = _a[1];
307
+ var constraintCandidate = (0, assign_1.default)({}, baseConstraints);
308
+ constraintCandidate.video = (0, assign_1.default)({}, baseConstraints.video, {
300
309
  width: _constraintByType(width, videoResolution.constraintType),
301
310
  height: _constraintByType(height, videoResolution.constraintType)
302
311
  });
303
312
  constraintCandidates.push(constraintCandidate);
304
313
  };
305
- if (baseConstraints.video && typeof streamConstraints.video === 'boolean' || !(streamConstraints.video.videoResolution instanceof Array)) {
314
+ if ((baseConstraints.video && typeof streamConstraints.video === 'boolean') ||
315
+ !(streamConstraints.video.videoResolution instanceof Array)) {
306
316
  var defaultResolution = {
307
317
  resolution: MediaConstants_1.DEFAULT_VIDEO_RESOLUTION,
308
318
  constraintType: MediaConstants_1.DEFAULT_VIDEO_CONSTRAINT_TYPE
@@ -320,18 +330,8 @@ var LocalStreamManager = /** @class */function () {
320
330
  trace.error('Get media stream error.', error);
321
331
  var errorName = error && error.name ? error.name : '';
322
332
  var permissionErrorNames = ['NotAllowedError', 'PermissionDismissedError', 'PermissionDeniedError'];
323
- // const generalError = [
324
- // 'NotFoundError',
325
- // 'DevicesNotFoundError',
326
- // 'NotReadableError',
327
- // 'TrackStartError'
328
- // ];
329
333
  var constraintsErrors = ['OverconstrainedError', 'ConstraintNotSatisfiedError'];
330
- var isErrorOfType = function isErrorOfType(errorsArr) {
331
- return errorsArr.filter(function (err) {
332
- return err === errorName;
333
- }).length > 0;
334
- };
334
+ var isErrorOfType = function (errorsArr) { return errorsArr.filter(function (err) { return err === errorName; }).length > 0; };
335
335
  if (isErrorOfType(permissionErrorNames)) {
336
336
  throw { errorCode: MediaConstants_1.MediaRequestErrorCode.PermissionDenied, message: errorName };
337
337
  }
@@ -341,7 +341,7 @@ var LocalStreamManager = /** @class */function () {
341
341
  throw { errorCode: MediaConstants_1.MediaRequestErrorCode.GeneralError, message: errorName };
342
342
  };
343
343
  return LocalStreamManager;
344
- }();
344
+ }());
345
345
  exports.LocalStreamManager = LocalStreamManager;
346
346
  function _constraintByType(value, type) {
347
347
  switch (type) {
@@ -351,6 +351,4 @@ function _constraintByType(value, type) {
351
351
  return { ideal: value };
352
352
  }
353
353
  }
354
-
355
- //# sourceMappingURL=LocalStreamManager.js.map
356
- //# sourceMappingURL=LocalStreamManager.js.map
354
+ //# sourceMappingURL=LocalStreamManager.js.map