@sbhjt-gr/react-native-webrtc 137.0.2
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.
- package/.clang-format +11 -0
- package/.eslintignore +6 -0
- package/.nvmrc +1 -0
- package/ISSUE_TEMPLATE.md +40 -0
- package/LICENSE +22 -0
- package/README.md +82 -0
- package/android/build.gradle +36 -0
- package/android/consumer-rules.pro +3 -0
- package/android/src/main/AndroidManifest.xml +11 -0
- package/android/src/main/java/com/oney/WebRTCModule/AbstractVideoCaptureController.java +113 -0
- package/android/src/main/java/com/oney/WebRTCModule/CameraCaptureController.java +338 -0
- package/android/src/main/java/com/oney/WebRTCModule/CameraEventsHandler.java +49 -0
- package/android/src/main/java/com/oney/WebRTCModule/DataChannelWrapper.java +99 -0
- package/android/src/main/java/com/oney/WebRTCModule/DataPacketCryptorManager.java +63 -0
- package/android/src/main/java/com/oney/WebRTCModule/DisplayUtils.java +16 -0
- package/android/src/main/java/com/oney/WebRTCModule/EglUtils.java +66 -0
- package/android/src/main/java/com/oney/WebRTCModule/GetUserMediaImpl.java +539 -0
- package/android/src/main/java/com/oney/WebRTCModule/LibraryLoader.java +21 -0
- package/android/src/main/java/com/oney/WebRTCModule/MediaProjectionNotification.java +70 -0
- package/android/src/main/java/com/oney/WebRTCModule/MediaProjectionService.java +82 -0
- package/android/src/main/java/com/oney/WebRTCModule/PeerConnectionObserver.java +588 -0
- package/android/src/main/java/com/oney/WebRTCModule/RTCCryptoManager.java +493 -0
- package/android/src/main/java/com/oney/WebRTCModule/RTCVideoViewManager.java +98 -0
- package/android/src/main/java/com/oney/WebRTCModule/ReactBridgeUtil.java +36 -0
- package/android/src/main/java/com/oney/WebRTCModule/ScreenCaptureController.java +94 -0
- package/android/src/main/java/com/oney/WebRTCModule/SerializeUtils.java +342 -0
- package/android/src/main/java/com/oney/WebRTCModule/StringUtils.java +101 -0
- package/android/src/main/java/com/oney/WebRTCModule/ThreadUtils.java +41 -0
- package/android/src/main/java/com/oney/WebRTCModule/TrackCapturerEventsEmitter.java +34 -0
- package/android/src/main/java/com/oney/WebRTCModule/VideoTrackAdapter.java +137 -0
- package/android/src/main/java/com/oney/WebRTCModule/WebRTCModule.java +1593 -0
- package/android/src/main/java/com/oney/WebRTCModule/WebRTCModuleOptions.java +33 -0
- package/android/src/main/java/com/oney/WebRTCModule/WebRTCModulePackage.java +21 -0
- package/android/src/main/java/com/oney/WebRTCModule/WebRTCView.java +583 -0
- package/android/src/main/java/com/oney/WebRTCModule/videoEffects/ProcessorProvider.java +38 -0
- package/android/src/main/java/com/oney/WebRTCModule/videoEffects/VideoEffectProcessor.java +59 -0
- package/android/src/main/java/com/oney/WebRTCModule/videoEffects/VideoFrameProcessor.java +19 -0
- package/android/src/main/java/com/oney/WebRTCModule/videoEffects/VideoFrameProcessorFactoryInterface.java +12 -0
- package/android/src/main/java/com/oney/WebRTCModule/webrtcutils/H264AndSoftwareVideoDecoderFactory.java +73 -0
- package/android/src/main/java/com/oney/WebRTCModule/webrtcutils/H264AndSoftwareVideoEncoderFactory.java +73 -0
- package/android/src/main/java/com/oney/WebRTCModule/webrtcutils/SoftwareVideoDecoderFactoryProxy.java +36 -0
- package/android/src/main/java/com/oney/WebRTCModule/webrtcutils/SoftwareVideoEncoderFactoryProxy.java +36 -0
- package/android/src/main/java/org/webrtc/Camera1Helper.java +54 -0
- package/android/src/main/java/org/webrtc/Camera2Helper.java +52 -0
- package/android/src/main/res/values/strings.xml +5 -0
- package/android/src/main/res/values/styles.xml +8 -0
- package/apple/.placeholder +0 -0
- package/ios/RCTWebRTC/CaptureController.h +18 -0
- package/ios/RCTWebRTC/CaptureController.m +29 -0
- package/ios/RCTWebRTC/CapturerEventsDelegate.h +12 -0
- package/ios/RCTWebRTC/DataChannelWrapper.h +27 -0
- package/ios/RCTWebRTC/DataChannelWrapper.m +42 -0
- package/ios/RCTWebRTC/I420Converter.h +22 -0
- package/ios/RCTWebRTC/I420Converter.m +164 -0
- package/ios/RCTWebRTC/PIPController.h +24 -0
- package/ios/RCTWebRTC/PIPController.m +234 -0
- package/ios/RCTWebRTC/RCTConvert+WebRTC.h +16 -0
- package/ios/RCTWebRTC/RCTConvert+WebRTC.m +206 -0
- package/ios/RCTWebRTC/RTCMediaStreamTrack+React.h +10 -0
- package/ios/RCTWebRTC/RTCMediaStreamTrack+React.m +16 -0
- package/ios/RCTWebRTC/RTCVideoViewManager.h +29 -0
- package/ios/RCTWebRTC/RTCVideoViewManager.m +411 -0
- package/ios/RCTWebRTC/SampleBufferVideoCallView.h +12 -0
- package/ios/RCTWebRTC/SampleBufferVideoCallView.m +178 -0
- package/ios/RCTWebRTC/ScreenCaptureController.h +20 -0
- package/ios/RCTWebRTC/ScreenCaptureController.m +83 -0
- package/ios/RCTWebRTC/ScreenCapturePickerViewManager.h +7 -0
- package/ios/RCTWebRTC/ScreenCapturePickerViewManager.m +60 -0
- package/ios/RCTWebRTC/ScreenCapturer.h +19 -0
- package/ios/RCTWebRTC/ScreenCapturer.m +264 -0
- package/ios/RCTWebRTC/SerializeUtils.h +28 -0
- package/ios/RCTWebRTC/SerializeUtils.m +314 -0
- package/ios/RCTWebRTC/SocketConnection.h +13 -0
- package/ios/RCTWebRTC/SocketConnection.m +137 -0
- package/ios/RCTWebRTC/TrackCapturerEventsEmitter.h +14 -0
- package/ios/RCTWebRTC/TrackCapturerEventsEmitter.m +37 -0
- package/ios/RCTWebRTC/VideoCaptureController.h +21 -0
- package/ios/RCTWebRTC/VideoCaptureController.m +328 -0
- package/ios/RCTWebRTC/WebRTCModule+Permissions.m +75 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCAudioSession.m +20 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCDataChannel.h +14 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCDataChannel.m +165 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCFrameCryptor.m +611 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCMediaStream.h +14 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCMediaStream.m +545 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCPeerConnection.h +24 -0
- package/ios/RCTWebRTC/WebRTCModule+RTCPeerConnection.m +1004 -0
- package/ios/RCTWebRTC/WebRTCModule+Transceivers.m +267 -0
- package/ios/RCTWebRTC/WebRTCModule+VideoTrackAdapter.h +12 -0
- package/ios/RCTWebRTC/WebRTCModule+VideoTrackAdapter.m +166 -0
- package/ios/RCTWebRTC/WebRTCModule.h +45 -0
- package/ios/RCTWebRTC/WebRTCModule.m +149 -0
- package/ios/RCTWebRTC/WebRTCModuleOptions.h +24 -0
- package/ios/RCTWebRTC/WebRTCModuleOptions.m +31 -0
- package/ios/RCTWebRTC/videoEffects/ProcessorProvider.h +9 -0
- package/ios/RCTWebRTC/videoEffects/ProcessorProvider.m +23 -0
- package/ios/RCTWebRTC/videoEffects/VideoEffectProcessor.h +13 -0
- package/ios/RCTWebRTC/videoEffects/VideoEffectProcessor.m +23 -0
- package/ios/RCTWebRTC/videoEffects/VideoFrameProcessor.h +8 -0
- package/ios/RCTWebRTC.xcodeproj/project.pbxproj +404 -0
- package/ios/RCTWebRTC.xcworkspace/contents.xcworkspacedata +10 -0
- package/lib/commonjs/Constraints.js +2 -0
- package/lib/commonjs/Constraints.js.map +1 -0
- package/lib/commonjs/EventEmitter.js +69 -0
- package/lib/commonjs/EventEmitter.js.map +1 -0
- package/lib/commonjs/Logger.js +47 -0
- package/lib/commonjs/Logger.js.map +1 -0
- package/lib/commonjs/MediaDevices.js +54 -0
- package/lib/commonjs/MediaDevices.js.map +1 -0
- package/lib/commonjs/MediaStream.js +137 -0
- package/lib/commonjs/MediaStream.js.map +1 -0
- package/lib/commonjs/MediaStreamError.js +19 -0
- package/lib/commonjs/MediaStreamError.js.map +1 -0
- package/lib/commonjs/MediaStreamErrorEvent.js +17 -0
- package/lib/commonjs/MediaStreamErrorEvent.js.map +1 -0
- package/lib/commonjs/MediaStreamTrack.js +239 -0
- package/lib/commonjs/MediaStreamTrack.js.map +1 -0
- package/lib/commonjs/MediaStreamTrackEvent.js +26 -0
- package/lib/commonjs/MediaStreamTrackEvent.js.map +1 -0
- package/lib/commonjs/MessageEvent.js +27 -0
- package/lib/commonjs/MessageEvent.js.map +1 -0
- package/lib/commonjs/Permissions.js +116 -0
- package/lib/commonjs/Permissions.js.map +1 -0
- package/lib/commonjs/RTCAudioSession.js +33 -0
- package/lib/commonjs/RTCAudioSession.js.map +1 -0
- package/lib/commonjs/RTCDataChannel.js +165 -0
- package/lib/commonjs/RTCDataChannel.js.map +1 -0
- package/lib/commonjs/RTCDataChannelEvent.js +26 -0
- package/lib/commonjs/RTCDataChannelEvent.js.map +1 -0
- package/lib/commonjs/RTCDataPacketCryptor.js +76 -0
- package/lib/commonjs/RTCDataPacketCryptor.js.map +1 -0
- package/lib/commonjs/RTCDataPacketCryptorFactory.js +27 -0
- package/lib/commonjs/RTCDataPacketCryptorFactory.js.map +1 -0
- package/lib/commonjs/RTCErrorEvent.js +23 -0
- package/lib/commonjs/RTCErrorEvent.js.map +1 -0
- package/lib/commonjs/RTCFrameCryptor.js +138 -0
- package/lib/commonjs/RTCFrameCryptor.js.map +1 -0
- package/lib/commonjs/RTCFrameCryptorFactory.js +81 -0
- package/lib/commonjs/RTCFrameCryptorFactory.js.map +1 -0
- package/lib/commonjs/RTCIceCandidate.js +34 -0
- package/lib/commonjs/RTCIceCandidate.js.map +1 -0
- package/lib/commonjs/RTCIceCandidateEvent.js +28 -0
- package/lib/commonjs/RTCIceCandidateEvent.js.map +1 -0
- package/lib/commonjs/RTCKeyProvider.js +111 -0
- package/lib/commonjs/RTCKeyProvider.js.map +1 -0
- package/lib/commonjs/RTCPIPView.js +38 -0
- package/lib/commonjs/RTCPIPView.js.map +1 -0
- package/lib/commonjs/RTCPeerConnection.js +694 -0
- package/lib/commonjs/RTCPeerConnection.js.map +1 -0
- package/lib/commonjs/RTCRtcpParameters.js +24 -0
- package/lib/commonjs/RTCRtcpParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpCapabilities.js +22 -0
- package/lib/commonjs/RTCRtpCapabilities.js.map +1 -0
- package/lib/commonjs/RTCRtpCodecCapability.js +19 -0
- package/lib/commonjs/RTCRtpCodecCapability.js.map +1 -0
- package/lib/commonjs/RTCRtpCodecParameters.js +38 -0
- package/lib/commonjs/RTCRtpCodecParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpEncodingParameters.js +78 -0
- package/lib/commonjs/RTCRtpEncodingParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpHeaderExtension.js +27 -0
- package/lib/commonjs/RTCRtpHeaderExtension.js.map +1 -0
- package/lib/commonjs/RTCRtpParameters.js +35 -0
- package/lib/commonjs/RTCRtpParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpReceiveParameters.js +15 -0
- package/lib/commonjs/RTCRtpReceiveParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpReceiver.js +53 -0
- package/lib/commonjs/RTCRtpReceiver.js.map +1 -0
- package/lib/commonjs/RTCRtpSendParameters.js +49 -0
- package/lib/commonjs/RTCRtpSendParameters.js.map +1 -0
- package/lib/commonjs/RTCRtpSender.js +67 -0
- package/lib/commonjs/RTCRtpSender.js.map +1 -0
- package/lib/commonjs/RTCRtpTransceiver.js +81 -0
- package/lib/commonjs/RTCRtpTransceiver.js.map +1 -0
- package/lib/commonjs/RTCSessionDescription.js +33 -0
- package/lib/commonjs/RTCSessionDescription.js.map +1 -0
- package/lib/commonjs/RTCTrackEvent.js +38 -0
- package/lib/commonjs/RTCTrackEvent.js.map +1 -0
- package/lib/commonjs/RTCUtil.js +186 -0
- package/lib/commonjs/RTCUtil.js.map +1 -0
- package/lib/commonjs/RTCView.js +16 -0
- package/lib/commonjs/RTCView.js.map +1 -0
- package/lib/commonjs/ScreenCapturePickerView.js +10 -0
- package/lib/commonjs/ScreenCapturePickerView.js.map +1 -0
- package/lib/commonjs/getDisplayMedia.js +33 -0
- package/lib/commonjs/getDisplayMedia.js.map +1 -0
- package/lib/commonjs/getUserMedia.js +101 -0
- package/lib/commonjs/getUserMedia.js.map +1 -0
- package/lib/commonjs/index.js +224 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/module/Constraints.js +2 -0
- package/lib/module/Constraints.js.map +1 -0
- package/lib/module/EventEmitter.js +58 -0
- package/lib/module/EventEmitter.js.map +1 -0
- package/lib/module/Logger.js +39 -0
- package/lib/module/Logger.js.map +1 -0
- package/lib/module/MediaDevices.js +46 -0
- package/lib/module/MediaDevices.js.map +1 -0
- package/lib/module/MediaStream.js +129 -0
- package/lib/module/MediaStream.js.map +1 -0
- package/lib/module/MediaStreamError.js +12 -0
- package/lib/module/MediaStreamError.js.map +1 -0
- package/lib/module/MediaStreamErrorEvent.js +10 -0
- package/lib/module/MediaStreamErrorEvent.js.map +1 -0
- package/lib/module/MediaStreamTrack.js +231 -0
- package/lib/module/MediaStreamTrack.js.map +1 -0
- package/lib/module/MediaStreamTrackEvent.js +19 -0
- package/lib/module/MediaStreamTrackEvent.js.map +1 -0
- package/lib/module/MessageEvent.js +20 -0
- package/lib/module/MessageEvent.js.map +1 -0
- package/lib/module/Permissions.js +109 -0
- package/lib/module/Permissions.js.map +1 -0
- package/lib/module/RTCAudioSession.js +26 -0
- package/lib/module/RTCAudioSession.js.map +1 -0
- package/lib/module/RTCDataChannel.js +155 -0
- package/lib/module/RTCDataChannel.js.map +1 -0
- package/lib/module/RTCDataChannelEvent.js +19 -0
- package/lib/module/RTCDataChannelEvent.js.map +1 -0
- package/lib/module/RTCDataPacketCryptor.js +66 -0
- package/lib/module/RTCDataPacketCryptor.js.map +1 -0
- package/lib/module/RTCDataPacketCryptorFactory.js +19 -0
- package/lib/module/RTCDataPacketCryptorFactory.js.map +1 -0
- package/lib/module/RTCErrorEvent.js +16 -0
- package/lib/module/RTCErrorEvent.js.map +1 -0
- package/lib/module/RTCFrameCryptor.js +128 -0
- package/lib/module/RTCFrameCryptor.js.map +1 -0
- package/lib/module/RTCFrameCryptorFactory.js +70 -0
- package/lib/module/RTCFrameCryptorFactory.js.map +1 -0
- package/lib/module/RTCIceCandidate.js +27 -0
- package/lib/module/RTCIceCandidate.js.map +1 -0
- package/lib/module/RTCIceCandidateEvent.js +21 -0
- package/lib/module/RTCIceCandidateEvent.js.map +1 -0
- package/lib/module/RTCKeyProvider.js +101 -0
- package/lib/module/RTCKeyProvider.js.map +1 -0
- package/lib/module/RTCPIPView.js +26 -0
- package/lib/module/RTCPIPView.js.map +1 -0
- package/lib/module/RTCPeerConnection.js +684 -0
- package/lib/module/RTCPeerConnection.js.map +1 -0
- package/lib/module/RTCRtcpParameters.js +17 -0
- package/lib/module/RTCRtcpParameters.js.map +1 -0
- package/lib/module/RTCRtpCapabilities.js +15 -0
- package/lib/module/RTCRtpCapabilities.js.map +1 -0
- package/lib/module/RTCRtpCodecCapability.js +12 -0
- package/lib/module/RTCRtpCodecCapability.js.map +1 -0
- package/lib/module/RTCRtpCodecParameters.js +31 -0
- package/lib/module/RTCRtpCodecParameters.js.map +1 -0
- package/lib/module/RTCRtpEncodingParameters.js +71 -0
- package/lib/module/RTCRtpEncodingParameters.js.map +1 -0
- package/lib/module/RTCRtpHeaderExtension.js +20 -0
- package/lib/module/RTCRtpHeaderExtension.js.map +1 -0
- package/lib/module/RTCRtpParameters.js +27 -0
- package/lib/module/RTCRtpParameters.js.map +1 -0
- package/lib/module/RTCRtpReceiveParameters.js +7 -0
- package/lib/module/RTCRtpReceiveParameters.js.map +1 -0
- package/lib/module/RTCRtpReceiver.js +45 -0
- package/lib/module/RTCRtpReceiver.js.map +1 -0
- package/lib/module/RTCRtpSendParameters.js +41 -0
- package/lib/module/RTCRtpSendParameters.js.map +1 -0
- package/lib/module/RTCRtpSender.js +59 -0
- package/lib/module/RTCRtpSender.js.map +1 -0
- package/lib/module/RTCRtpTransceiver.js +74 -0
- package/lib/module/RTCRtpTransceiver.js.map +1 -0
- package/lib/module/RTCSessionDescription.js +26 -0
- package/lib/module/RTCSessionDescription.js.map +1 -0
- package/lib/module/RTCTrackEvent.js +31 -0
- package/lib/module/RTCTrackEvent.js.map +1 -0
- package/lib/module/RTCUtil.js +176 -0
- package/lib/module/RTCUtil.js.map +1 -0
- package/lib/module/RTCView.js +11 -0
- package/lib/module/RTCView.js.map +1 -0
- package/lib/module/ScreenCapturePickerView.js +3 -0
- package/lib/module/ScreenCapturePickerView.js.map +1 -0
- package/lib/module/getDisplayMedia.js +26 -0
- package/lib/module/getDisplayMedia.js.map +1 -0
- package/lib/module/getUserMedia.js +92 -0
- package/lib/module/getUserMedia.js.map +1 -0
- package/lib/module/index.js +60 -0
- package/lib/module/index.js.map +1 -0
- package/lib/typescript/Constraints.d.ts +19 -0
- package/lib/typescript/EventEmitter.d.ts +7 -0
- package/lib/typescript/Logger.d.ts +13 -0
- package/lib/typescript/MediaDevices.d.ts +30 -0
- package/lib/typescript/MediaStream.d.ts +48 -0
- package/lib/typescript/MediaStreamError.d.ts +6 -0
- package/lib/typescript/MediaStreamErrorEvent.d.ts +6 -0
- package/lib/typescript/MediaStreamTrack.d.ts +103 -0
- package/lib/typescript/MediaStreamTrackEvent.d.ts +19 -0
- package/lib/typescript/MessageEvent.d.ts +21 -0
- package/lib/typescript/Permissions.d.ts +55 -0
- package/lib/typescript/RTCAudioSession.d.ts +10 -0
- package/lib/typescript/RTCDataChannel.d.ts +43 -0
- package/lib/typescript/RTCDataChannelEvent.d.ts +19 -0
- package/lib/typescript/RTCDataPacketCryptor.d.ts +12 -0
- package/lib/typescript/RTCDataPacketCryptorFactory.d.ts +6 -0
- package/lib/typescript/RTCErrorEvent.d.ts +12 -0
- package/lib/typescript/RTCFrameCryptor.d.ts +47 -0
- package/lib/typescript/RTCFrameCryptorFactory.d.ts +21 -0
- package/lib/typescript/RTCIceCandidate.d.ts +17 -0
- package/lib/typescript/RTCIceCandidateEvent.d.ts +20 -0
- package/lib/typescript/RTCKeyProvider.d.ts +21 -0
- package/lib/typescript/RTCPIPView.d.ts +15 -0
- package/lib/typescript/RTCPeerConnection.d.ts +117 -0
- package/lib/typescript/RTCRtcpParameters.d.ts +10 -0
- package/lib/typescript/RTCRtpCapabilities.d.ts +9 -0
- package/lib/typescript/RTCRtpCodecCapability.d.ts +7 -0
- package/lib/typescript/RTCRtpCodecParameters.d.ts +16 -0
- package/lib/typescript/RTCRtpEncodingParameters.d.ts +23 -0
- package/lib/typescript/RTCRtpHeaderExtension.d.ts +12 -0
- package/lib/typescript/RTCRtpParameters.d.ts +19 -0
- package/lib/typescript/RTCRtpReceiveParameters.d.ts +4 -0
- package/lib/typescript/RTCRtpReceiver.d.ts +21 -0
- package/lib/typescript/RTCRtpSendParameters.d.ts +20 -0
- package/lib/typescript/RTCRtpSender.d.ts +22 -0
- package/lib/typescript/RTCRtpTransceiver.d.ts +31 -0
- package/lib/typescript/RTCSessionDescription.d.ts +12 -0
- package/lib/typescript/RTCTrackEvent.d.ts +29 -0
- package/lib/typescript/RTCUtil.d.ts +37 -0
- package/lib/typescript/RTCView.d.ts +117 -0
- package/lib/typescript/ScreenCapturePickerView.d.ts +2 -0
- package/lib/typescript/getDisplayMedia.d.ts +2 -0
- package/lib/typescript/getUserMedia.d.ts +7 -0
- package/lib/typescript/index.d.ts +22 -0
- package/livekit-react-native-webrtc.podspec +29 -0
- package/macos/RCTWebRTC.xcodeproj/project.pbxproj +324 -0
- package/macos/RCTWebRTC.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -0
- package/macos/RCTWebRTC.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/metro.config.js +7 -0
- package/metro.config.macos.js +14 -0
- package/package.json +65 -0
- package/react-native.config.js +11 -0
- package/src/.eslintrc.cjs +67 -0
- package/src/Constraints.ts +21 -0
- package/src/EventEmitter.ts +83 -0
- package/src/Logger.ts +49 -0
- package/src/MediaDevices.ts +53 -0
- package/src/MediaStream.ts +161 -0
- package/src/MediaStreamError.ts +12 -0
- package/src/MediaStreamErrorEvent.ts +11 -0
- package/src/MediaStreamTrack.ts +331 -0
- package/src/MediaStreamTrackEvent.ts +25 -0
- package/src/MessageEvent.ts +26 -0
- package/src/Permissions.ts +133 -0
- package/src/RTCAudioSession.ts +25 -0
- package/src/RTCDataChannel.ts +190 -0
- package/src/RTCDataChannelEvent.ts +28 -0
- package/src/RTCDataPacketCryptor.ts +90 -0
- package/src/RTCDataPacketCryptorFactory.ts +25 -0
- package/src/RTCErrorEvent.ts +21 -0
- package/src/RTCFrameCryptor.ts +163 -0
- package/src/RTCFrameCryptorFactory.ts +102 -0
- package/src/RTCIceCandidate.ts +29 -0
- package/src/RTCIceCandidateEvent.ts +26 -0
- package/src/RTCKeyProvider.ts +117 -0
- package/src/RTCPIPView.tsx +47 -0
- package/src/RTCPeerConnection.ts +832 -0
- package/src/RTCRtcpParameters.ts +23 -0
- package/src/RTCRtpCapabilities.ts +16 -0
- package/src/RTCRtpCodecCapability.ts +13 -0
- package/src/RTCRtpCodecParameters.ts +44 -0
- package/src/RTCRtpEncodingParameters.ts +90 -0
- package/src/RTCRtpHeaderExtension.ts +27 -0
- package/src/RTCRtpParameters.ts +37 -0
- package/src/RTCRtpReceiveParameters.ts +7 -0
- package/src/RTCRtpReceiver.ts +60 -0
- package/src/RTCRtpSendParameters.ts +63 -0
- package/src/RTCRtpSender.ts +78 -0
- package/src/RTCRtpTransceiver.ts +107 -0
- package/src/RTCSessionDescription.ts +30 -0
- package/src/RTCTrackEvent.ts +42 -0
- package/src/RTCUtil.ts +211 -0
- package/src/RTCView.ts +122 -0
- package/src/ScreenCapturePickerView.ts +4 -0
- package/src/getDisplayMedia.ts +30 -0
- package/src/getUserMedia.ts +111 -0
- package/src/index.ts +101 -0
- package/tools/format.sh +6 -0
- package/tools/release.sh +45 -0
- package/tsconfig.json +16 -0
|
@@ -0,0 +1,684 @@
|
|
|
1
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
2
|
+
import { EventTarget, Event, defineEventAttribute } from 'event-target-shim/index';
|
|
3
|
+
import { NativeModules } from 'react-native';
|
|
4
|
+
import { addListener, removeListener } from './EventEmitter';
|
|
5
|
+
import Logger from './Logger';
|
|
6
|
+
import MediaStream from './MediaStream';
|
|
7
|
+
import MediaStreamTrack from './MediaStreamTrack';
|
|
8
|
+
import MediaStreamTrackEvent from './MediaStreamTrackEvent';
|
|
9
|
+
import RTCDataChannel from './RTCDataChannel';
|
|
10
|
+
import RTCDataChannelEvent from './RTCDataChannelEvent';
|
|
11
|
+
import RTCIceCandidate from './RTCIceCandidate';
|
|
12
|
+
import RTCIceCandidateEvent from './RTCIceCandidateEvent';
|
|
13
|
+
import RTCRtpReceiveParameters from './RTCRtpReceiveParameters';
|
|
14
|
+
import RTCRtpReceiver from './RTCRtpReceiver';
|
|
15
|
+
import RTCRtpSendParameters from './RTCRtpSendParameters';
|
|
16
|
+
import RTCRtpSender from './RTCRtpSender';
|
|
17
|
+
import RTCRtpTransceiver from './RTCRtpTransceiver';
|
|
18
|
+
import RTCSessionDescription from './RTCSessionDescription';
|
|
19
|
+
import RTCTrackEvent from './RTCTrackEvent';
|
|
20
|
+
import * as RTCUtil from './RTCUtil';
|
|
21
|
+
const log = new Logger('pc');
|
|
22
|
+
const {
|
|
23
|
+
WebRTCModule
|
|
24
|
+
} = NativeModules;
|
|
25
|
+
let nextPeerConnectionId = 0;
|
|
26
|
+
export default class RTCPeerConnection extends EventTarget {
|
|
27
|
+
constructor(configuration) {
|
|
28
|
+
super();
|
|
29
|
+
_defineProperty(this, "localDescription", null);
|
|
30
|
+
_defineProperty(this, "remoteDescription", null);
|
|
31
|
+
_defineProperty(this, "signalingState", 'stable');
|
|
32
|
+
_defineProperty(this, "iceGatheringState", 'new');
|
|
33
|
+
_defineProperty(this, "connectionState", 'new');
|
|
34
|
+
_defineProperty(this, "iceConnectionState", 'new');
|
|
35
|
+
_defineProperty(this, "_pcId", void 0);
|
|
36
|
+
_defineProperty(this, "_transceivers", void 0);
|
|
37
|
+
_defineProperty(this, "_remoteStreams", void 0);
|
|
38
|
+
_defineProperty(this, "_pendingTrackEvents", void 0);
|
|
39
|
+
this._pcId = nextPeerConnectionId++;
|
|
40
|
+
|
|
41
|
+
// Sanitize ICE servers.
|
|
42
|
+
if (configuration) {
|
|
43
|
+
var _configuration$iceSer;
|
|
44
|
+
const servers = (_configuration$iceSer = configuration === null || configuration === void 0 ? void 0 : configuration.iceServers) !== null && _configuration$iceSer !== void 0 ? _configuration$iceSer : [];
|
|
45
|
+
for (const server of servers) {
|
|
46
|
+
let urls = server.url || server.urls;
|
|
47
|
+
delete server.url;
|
|
48
|
+
delete server.urls;
|
|
49
|
+
if (!urls) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
if (!Array.isArray(urls)) {
|
|
53
|
+
urls = [urls];
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
// Native WebRTC does case sensitive parsing.
|
|
57
|
+
server.urls = urls.map(url => url.toLowerCase());
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// Filter out bogus servers.
|
|
61
|
+
configuration.iceServers = servers.filter(s => s.urls);
|
|
62
|
+
}
|
|
63
|
+
if (!WebRTCModule.peerConnectionInit(configuration, this._pcId)) {
|
|
64
|
+
throw new Error('Failed to initialize PeerConnection, check the native logs!');
|
|
65
|
+
}
|
|
66
|
+
this._transceivers = [];
|
|
67
|
+
this._remoteStreams = new Map();
|
|
68
|
+
this._pendingTrackEvents = [];
|
|
69
|
+
this._registerEvents();
|
|
70
|
+
log.debug(`${this._pcId} ctor`);
|
|
71
|
+
}
|
|
72
|
+
async createOffer(options) {
|
|
73
|
+
log.debug(`${this._pcId} createOffer`);
|
|
74
|
+
const {
|
|
75
|
+
sdpInfo,
|
|
76
|
+
newTransceivers,
|
|
77
|
+
transceiversInfo
|
|
78
|
+
} = await WebRTCModule.peerConnectionCreateOffer(this._pcId, RTCUtil.normalizeOfferOptions(options));
|
|
79
|
+
log.debug(`${this._pcId} createOffer OK`);
|
|
80
|
+
newTransceivers === null || newTransceivers === void 0 ? void 0 : newTransceivers.forEach(t => {
|
|
81
|
+
const {
|
|
82
|
+
transceiverOrder,
|
|
83
|
+
transceiver
|
|
84
|
+
} = t;
|
|
85
|
+
const newSender = new RTCRtpSender({
|
|
86
|
+
...transceiver.sender,
|
|
87
|
+
track: null
|
|
88
|
+
});
|
|
89
|
+
const remoteTrack = transceiver.receiver.track ? new MediaStreamTrack(transceiver.receiver.track) : null;
|
|
90
|
+
const newReceiver = new RTCRtpReceiver({
|
|
91
|
+
...transceiver.receiver,
|
|
92
|
+
track: remoteTrack
|
|
93
|
+
});
|
|
94
|
+
const newTransceiver = new RTCRtpTransceiver({
|
|
95
|
+
...transceiver,
|
|
96
|
+
sender: newSender,
|
|
97
|
+
receiver: newReceiver
|
|
98
|
+
});
|
|
99
|
+
this._insertTransceiverSorted(transceiverOrder, newTransceiver);
|
|
100
|
+
});
|
|
101
|
+
this._updateTransceivers(transceiversInfo);
|
|
102
|
+
return sdpInfo;
|
|
103
|
+
}
|
|
104
|
+
async createAnswer() {
|
|
105
|
+
log.debug(`${this._pcId} createAnswer`);
|
|
106
|
+
const {
|
|
107
|
+
sdpInfo,
|
|
108
|
+
transceiversInfo
|
|
109
|
+
} = await WebRTCModule.peerConnectionCreateAnswer(this._pcId, {});
|
|
110
|
+
this._updateTransceivers(transceiversInfo);
|
|
111
|
+
return sdpInfo;
|
|
112
|
+
}
|
|
113
|
+
setConfiguration(configuration) {
|
|
114
|
+
WebRTCModule.peerConnectionSetConfiguration(configuration, this._pcId);
|
|
115
|
+
}
|
|
116
|
+
async setLocalDescription(sessionDescription) {
|
|
117
|
+
var _desc;
|
|
118
|
+
log.debug(`${this._pcId} setLocalDescription`);
|
|
119
|
+
let desc;
|
|
120
|
+
if (sessionDescription) {
|
|
121
|
+
var _sessionDescription$s;
|
|
122
|
+
desc = {
|
|
123
|
+
type: sessionDescription.type,
|
|
124
|
+
sdp: (_sessionDescription$s = sessionDescription.sdp) !== null && _sessionDescription$s !== void 0 ? _sessionDescription$s : ''
|
|
125
|
+
};
|
|
126
|
+
if (!RTCUtil.isSdpTypeValid(desc.type)) {
|
|
127
|
+
throw new Error(`Invalid session description: invalid type: ${desc.type}`);
|
|
128
|
+
}
|
|
129
|
+
} else {
|
|
130
|
+
desc = null;
|
|
131
|
+
}
|
|
132
|
+
const {
|
|
133
|
+
sdpInfo,
|
|
134
|
+
transceiversInfo
|
|
135
|
+
} = await WebRTCModule.peerConnectionSetLocalDescription(this._pcId, desc);
|
|
136
|
+
if (sdpInfo.type && sdpInfo.sdp) {
|
|
137
|
+
this.localDescription = new RTCSessionDescription(sdpInfo);
|
|
138
|
+
} else {
|
|
139
|
+
this.localDescription = null;
|
|
140
|
+
}
|
|
141
|
+
this._updateTransceivers(transceiversInfo, /* removeStopped */((_desc = desc) === null || _desc === void 0 ? void 0 : _desc.type) === 'answer');
|
|
142
|
+
log.debug(`${this._pcId} setLocalDescription OK`);
|
|
143
|
+
}
|
|
144
|
+
async setRemoteDescription(sessionDescription) {
|
|
145
|
+
var _sessionDescription$s2, _desc$type;
|
|
146
|
+
log.debug(`${this._pcId} setRemoteDescription`);
|
|
147
|
+
if (!sessionDescription) {
|
|
148
|
+
return Promise.reject(new Error('No session description provided'));
|
|
149
|
+
}
|
|
150
|
+
const desc = {
|
|
151
|
+
type: sessionDescription.type,
|
|
152
|
+
sdp: (_sessionDescription$s2 = sessionDescription.sdp) !== null && _sessionDescription$s2 !== void 0 ? _sessionDescription$s2 : ''
|
|
153
|
+
};
|
|
154
|
+
if (!RTCUtil.isSdpTypeValid((_desc$type = desc.type) !== null && _desc$type !== void 0 ? _desc$type : '')) {
|
|
155
|
+
throw new Error(`Invalid session description: invalid type: ${desc.type}`);
|
|
156
|
+
}
|
|
157
|
+
const {
|
|
158
|
+
sdpInfo,
|
|
159
|
+
newTransceivers,
|
|
160
|
+
transceiversInfo
|
|
161
|
+
} = await WebRTCModule.peerConnectionSetRemoteDescription(this._pcId, desc);
|
|
162
|
+
if (sdpInfo.type && sdpInfo.sdp) {
|
|
163
|
+
this.remoteDescription = new RTCSessionDescription(sdpInfo);
|
|
164
|
+
} else {
|
|
165
|
+
this.remoteDescription = null;
|
|
166
|
+
}
|
|
167
|
+
newTransceivers === null || newTransceivers === void 0 ? void 0 : newTransceivers.forEach(t => {
|
|
168
|
+
const {
|
|
169
|
+
transceiverOrder,
|
|
170
|
+
transceiver
|
|
171
|
+
} = t;
|
|
172
|
+
const newSender = new RTCRtpSender({
|
|
173
|
+
...transceiver.sender,
|
|
174
|
+
track: null
|
|
175
|
+
});
|
|
176
|
+
const remoteTrack = transceiver.receiver.track ? new MediaStreamTrack(transceiver.receiver.track) : null;
|
|
177
|
+
const newReceiver = new RTCRtpReceiver({
|
|
178
|
+
...transceiver.receiver,
|
|
179
|
+
track: remoteTrack
|
|
180
|
+
});
|
|
181
|
+
const newTransceiver = new RTCRtpTransceiver({
|
|
182
|
+
...transceiver,
|
|
183
|
+
sender: newSender,
|
|
184
|
+
receiver: newReceiver
|
|
185
|
+
});
|
|
186
|
+
this._insertTransceiverSorted(transceiverOrder, newTransceiver);
|
|
187
|
+
});
|
|
188
|
+
this._updateTransceivers(transceiversInfo, /* removeStopped */desc.type === 'answer');
|
|
189
|
+
|
|
190
|
+
// Fire track events. They must fire before sRD resolves.
|
|
191
|
+
const pendingTrackEvents = this._pendingTrackEvents;
|
|
192
|
+
this._pendingTrackEvents = [];
|
|
193
|
+
for (const ev of pendingTrackEvents) {
|
|
194
|
+
const [transceiver] = this.getTransceivers().filter(t => t.receiver.id === ev.receiver.id);
|
|
195
|
+
|
|
196
|
+
// We need to fire this event for an existing track sometimes, like
|
|
197
|
+
// when the transceiver direction (on the sending side) switches from
|
|
198
|
+
// sendrecv to recvonly and then back.
|
|
199
|
+
|
|
200
|
+
// @ts-ignore
|
|
201
|
+
const track = transceiver.receiver.track;
|
|
202
|
+
transceiver._mid = ev.transceiver.mid;
|
|
203
|
+
transceiver._currentDirection = ev.transceiver.currentDirection;
|
|
204
|
+
transceiver._direction = ev.transceiver.direction;
|
|
205
|
+
|
|
206
|
+
// Get the stream object from the event. Create if necessary.
|
|
207
|
+
const streams = ev.streams.map(streamInfo => {
|
|
208
|
+
// Here we are making sure that we don't create stream objects that already exist
|
|
209
|
+
// So that event listeners do get the same object if it has been created before.
|
|
210
|
+
if (!this._remoteStreams.has(streamInfo.streamId)) {
|
|
211
|
+
const stream = new MediaStream({
|
|
212
|
+
streamId: streamInfo.streamId,
|
|
213
|
+
streamReactTag: streamInfo.streamReactTag,
|
|
214
|
+
tracks: []
|
|
215
|
+
});
|
|
216
|
+
this._remoteStreams.set(streamInfo.streamId, stream);
|
|
217
|
+
}
|
|
218
|
+
const stream = this._remoteStreams.get(streamInfo.streamId);
|
|
219
|
+
if (!(stream !== null && stream !== void 0 && stream._tracks.includes(track))) {
|
|
220
|
+
stream === null || stream === void 0 ? void 0 : stream._tracks.push(track);
|
|
221
|
+
}
|
|
222
|
+
return stream;
|
|
223
|
+
});
|
|
224
|
+
const eventData = {
|
|
225
|
+
streams,
|
|
226
|
+
transceiver,
|
|
227
|
+
track,
|
|
228
|
+
receiver: transceiver.receiver
|
|
229
|
+
};
|
|
230
|
+
this.dispatchEvent(new RTCTrackEvent('track', eventData));
|
|
231
|
+
streams.forEach(stream => {
|
|
232
|
+
stream.dispatchEvent(new MediaStreamTrackEvent('addtrack', {
|
|
233
|
+
track
|
|
234
|
+
}));
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
// Dispatch an unmute event for the track.
|
|
238
|
+
track._setMutedInternal(false);
|
|
239
|
+
}
|
|
240
|
+
log.debug(`${this._pcId} setRemoteDescription OK`);
|
|
241
|
+
}
|
|
242
|
+
async addIceCandidate(candidate) {
|
|
243
|
+
log.debug(`${this._pcId} addIceCandidate`);
|
|
244
|
+
if (!candidate || !candidate.candidate) {
|
|
245
|
+
// XXX end-of candidates is not implemented: https://bugs.chromium.org/p/webrtc/issues/detail?id=9218
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
if ((candidate.sdpMLineIndex === null || candidate.sdpMLineIndex === undefined) && (candidate.sdpMid === null || candidate.sdpMid === undefined)) {
|
|
249
|
+
throw new TypeError('`sdpMLineIndex` and `sdpMid` must not be both null or undefined');
|
|
250
|
+
}
|
|
251
|
+
const newSdp = await WebRTCModule.peerConnectionAddICECandidate(this._pcId, RTCUtil.deepClone(candidate));
|
|
252
|
+
this.remoteDescription = new RTCSessionDescription(newSdp);
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* @brief Adds a new track to the {@link RTCPeerConnection},
|
|
257
|
+
* and indicates that it is contained in the specified {@link MediaStream}s.
|
|
258
|
+
* This method has to be synchronous as the W3C API expects a track to be returned
|
|
259
|
+
* @param {MediaStreamTrack} track The track to be added
|
|
260
|
+
* @param {...MediaStream} streams One or more {@link MediaStream}s the track needs to be added to
|
|
261
|
+
* https://w3c.github.io/webrtc-pc/#dom-rtcpeerconnection-addtrack
|
|
262
|
+
*/
|
|
263
|
+
addTrack(track) {
|
|
264
|
+
log.debug(`${this._pcId} addTrack`);
|
|
265
|
+
if (this.connectionState === 'closed') {
|
|
266
|
+
throw new Error('Peer Connection is closed');
|
|
267
|
+
}
|
|
268
|
+
if (this._trackExists(track)) {
|
|
269
|
+
throw new Error('Track already exists in a sender');
|
|
270
|
+
}
|
|
271
|
+
for (var _len = arguments.length, streams = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|
272
|
+
streams[_key - 1] = arguments[_key];
|
|
273
|
+
}
|
|
274
|
+
const streamIds = streams.map(s => s.id);
|
|
275
|
+
const result = WebRTCModule.peerConnectionAddTrack(this._pcId, track.id, {
|
|
276
|
+
streamIds
|
|
277
|
+
});
|
|
278
|
+
if (result === null) {
|
|
279
|
+
throw new Error('Could not add sender');
|
|
280
|
+
}
|
|
281
|
+
const {
|
|
282
|
+
transceiverOrder,
|
|
283
|
+
transceiver,
|
|
284
|
+
sender
|
|
285
|
+
} = result;
|
|
286
|
+
|
|
287
|
+
// According to the W3C docs, the sender could have been reused, and
|
|
288
|
+
// so we check if that is the case, and update accordingly.
|
|
289
|
+
const [existingSender] = this.getSenders().filter(s => s.id === sender.id);
|
|
290
|
+
if (existingSender) {
|
|
291
|
+
// Update sender
|
|
292
|
+
existingSender._track = track;
|
|
293
|
+
|
|
294
|
+
// Update the corresponding transceiver as well
|
|
295
|
+
const [existingTransceiver] = this.getTransceivers().filter(t => t.sender.id === existingSender.id);
|
|
296
|
+
existingTransceiver._direction = transceiver.direction;
|
|
297
|
+
existingTransceiver._currentDirection = transceiver.currentDirection;
|
|
298
|
+
return existingSender;
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
// This is a new transceiver, should create a transceiver for it and add it
|
|
302
|
+
const newSender = new RTCRtpSender({
|
|
303
|
+
...transceiver.sender,
|
|
304
|
+
track
|
|
305
|
+
});
|
|
306
|
+
const remoteTrack = transceiver.receiver.track ? new MediaStreamTrack(transceiver.receiver.track) : null;
|
|
307
|
+
const newReceiver = new RTCRtpReceiver({
|
|
308
|
+
...transceiver.receiver,
|
|
309
|
+
track: remoteTrack
|
|
310
|
+
});
|
|
311
|
+
const newTransceiver = new RTCRtpTransceiver({
|
|
312
|
+
...transceiver,
|
|
313
|
+
sender: newSender,
|
|
314
|
+
receiver: newReceiver
|
|
315
|
+
});
|
|
316
|
+
this._insertTransceiverSorted(transceiverOrder, newTransceiver);
|
|
317
|
+
return newSender;
|
|
318
|
+
}
|
|
319
|
+
addTransceiver(source, init) {
|
|
320
|
+
log.debug(`${this._pcId} addTransceiver`);
|
|
321
|
+
let src = {};
|
|
322
|
+
if (source === 'audio') {
|
|
323
|
+
src = {
|
|
324
|
+
type: 'audio'
|
|
325
|
+
};
|
|
326
|
+
} else if (source === 'video') {
|
|
327
|
+
src = {
|
|
328
|
+
type: 'video'
|
|
329
|
+
};
|
|
330
|
+
} else {
|
|
331
|
+
src = {
|
|
332
|
+
trackId: source.id
|
|
333
|
+
};
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
// Extract the stream ids
|
|
337
|
+
if (init && init.streams) {
|
|
338
|
+
init.streamIds = init.streams.map(stream => stream.id);
|
|
339
|
+
}
|
|
340
|
+
const result = WebRTCModule.peerConnectionAddTransceiver(this._pcId, {
|
|
341
|
+
...src,
|
|
342
|
+
init: {
|
|
343
|
+
...init
|
|
344
|
+
}
|
|
345
|
+
});
|
|
346
|
+
if (result === null) {
|
|
347
|
+
throw new Error('Transceiver could not be added');
|
|
348
|
+
}
|
|
349
|
+
const t = result.transceiver;
|
|
350
|
+
let track = null;
|
|
351
|
+
if (typeof source === 'string') {
|
|
352
|
+
if (t.sender.track) {
|
|
353
|
+
track = new MediaStreamTrack(t.sender.track);
|
|
354
|
+
}
|
|
355
|
+
} else {
|
|
356
|
+
// 'source' is a MediaStreamTrack
|
|
357
|
+
track = source;
|
|
358
|
+
}
|
|
359
|
+
const sender = new RTCRtpSender({
|
|
360
|
+
...t.sender,
|
|
361
|
+
track
|
|
362
|
+
});
|
|
363
|
+
const remoteTrack = t.receiver.track ? new MediaStreamTrack(t.receiver.track) : null;
|
|
364
|
+
const receiver = new RTCRtpReceiver({
|
|
365
|
+
...t.receiver,
|
|
366
|
+
track: remoteTrack
|
|
367
|
+
});
|
|
368
|
+
const transceiver = new RTCRtpTransceiver({
|
|
369
|
+
...result.transceiver,
|
|
370
|
+
sender,
|
|
371
|
+
receiver
|
|
372
|
+
});
|
|
373
|
+
this._insertTransceiverSorted(result.transceiverOrder, transceiver);
|
|
374
|
+
return transceiver;
|
|
375
|
+
}
|
|
376
|
+
removeTrack(sender) {
|
|
377
|
+
log.debug(`${this._pcId} removeTrack`);
|
|
378
|
+
if (this._pcId !== sender._peerConnectionId) {
|
|
379
|
+
throw new Error('Sender does not belong to this peer connection');
|
|
380
|
+
}
|
|
381
|
+
if (this.connectionState === 'closed') {
|
|
382
|
+
throw new Error('Peer Connection is closed');
|
|
383
|
+
}
|
|
384
|
+
const existingSender = this.getSenders().find(s => s === sender);
|
|
385
|
+
if (!existingSender) {
|
|
386
|
+
throw new Error('Sender does not exist');
|
|
387
|
+
}
|
|
388
|
+
if (existingSender.track === null) {
|
|
389
|
+
return;
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
// Blocking!
|
|
393
|
+
WebRTCModule.peerConnectionRemoveTrack(this._pcId, sender.id);
|
|
394
|
+
existingSender._track = null;
|
|
395
|
+
const [existingTransceiver] = this.getTransceivers().filter(t => t.sender.id === existingSender.id);
|
|
396
|
+
existingTransceiver._direction = existingTransceiver.direction === 'sendrecv' ? 'recvonly' : 'inactive';
|
|
397
|
+
}
|
|
398
|
+
async getStats(selector) {
|
|
399
|
+
log.debug(`${this._pcId} getStats`);
|
|
400
|
+
if (!selector) {
|
|
401
|
+
const data = await WebRTCModule.peerConnectionGetStats(this._pcId);
|
|
402
|
+
|
|
403
|
+
/**
|
|
404
|
+
* On both Android and iOS it is faster to construct a single
|
|
405
|
+
* JSON string representing the Map of StatsReports and have it
|
|
406
|
+
* pass through the React Native bridge rather than the Map of
|
|
407
|
+
* StatsReports. While the implementations do try to be faster in
|
|
408
|
+
* general, the stress is on being faster to pass through the React
|
|
409
|
+
* Native bridge which is a bottleneck that tends to be visible in
|
|
410
|
+
* the UI when there is congestion involving UI-related passing.
|
|
411
|
+
*/
|
|
412
|
+
return new Map(JSON.parse(data));
|
|
413
|
+
} else {
|
|
414
|
+
const senders = this.getSenders().filter(s => s.track === selector);
|
|
415
|
+
const receivers = this.getReceivers().filter(r => r.track === selector);
|
|
416
|
+
const matches = senders.length + receivers.length;
|
|
417
|
+
if (matches === 0) {
|
|
418
|
+
throw new Error('Invalid selector: could not find matching sender / receiver');
|
|
419
|
+
} else if (matches > 1) {
|
|
420
|
+
throw new Error('Invalid selector: multiple matching senders / receivers');
|
|
421
|
+
} else {
|
|
422
|
+
const sr = senders[0] || receivers[0];
|
|
423
|
+
return sr.getStats();
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
getTransceivers() {
|
|
428
|
+
return this._transceivers.map(e => e.transceiver);
|
|
429
|
+
}
|
|
430
|
+
getSenders() {
|
|
431
|
+
return this._transceivers.filter(e => !e.transceiver.stopped).map(e => e.transceiver.sender);
|
|
432
|
+
}
|
|
433
|
+
getReceivers() {
|
|
434
|
+
return this._transceivers.filter(e => !e.transceiver.stopped).map(e => e.transceiver.receiver);
|
|
435
|
+
}
|
|
436
|
+
close() {
|
|
437
|
+
log.debug(`${this._pcId} close`);
|
|
438
|
+
if (this.connectionState === 'closed') {
|
|
439
|
+
return;
|
|
440
|
+
}
|
|
441
|
+
WebRTCModule.peerConnectionClose(this._pcId);
|
|
442
|
+
|
|
443
|
+
// Mark transceivers as stopped.
|
|
444
|
+
this._transceivers.forEach(_ref => {
|
|
445
|
+
let {
|
|
446
|
+
transceiver
|
|
447
|
+
} = _ref;
|
|
448
|
+
transceiver._setStopped();
|
|
449
|
+
});
|
|
450
|
+
}
|
|
451
|
+
restartIce() {
|
|
452
|
+
WebRTCModule.peerConnectionRestartIce(this._pcId);
|
|
453
|
+
}
|
|
454
|
+
_registerEvents() {
|
|
455
|
+
addListener(this, 'peerConnectionOnRenegotiationNeeded', ev => {
|
|
456
|
+
if (ev.pcId !== this._pcId) {
|
|
457
|
+
return;
|
|
458
|
+
}
|
|
459
|
+
this.dispatchEvent(new Event('negotiationneeded'));
|
|
460
|
+
});
|
|
461
|
+
addListener(this, 'peerConnectionIceConnectionChanged', ev => {
|
|
462
|
+
if (ev.pcId !== this._pcId) {
|
|
463
|
+
return;
|
|
464
|
+
}
|
|
465
|
+
this.iceConnectionState = ev.iceConnectionState;
|
|
466
|
+
this.dispatchEvent(new Event('iceconnectionstatechange'));
|
|
467
|
+
});
|
|
468
|
+
addListener(this, 'peerConnectionStateChanged', ev => {
|
|
469
|
+
if (ev.pcId !== this._pcId) {
|
|
470
|
+
return;
|
|
471
|
+
}
|
|
472
|
+
this.connectionState = ev.connectionState;
|
|
473
|
+
this.dispatchEvent(new Event('connectionstatechange'));
|
|
474
|
+
if (ev.connectionState === 'closed') {
|
|
475
|
+
// This PeerConnection is done, clean up.
|
|
476
|
+
removeListener(this);
|
|
477
|
+
WebRTCModule.peerConnectionDispose(this._pcId);
|
|
478
|
+
}
|
|
479
|
+
});
|
|
480
|
+
addListener(this, 'peerConnectionSignalingStateChanged', ev => {
|
|
481
|
+
if (ev.pcId !== this._pcId) {
|
|
482
|
+
return;
|
|
483
|
+
}
|
|
484
|
+
this.signalingState = ev.signalingState;
|
|
485
|
+
this.dispatchEvent(new Event('signalingstatechange'));
|
|
486
|
+
});
|
|
487
|
+
|
|
488
|
+
// Consider moving away from this event: https://github.com/WebKit/WebKit/pull/3953
|
|
489
|
+
addListener(this, 'peerConnectionOnTrack', ev => {
|
|
490
|
+
if (ev.pcId !== this._pcId) {
|
|
491
|
+
return;
|
|
492
|
+
}
|
|
493
|
+
log.debug(`${this._pcId} ontrack`);
|
|
494
|
+
|
|
495
|
+
// NOTE: We need to make sure the track event fires right before sRD completes,
|
|
496
|
+
// so we queue them up here and dispatch the events when sRD fires, but before completing it.
|
|
497
|
+
// In the future we should probably implement out own logic and drop this event altogether.
|
|
498
|
+
this._pendingTrackEvents.push(ev);
|
|
499
|
+
});
|
|
500
|
+
addListener(this, 'peerConnectionOnRemoveTrack', ev => {
|
|
501
|
+
if (ev.pcId !== this._pcId) {
|
|
502
|
+
return;
|
|
503
|
+
}
|
|
504
|
+
log.debug(`${this._pcId} onremovetrack ${ev.receiverId}`);
|
|
505
|
+
const receiver = this.getReceivers().find(r => r.id === ev.receiverId);
|
|
506
|
+
const track = receiver === null || receiver === void 0 ? void 0 : receiver.track;
|
|
507
|
+
if (receiver && track) {
|
|
508
|
+
// As per the spec:
|
|
509
|
+
// - Remove the track from any media streams that were previously passed to the `track` event.
|
|
510
|
+
// https://w3c.github.io/webrtc-pc/#dom-rtcpeerconnection-removetrack,
|
|
511
|
+
// - Mark the track as muted:
|
|
512
|
+
// https://w3c.github.io/webrtc-pc/#process-remote-track-removal
|
|
513
|
+
for (const stream of this._remoteStreams.values()) {
|
|
514
|
+
if (stream._tracks.includes(track)) {
|
|
515
|
+
const trackIdx = stream._tracks.indexOf(track);
|
|
516
|
+
log.debug(`${this._pcId} removetrack ${track.id}`);
|
|
517
|
+
stream._tracks.splice(trackIdx, 1);
|
|
518
|
+
stream.dispatchEvent(new MediaStreamTrackEvent('removetrack', {
|
|
519
|
+
track
|
|
520
|
+
}));
|
|
521
|
+
|
|
522
|
+
// Dispatch a mute event for the track.
|
|
523
|
+
track._setMutedInternal(true);
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
});
|
|
528
|
+
addListener(this, 'peerConnectionGotICECandidate', ev => {
|
|
529
|
+
if (ev.pcId !== this._pcId) {
|
|
530
|
+
return;
|
|
531
|
+
}
|
|
532
|
+
const sdpInfo = ev.sdp;
|
|
533
|
+
|
|
534
|
+
// Can happen when doing a rollback.
|
|
535
|
+
if (sdpInfo.type && sdpInfo.sdp) {
|
|
536
|
+
this.localDescription = new RTCSessionDescription(sdpInfo);
|
|
537
|
+
} else {
|
|
538
|
+
this.localDescription = null;
|
|
539
|
+
}
|
|
540
|
+
const candidate = new RTCIceCandidate(ev.candidate);
|
|
541
|
+
this.dispatchEvent(new RTCIceCandidateEvent('icecandidate', {
|
|
542
|
+
candidate
|
|
543
|
+
}));
|
|
544
|
+
});
|
|
545
|
+
addListener(this, 'peerConnectionIceGatheringChanged', ev => {
|
|
546
|
+
if (ev.pcId !== this._pcId) {
|
|
547
|
+
return;
|
|
548
|
+
}
|
|
549
|
+
this.iceGatheringState = ev.iceGatheringState;
|
|
550
|
+
if (this.iceGatheringState === 'complete') {
|
|
551
|
+
const sdpInfo = ev.sdp;
|
|
552
|
+
|
|
553
|
+
// Can happen when doing a rollback.
|
|
554
|
+
if (sdpInfo.type && sdpInfo.sdp) {
|
|
555
|
+
this.localDescription = new RTCSessionDescription(sdpInfo);
|
|
556
|
+
} else {
|
|
557
|
+
this.localDescription = null;
|
|
558
|
+
}
|
|
559
|
+
this.dispatchEvent(new RTCIceCandidateEvent('icecandidate', {
|
|
560
|
+
candidate: null
|
|
561
|
+
}));
|
|
562
|
+
}
|
|
563
|
+
this.dispatchEvent(new Event('icegatheringstatechange'));
|
|
564
|
+
});
|
|
565
|
+
addListener(this, 'peerConnectionDidOpenDataChannel', ev => {
|
|
566
|
+
if (ev.pcId !== this._pcId) {
|
|
567
|
+
return;
|
|
568
|
+
}
|
|
569
|
+
const channel = new RTCDataChannel(ev.dataChannel);
|
|
570
|
+
this.dispatchEvent(new RTCDataChannelEvent('datachannel', {
|
|
571
|
+
channel
|
|
572
|
+
}));
|
|
573
|
+
|
|
574
|
+
// Send 'open' event. Native doesn't update the state since it's already
|
|
575
|
+
// set at this point.
|
|
576
|
+
channel.dispatchEvent(new RTCDataChannelEvent('open', {
|
|
577
|
+
channel
|
|
578
|
+
}));
|
|
579
|
+
});
|
|
580
|
+
addListener(this, 'mediaStreamTrackMuteChanged', ev => {
|
|
581
|
+
if (ev.pcId !== this._pcId) {
|
|
582
|
+
return;
|
|
583
|
+
}
|
|
584
|
+
const [track] = this.getReceivers().map(r => r.track).filter(t => (t === null || t === void 0 ? void 0 : t.id) === ev.trackId);
|
|
585
|
+
if (track) {
|
|
586
|
+
track._setMutedInternal(ev.muted);
|
|
587
|
+
}
|
|
588
|
+
});
|
|
589
|
+
}
|
|
590
|
+
|
|
591
|
+
/**
|
|
592
|
+
* Creates a new RTCDataChannel object with the given label. The
|
|
593
|
+
* RTCDataChannelInit dictionary can be used to configure properties of the
|
|
594
|
+
* underlying channel such as data reliability.
|
|
595
|
+
*
|
|
596
|
+
* @param {string} label - the value with which the label attribute of the new
|
|
597
|
+
* instance is to be initialized
|
|
598
|
+
* @param {RTCDataChannelInit} dataChannelDict - an optional dictionary of
|
|
599
|
+
* values with which to initialize corresponding attributes of the new
|
|
600
|
+
* instance such as id
|
|
601
|
+
*/
|
|
602
|
+
createDataChannel(label, dataChannelDict) {
|
|
603
|
+
if (arguments.length === 0) {
|
|
604
|
+
throw new TypeError('1 argument required, but 0 present');
|
|
605
|
+
}
|
|
606
|
+
if (dataChannelDict && 'id' in dataChannelDict) {
|
|
607
|
+
const id = dataChannelDict.id;
|
|
608
|
+
if (typeof id !== 'number') {
|
|
609
|
+
throw new TypeError('DataChannel id must be a number: ' + id);
|
|
610
|
+
}
|
|
611
|
+
}
|
|
612
|
+
const channelInfo = WebRTCModule.createDataChannel(this._pcId, String(label), dataChannelDict);
|
|
613
|
+
if (channelInfo === null) {
|
|
614
|
+
throw new TypeError('Failed to create new DataChannel');
|
|
615
|
+
}
|
|
616
|
+
return new RTCDataChannel(channelInfo);
|
|
617
|
+
}
|
|
618
|
+
|
|
619
|
+
/**
|
|
620
|
+
* Check whether a media stream track exists already in a sender.
|
|
621
|
+
* See https://w3c.github.io/webrtc-pc/#dom-rtcpeerconnection-addtrack for more information
|
|
622
|
+
*/
|
|
623
|
+
_trackExists(track) {
|
|
624
|
+
const [sender] = this.getSenders().filter(sender => {
|
|
625
|
+
var _sender$track;
|
|
626
|
+
return ((_sender$track = sender.track) === null || _sender$track === void 0 ? void 0 : _sender$track.id) === track.id;
|
|
627
|
+
});
|
|
628
|
+
return sender ? true : false;
|
|
629
|
+
}
|
|
630
|
+
|
|
631
|
+
/**
|
|
632
|
+
* Updates transceivers after offer/answer updates if necessary.
|
|
633
|
+
*/
|
|
634
|
+
_updateTransceivers(transceiverUpdates) {
|
|
635
|
+
let removeStopped = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
636
|
+
for (const update of transceiverUpdates) {
|
|
637
|
+
const [transceiver] = this.getTransceivers().filter(t => t.sender.id === update.transceiverId);
|
|
638
|
+
if (!transceiver) {
|
|
639
|
+
continue;
|
|
640
|
+
}
|
|
641
|
+
if (update.currentDirection) {
|
|
642
|
+
transceiver._currentDirection = update.currentDirection;
|
|
643
|
+
}
|
|
644
|
+
transceiver._mid = update.mid;
|
|
645
|
+
transceiver._stopped = Boolean(update.isStopped);
|
|
646
|
+
transceiver._sender._rtpParameters = new RTCRtpSendParameters(update.senderRtpParameters);
|
|
647
|
+
transceiver._receiver._rtpParameters = new RTCRtpReceiveParameters(update.receiverRtpParameters);
|
|
648
|
+
}
|
|
649
|
+
if (removeStopped) {
|
|
650
|
+
const stopped = this.getTransceivers().filter(t => t.stopped);
|
|
651
|
+
const newTransceivers = this._transceivers.filter(t => !stopped.includes(t.transceiver));
|
|
652
|
+
this._transceivers = newTransceivers;
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
|
|
656
|
+
/**
|
|
657
|
+
* Inserts transceiver into the transceiver array in the order they are created (timestamp).
|
|
658
|
+
* @param order an index that refers to when it it was created relatively.
|
|
659
|
+
* @param transceiver the transceiver object to be inserted.
|
|
660
|
+
*/
|
|
661
|
+
_insertTransceiverSorted(order, transceiver) {
|
|
662
|
+
this._transceivers.push({
|
|
663
|
+
order,
|
|
664
|
+
transceiver
|
|
665
|
+
});
|
|
666
|
+
this._transceivers.sort((a, b) => a.order - b.order);
|
|
667
|
+
}
|
|
668
|
+
}
|
|
669
|
+
|
|
670
|
+
/**
|
|
671
|
+
* Define the `onxxx` event handlers.
|
|
672
|
+
*/
|
|
673
|
+
const proto = RTCPeerConnection.prototype;
|
|
674
|
+
defineEventAttribute(proto, 'connectionstatechange');
|
|
675
|
+
defineEventAttribute(proto, 'icecandidate');
|
|
676
|
+
defineEventAttribute(proto, 'icecandidateerror');
|
|
677
|
+
defineEventAttribute(proto, 'iceconnectionstatechange');
|
|
678
|
+
defineEventAttribute(proto, 'icegatheringstatechange');
|
|
679
|
+
defineEventAttribute(proto, 'negotiationneeded');
|
|
680
|
+
defineEventAttribute(proto, 'signalingstatechange');
|
|
681
|
+
defineEventAttribute(proto, 'datachannel');
|
|
682
|
+
defineEventAttribute(proto, 'track');
|
|
683
|
+
defineEventAttribute(proto, 'error');
|
|
684
|
+
//# sourceMappingURL=RTCPeerConnection.js.map
|