diff --git a/examples/app.css b/examples/app.css index 056dc4e..4b38773 100644 --- a/examples/app.css +++ b/examples/app.css @@ -26,7 +26,7 @@ pre .warn { color: goldenrod; } -#debug pre { +#logs { height: 500px; overflow: auto; -} \ No newline at end of file +} diff --git a/examples/app.js b/examples/app.js index 0fc9f4b..62a11df 100644 --- a/examples/app.js +++ b/examples/app.js @@ -76,6 +76,7 @@ function getFormValues() { sendAudio: $('#sendAudio').is(':checked'), streamName: $('#streamName').val(), ingestMedia: $('#ingest-media').is(':checked'), + showJSSButton: $('#show-join-storage-session-button').is(':checked'), openDataChannel: $('#openDataChannel').is(':checked'), widescreen: $('#widescreen').is(':checked'), fullscreen: $('#fullscreen').is(':checked'), @@ -88,6 +89,18 @@ function getFormValues() { secretAccessKey: $('#secretAccessKey').val(), sessionToken: $('#sessionToken').val() || null, enableDQPmetrics: $('#enableDQPmetrics').is(':checked'), + sendHostCandidates: $('#send-host').is(':checked'), + acceptHostCandidates: $('#accept-host').is(':checked'), + sendRelayCandidates: $('#send-relay').is(':checked'), + acceptRelayCandidates: $('#accept-relay').is(':checked'), + sendSrflxCandidates: $('#send-srflx').is(':checked'), + acceptSrflxCandidates: $('#accept-srflx').is(':checked'), + sendPrflxCandidates: $('#send-prflx').is(':checked'), + acceptPrflxCandidates: $('#accept-prflx').is(':checked'), + sendTcpCandidates: $('#send-tcp').is(':checked'), + acceptTcpCandidates: $('#accept-tcp').is(':checked'), + sendUdpCandidates: $('#send-udp').is(':checked'), + acceptUdpCandidates: $('#accept-udp').is(':checked'), }; } @@ -112,6 +125,8 @@ function onStop() { if (ROLE === 'master') { stopMaster(); $('#master').addClass('d-none'); + $('#master .remote-view').removeClass('d-none'); + $('#master .remote').removeClass('d-none'); } else { stopViewer(); $('#viewer').addClass('d-none'); @@ -123,6 +138,7 @@ function onStop() { } $('#form').removeClass('d-none'); + $('#join-storage-session-button').addClass('d-none'); ROLE = null; } @@ -402,6 +418,7 @@ const fields = [ { field: 'sendAudio', type: 'checkbox' }, { field: 'streamName', type: 'text' }, { field: 'ingest-media', type: 'checkbox' }, + { field: 'show-join-storage-session-button', type: 'checkbox' }, { field: 'widescreen', type: 'radio', name: 'resolution' }, { field: 'fullscreen', type: 'radio', name: 'resolution' }, { field: 'openDataChannel', type: 'checkbox' }, @@ -410,7 +427,21 @@ const fields = [ { field: 'forceSTUN', type: 'radio', name: 'natTraversal' }, { field: 'forceTURN', type: 'radio', name: 'natTraversal' }, { field: 'natTraversalDisabled', type: 'radio', name: 'natTraversal' }, + { field: 'enableDQPmetrics', type: 'checkbox' }, + { field: 'send-host', type: 'checkbox' }, + { field: 'accept-host', type: 'checkbox' }, + { field: 'send-relay', type: 'checkbox' }, + { field: 'accept-relay', type: 'checkbox' }, + { field: 'send-srflx', type: 'checkbox' }, + { field: 'accept-srflx', type: 'checkbox' }, + { field: 'send-prflx', type: 'checkbox' }, + { field: 'accept-prflx', type: 'checkbox' }, + { field: 'send-tcp', type: 'checkbox' }, + { field: 'accept-tcp', type: 'checkbox' }, + { field: 'send-udp', type: 'checkbox' }, + { field: 'accept-udp', type: 'checkbox' }, ]; + fields.forEach(({ field, type, name }) => { const id = '#' + field; @@ -459,6 +490,149 @@ fields.forEach(({ field, type, name }) => { }); }); +/** + * Determines whether the ICE Candidate should be added. + * @param formValues Settings used. + * @param candidate {RTCIceCandidate} iceCandidate to check + * @returns true if the candidate should be added to the peerConnection. + */ +function shouldAcceptCandidate(formValues, candidate) { + const { transport, type } = extractTransportAndType(candidate); + + if (!formValues.acceptUdpCandidates && transport === 'udp') { + return false; + } + + if (!formValues.acceptTcpCandidates && transport === 'tcp') { + return false; + } + + switch (type) { + case 'host': + return formValues.acceptHostCandidates; + case 'srflx': + return formValues.acceptSrflxCandidates; + case 'relay': + return formValues.acceptRelayCandidates; + case 'prflx': + return formValues.acceptPrflxCandidates; + default: + console.warn('ShouldAcceptICECandidate: Unknown candidate type:', candidate.type); + return false; + } +} + +$('#natTraversalEnabled').on('click', () => { + $('#accept-host').prop('checked', true); + $('#send-host').prop('checked', true); + $('#accept-relay').prop('checked', true); + $('#send-relay').prop('checked', true); + $('#accept-srflx').prop('checked', true); + $('#send-srflx').prop('checked', true); + $('#accept-prflx').prop('checked', true); + $('#send-prflx').prop('checked', true); + + saveAdvanced(); +}); + +$('#forceSTUN').on('click', () => { + $('#accept-host').prop('checked', false); + $('#send-host').prop('checked', false); + $('#accept-relay').prop('checked', false); + $('#send-relay').prop('checked', false); + $('#accept-srflx').prop('checked', true); + $('#send-srflx').prop('checked', true); + $('#accept-prflx').prop('checked', false); + $('#send-prflx').prop('checked', false); + + saveAdvanced(); +}); + +$('#forceTURN').on('click', () => { + $('#accept-host').prop('checked', false); + $('#send-host').prop('checked', false); + $('#accept-relay').prop('checked', true); + $('#send-relay').prop('checked', true); + $('#accept-srflx').prop('checked', false); + $('#send-srflx').prop('checked', false); + $('#accept-prflx').prop('checked', false); + $('#send-prflx').prop('checked', false); + + saveAdvanced(); +}); + +$('#natTraversalDisabled').on('click', () => { + $('#accept-host').prop('checked', true); + $('#send-host').prop('checked', true); + $('#accept-relay').prop('checked', true); + $('#send-relay').prop('checked', true); + $('#accept-srflx').prop('checked', true); + $('#send-srflx').prop('checked', true); + $('#accept-prflx').prop('checked', true); + $('#send-prflx').prop('checked', true); + + saveAdvanced(); +}); + +function saveAdvanced() { + $('#accept-host').trigger('change'); + $('#send-host').trigger('change'); + $('#accept-relay').trigger('change'); + $('#send-relay').trigger('change'); + $('#accept-srflx').trigger('change'); + $('#send-srflx').trigger('change'); + $('#accept-prflx').trigger('change'); + $('#send-prflx').trigger('change'); +} + +/** + * Determines whether the ICE Candidate should be sent to the peer. + * @param formValues Settings used. + * @param candidate {RTCIceCandidate} iceCandidate to check + * @returns true if the candidate should be sent to the peer. + */ +function shouldSendIceCandidate(formValues, candidate) { + const { transport, type } = extractTransportAndType(candidate); + + if (!formValues.sendUdpCandidates && transport === 'udp') { + return false; + } + + if (!formValues.sendTcpCandidates && transport === 'tcp') { + return false; + } + + switch (type) { + case 'host': + return formValues.sendHostCandidates; + case 'srflx': + return formValues.sendSrflxCandidates; + case 'relay': + return formValues.sendRelayCandidates; + case 'prflx': + return formValues.sendPrflxCandidates; + default: + console.warn('ShouldSendICECandidate: Unknown candidate type:', candidate.type); + return false; + } +} + +function randomString() { + return Date.now().toString(); +} + +function extractTransportAndType(candidate) { + const words = candidate.candidate.split(' '); + + if (words.length < 7) { + console.error('Invalid ice candidate!', candidate); + return false; + } + + // https://datatracker.ietf.org/doc/html/rfc5245#section-15.1 + return { transport: words[2], type: words[7] }; +} + $('#copy-logs').on('click', async function() { const logsResult = []; $('#logs') @@ -506,6 +680,11 @@ $('#create-stream-modal-create-stream-button').on('click', async function() { }); }); +$('#join-storage-session-button').on('click', async function() { + const formValues = getFormValues(); + joinStorageSessionManually(formValues); +}); + // Enable tooltips $(document).ready(function() { $('[data-toggle="tooltip"]').tooltip(); diff --git a/examples/index.html b/examples/index.html index d12c8a7..9beceb1 100644 --- a/examples/index.html +++ b/examples/index.html @@ -106,13 +106,17 @@

Tracks

List storage channels outputs the ARNs of all signaling channels configured for storage and their associated stream's ARN.

- +
+
+ + +

Video Resolution

@@ -172,6 +176,67 @@

Amazon KVS WebRTC DQP

"> + +
Advanced +

Filter settings for which ICE candidates and sent to and received from the peer.

+
+
+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+
+
+
+
@@ -215,7 +280,7 @@

Master

Master Section
-
+
Viewer Return Channel
@@ -226,7 +291,7 @@
Viewer Return Channel
-
+

                     
@@ -236,7 +301,8 @@
Viewer Return Channel
- + +
@@ -268,7 +334,7 @@
From Master
- + @@ -327,6 +393,7 @@

Logs

+ diff --git a/examples/joinStorageSession.js b/examples/joinStorageSession.js new file mode 100644 index 0000000..260aeb9 --- /dev/null +++ b/examples/joinStorageSession.js @@ -0,0 +1,64 @@ +/** + * This function calls joinStorageSession. + */ +async function joinStorageSessionManually(formValues) { + $('#logs-header')[0].scrollIntoView({ + block: 'start', + }); + + try { + console.log('[JOIN_STORAGE_SESSION] Calling JoinStorageSession for channel', formValues.channelName); + + // Create KVS client + const kinesisVideoClient = new AWS.KinesisVideo({ + region: formValues.region, + accessKeyId: formValues.accessKeyId, + secretAccessKey: formValues.secretAccessKey, + sessionToken: formValues.sessionToken, + endpoint: formValues.endpoint, + }); + + // Step 1: Obtain the ARN of the Signaling Channel + const describeSignalingChannelResponse = await kinesisVideoClient + .describeSignalingChannel({ + ChannelName: formValues.channelName, + }) + .promise(); + const channelARN = describeSignalingChannelResponse.ChannelInfo.ChannelARN; + + // Step 2: Obtain the WEBRTC endpoint + const getSignalingChannelEndpointResponse = await kinesisVideoClient + .getSignalingChannelEndpoint({ + ChannelARN: channelARN, + SingleMasterChannelEndpointConfiguration: { + Protocols: ['WEBRTC'], + Role: KVSWebRTC.Role.MASTER, + }, + }) + .promise(); + const webrtcEndpoint = getSignalingChannelEndpointResponse.ResourceEndpointList[0].ResourceEndpoint; + + const kinesisVideoClientWebRTCStorageClient = new AWS.KinesisVideoWebRTCStorage({ + region: formValues.region, + accessKeyId: formValues.accessKeyId, + secretAccessKey: formValues.secretAccessKey, + sessionToken: formValues.sessionToken, + endpoint: webrtcEndpoint, + maxRetries: 0, + httpOptions: { + timeout: retryIntervalForJoinStorageSession, + }, + }); + + // Step 3. Call JoinStorageSession + await kinesisVideoClientWebRTCStorageClient + .joinStorageSession({ + channelArn: channelARN, + }) + .promise(); + + console.log('[JOIN_STORAGE_SESSION] Finished invoking JoinStorageSession for channel', formValues.channelName); + } catch (e) { + console.error('[JOIN_STORAGE_SESSION] Encountered error:', e); + } +} diff --git a/examples/master.js b/examples/master.js index a4fd1bc..3309db6 100644 --- a/examples/master.js +++ b/examples/master.js @@ -92,6 +92,13 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR protocols.push('WEBRTC'); master.streamARN = mediaStorageConfiguration.StreamARN; console.log(`[MASTER] Using media ingestion feature. Stream ARN: ${master.streamARN}`); + + $('#master .remote').addClass('d-none'); + if (formValues.openDataChannel) { + console.warn('[MASTER] DataChannel is not enabled for WebRTC ingestion. Overriding value to false.'); + formValues.openDataChannel = false; + $('.datachannel').addClass('d-none'); + } } else { console.log('[MASTER] Not using media ingestion feature.'); master.streamARN = null; @@ -143,6 +150,8 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR timeout: retryIntervalForJoinStorageSession, }, }); + } else { + master.storageClient = null; } // Get ICE server configuration @@ -210,6 +219,9 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR const masterRunId = ++master.runId; master.websocketOpened = true; console.log('[MASTER] Connected to signaling service'); + if (formValues.showJSSButton) { + $('#join-storage-session-button').removeClass('d-none'); + } if (master.streamARN) { if (formValues.ingestMedia) { await connectToMediaServer(masterRunId); @@ -262,8 +274,12 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR // When trickle ICE is enabled, send the ICE candidates as they are generated. if (formValues.useTrickleICE) { - printSignalingLog('[MASTER] Sending ICE candidate to client', remoteClientId); - master.signalingClient.sendIceCandidate(candidate, remoteClientId); + if (shouldSendIceCandidate(formValues, candidate)) { + printSignalingLog('[MASTER] Sending ICE candidate to client', remoteClientId); + master.signalingClient.sendIceCandidate(candidate, remoteClientId); + } else { + console.log('[MASTER] Not sending ICE candidate to client', remoteClientId); + } } } else { printSignalingLog('[MASTER] All ICE candidates have been generated for client', remoteClientId); @@ -271,8 +287,9 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR // When trickle ICE is disabled, send the answer now that all the ICE candidates have ben generated. if (!formValues.useTrickleICE) { printSignalingLog('[MASTER] Sending SDP answer to client', remoteClientId); - console.debug('SDP answer:', peerConnection.localDescription); - master.signalingClient.sendSdpAnswer(peerConnection.localDescription, remoteClientId); + const correlationId = randomString(); + console.debug('SDP answer:', peerConnection.localDescription, 'correlationId:', correlationId); + master.signalingClient.sendSdpAnswer(peerConnection.localDescription, remoteClientId, correlationId); } } }); @@ -301,19 +318,52 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR // When trickle ICE is enabled, send the answer now and then send ICE candidates as they are generated. Otherwise wait on the ICE candidates. if (formValues.useTrickleICE) { printSignalingLog('[MASTER] Sending SDP answer to client', remoteClientId); - console.debug('SDP answer:', peerConnection.localDescription); - master.signalingClient.sendSdpAnswer(peerConnection.localDescription, remoteClientId); + const correlationId = randomString(); + console.debug('SDP answer:', peerConnection.localDescription, 'correlationId:', correlationId); + master.signalingClient.sendSdpAnswer(peerConnection.localDescription, remoteClientId, correlationId); } printSignalingLog('[MASTER] Generating ICE candidates for client', remoteClientId); + + // If in WebRTC ingestion mode, retry if no connection was established within 5 seconds. + if (master.streamARN) { + setTimeout(function() { + // We check that it's not failed because if the state transitioned to failed, + // the state change callback would handle this already + if ( + peerConnection.connectionState !== 'connected' && + peerConnection.connectionState !== 'failed' && + peerConnection.connectionState !== 'closed' + ) { + console.error('[MASTER] Connection failed to establish within 5 seconds. Retrying...'); + onPeerConnectionFailed(false); + } + }, 5000); + } }); master.signalingClient.on('iceCandidate', async (candidate, remoteClientId) => { printSignalingLog('[MASTER] Received ICE candidate from client', remoteClientId); console.debug('[MASTER] ICE candidate:', candidate); - // Add the ICE candidate received from the client to the peer connection - const peerConnection = master.peerConnectionByClientId[remoteClientId]; - peerConnection.addIceCandidate(candidate); + if (shouldAcceptCandidate(formValues, candidate)) { + // Add the ICE candidate received from the client to the peer connection + const peerConnection = master.peerConnectionByClientId[remoteClientId]; + peerConnection.addIceCandidate(candidate); + } else { + console.log('[MASTER] Not adding candidate from peer.'); + } + }); + + master.signalingClient.on('statusResponse', statusResponse => { + if (statusResponse.success) { + return; + } + console.error('[MASTER] Received response from Signaling:', statusResponse); + + if (master.streamARN) { + console.error('[MASTER] Encountered a fatal error. Stopping the application.'); + onStop(); + } }); master.signalingClient.on('close', () => { @@ -330,12 +380,15 @@ async function startMaster(localView, remoteView, formValues, onStatsReport, onR master.signalingClient.open(); } catch (e) { console.error('[MASTER] Encountered error starting:', e); + onStop(); } } -function onPeerConnectionFailed() { +function onPeerConnectionFailed(printLostConnectionLog = true) { if (master.streamARN) { - console.warn('[MASTER] Lost connection to the storage session.'); + if (printLostConnectionLog) { + console.warn('[MASTER] Lost connection to the storage session.'); + } master.connectionFailures.push(new Date().getTime()); if (shouldStopRetryingJoinStorageSession()) { console.error( diff --git a/examples/viewer.js b/examples/viewer.js index f4c90f5..4c05039 100644 --- a/examples/viewer.js +++ b/examples/viewer.js @@ -290,7 +290,11 @@ async function startViewer(localView, remoteView, formValues, onStatsReport, onR // Add the ICE candidate received from the MASTER to the peer connection console.log('[VIEWER] Received ICE candidate'); console.debug('ICE candidate', candidate); - viewer.peerConnection.addIceCandidate(candidate); + if (shouldAcceptCandidate(formValues, candidate)) { + viewer.peerConnection.addIceCandidate(candidate); + } else { + console.log('[VIEWER] Not adding candidate from peer.'); + } }); viewer.signalingClient.on('close', () => { @@ -309,8 +313,12 @@ async function startViewer(localView, remoteView, formValues, onStatsReport, onR // When trickle ICE is enabled, send the ICE candidates as they are generated. if (formValues.useTrickleICE) { - console.log('[VIEWER] Sending ICE candidate'); - viewer.signalingClient.sendIceCandidate(candidate); + if (shouldSendIceCandidate(formValues, candidate)) { + console.log('[VIEWER] Sending ICE candidate'); + viewer.signalingClient.sendIceCandidate(candidate); + } else { + console.log('[VIEWER] Not sending ICE candidate'); + } } } else { console.log('[VIEWER] All ICE candidates have been generated'); diff --git a/kvs-webrtc.LICENSE b/kvs-webrtc.LICENSE index e60fe7c..13b85b3 100644 --- a/kvs-webrtc.LICENSE +++ b/kvs-webrtc.LICENSE @@ -54,3 +54,27 @@ This product bundles events, which is available under the MIT license: OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +This product bundles ws, which is available under the MIT license: + + Copyright (c) 2011 Einar Otto Stangvik + Copyright (c) 2013 Arnout Kazemier and contributors + Copyright (c) 2016 Luigi Pinca and contributors + + Permission is hereby granted, free of charge, to any person obtaining a copy of + this software and associated documentation files (the "Software"), to deal in + the Software without restriction, including without limitation the rights to + use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of + the Software, and to permit persons to whom the Software is furnished to do so, + subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS + FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR + COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER + IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/kvs-webrtc.js b/kvs-webrtc.js index b5f2c3e..88805b1 100644 --- a/kvs-webrtc.js +++ b/kvs-webrtc.js @@ -1,4 +1,4 @@ -/* Amazon Kinesis Video Streams WebRTC SDK for JavaScript v2.1.0 +/* Amazon Kinesis Video Streams WebRTC SDK for JavaScript v2.2.0 Copyright 2019-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. This product includes software developed at @@ -819,6 +819,7 @@ var MessageType; MessageType["SDP_ANSWER"] = "SDP_ANSWER"; MessageType["SDP_OFFER"] = "SDP_OFFER"; MessageType["ICE_CANDIDATE"] = "ICE_CANDIDATE"; + MessageType["STATUS_RESPONSE"] = "STATUS_RESPONSE"; })(MessageType || (MessageType = {})); var ReadyState; (function (ReadyState) { @@ -912,7 +913,8 @@ var SignalingClient = /** @class */ (function (_super) { if (this.readyState !== ReadyState.CONNECTING) { return [2 /*return*/]; } - this.websocket = new WebSocket(signedURL); + /* istanbul ignore next */ + this.websocket = new (__webpack_require__.g.WebSocket || __webpack_require__(/*! ws */ "./node_modules/ws/browser.js"))(signedURL); this.websocket.addEventListener('open', this.onOpen); this.websocket.addEventListener('message', this.onMessage); this.websocket.addEventListener('error', this.onError); @@ -941,9 +943,11 @@ var SignalingClient = /** @class */ (function (_super) { * Typically, only the 'VIEWER' role should send an SDP offer. * @param {RTCSessionDescription} sdpOffer - SDP offer to send. * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role. + * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error, + * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned. */ - SignalingClient.prototype.sendSdpOffer = function (sdpOffer, recipientClientId) { - this.sendMessage(MessageType.SDP_OFFER, sdpOffer.toJSON(), recipientClientId); + SignalingClient.prototype.sendSdpOffer = function (sdpOffer, recipientClientId, correlationId) { + this.sendMessage(MessageType.SDP_OFFER, sdpOffer, recipientClientId, correlationId); }; /** * Sends the given SDP answer to the signaling service. @@ -951,9 +955,11 @@ var SignalingClient = /** @class */ (function (_super) { * Typically, only the 'MASTER' role should send an SDP answer. * @param {RTCSessionDescription} sdpAnswer - SDP answer to send. * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role. + * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error, + * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned. */ - SignalingClient.prototype.sendSdpAnswer = function (sdpAnswer, recipientClientId) { - this.sendMessage(MessageType.SDP_ANSWER, sdpAnswer.toJSON(), recipientClientId); + SignalingClient.prototype.sendSdpAnswer = function (sdpAnswer, recipientClientId, correlationId) { + this.sendMessage(MessageType.SDP_ANSWER, sdpAnswer, recipientClientId, correlationId); }; /** * Sends the given ICE candidate to the signaling service. @@ -961,23 +967,27 @@ var SignalingClient = /** @class */ (function (_super) { * Typically, both the 'VIEWER' role and 'MASTER' role should send ICE candidates. * @param {RTCIceCandidate} iceCandidate - ICE candidate to send. * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role. + * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error, + * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned. */ - SignalingClient.prototype.sendIceCandidate = function (iceCandidate, recipientClientId) { - this.sendMessage(MessageType.ICE_CANDIDATE, iceCandidate.toJSON(), recipientClientId); + SignalingClient.prototype.sendIceCandidate = function (iceCandidate, recipientClientId, correlationId) { + this.sendMessage(MessageType.ICE_CANDIDATE, iceCandidate, recipientClientId, correlationId); }; /** * Validates the WebSocket connection is open and that the recipient client id is present if sending as the 'MASTER'. Encodes the given message payload * and sends the message to the signaling service. */ - SignalingClient.prototype.sendMessage = function (action, messagePayload, recipientClientId) { + SignalingClient.prototype.sendMessage = function (action, messagePayload, recipientClientId, correlationId) { if (this.readyState !== ReadyState.OPEN) { throw new Error('Could not send message because the connection to the signaling service is not open.'); } this.validateRecipientClientId(recipientClientId); + this.validateCorrelationId(correlationId); this.websocket.send(JSON.stringify({ action: action, messagePayload: SignalingClient.serializeJSONObjectAsBase64String(messagePayload), recipientClientId: recipientClientId || undefined, + correlationId: correlationId || undefined, })); }; /** @@ -1008,14 +1018,23 @@ var SignalingClient = /** @class */ (function (_super) { var parsedMessagePayload; try { parsedEventData = JSON.parse(event.data); - parsedMessagePayload = SignalingClient.parseJSONObjectFromBase64String(parsedEventData.messagePayload); } catch (e) { // For forwards compatibility we ignore messages that are not able to be parsed. // TODO: Consider how to make it easier for users to be aware of dropped messages. return; } - var messageType = parsedEventData.messageType, senderClientId = parsedEventData.senderClientId; + try { + parsedMessagePayload = SignalingClient.parseJSONObjectFromBase64String(parsedEventData.messagePayload); + } + catch (e) { + // TODO: Consider how to make it easier for users to be aware of dropped messages. + } + var messageType = parsedEventData.messageType, senderClientId = parsedEventData.senderClientId, statusResponse = parsedEventData.statusResponse; + if (!parsedMessagePayload && !statusResponse) { + // TODO: Consider how to make it easier for users to be aware of dropped messages. + return; + } switch (messageType) { case MessageType.SDP_OFFER: this.emit('sdpOffer', parsedMessagePayload, senderClientId); @@ -1028,19 +1047,32 @@ var SignalingClient = /** @class */ (function (_super) { case MessageType.ICE_CANDIDATE: this.emitOrQueueIceCandidate(parsedMessagePayload, senderClientId); return; + case MessageType.STATUS_RESPONSE: + this.emit('statusResponse', statusResponse); + return; } }; /** * Takes the given base64 encoded string and decodes it into a JSON object. */ SignalingClient.parseJSONObjectFromBase64String = function (base64EncodedString) { - return JSON.parse(atob(base64EncodedString)); + try { + return JSON.parse(atob(base64EncodedString)); + } + catch (e) { + return JSON.parse(Buffer.from(base64EncodedString, 'base64').toString()); + } }; /** * Takes the given JSON object and encodes it into a base64 string. */ SignalingClient.serializeJSONObjectAsBase64String = function (object) { - return btoa(JSON.stringify(object)); + try { + return btoa(JSON.stringify(object)); + } + catch (e) { + return Buffer.from(JSON.stringify(object)).toString('base64'); + } }; /** * If an SDP offer or answer has already been received from the given client, then the given ICE candidate is emitted. Otherwise, it is queued up for when @@ -1082,6 +1114,14 @@ var SignalingClient = /** @class */ (function (_super) { throw new Error('Unexpected recipient client id. As the VIEWER, messages must not be sent with a recipient client id.'); } }; + /** + * Throws an error if the correlationId does not fit the constraints mentioned in {@link https://docs.aws.amazon.com/kinesisvideostreams-webrtc-dg/latest/devguide/kvswebrtc-websocket-apis4.html the documentation}. + */ + SignalingClient.prototype.validateCorrelationId = function (correlationId) { + if (correlationId && !/^[a-zA-Z0-9_.-]{1,256}$/.test(correlationId)) { + throw new Error('Correlation id does not fit the constraint!'); + } + }; /** * 'error' event handler. Forwards the error onto listeners. */ @@ -1428,6 +1468,24 @@ function __classPrivateFieldSet(receiver, privateMap, value) { } +/***/ }), + +/***/ "./node_modules/ws/browser.js": +/*!************************************!*\ + !*** ./node_modules/ws/browser.js ***! + \************************************/ +/***/ ((module) => { + + + +module.exports = function () { + throw new Error( + 'ws does not work in the browser. Browser clients must use the native ' + + 'WebSocket object' + ); +}; + + /***/ }), /***/ "isomorphic-webcrypto": @@ -1479,6 +1537,18 @@ module.exports = window["crypto"]; /******/ }; /******/ })(); /******/ +/******/ /* webpack/runtime/global */ +/******/ (() => { +/******/ __webpack_require__.g = (function() { +/******/ if (typeof globalThis === 'object') return globalThis; +/******/ try { +/******/ return this || new Function('return this')(); +/******/ } catch (e) { +/******/ if (typeof window === 'object') return window; +/******/ } +/******/ })(); +/******/ })(); +/******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) @@ -1523,11 +1593,11 @@ var QueryParams_1 = __webpack_require__(/*! ./QueryParams */ "./src/QueryParams. Object.defineProperty(exports, "QueryParams", ({ enumerable: true, get: function () { return QueryParams_1.QueryParams; } })); var RequestSigner_1 = __webpack_require__(/*! ./RequestSigner */ "./src/RequestSigner.ts"); Object.defineProperty(exports, "RequestSigner", ({ enumerable: true, get: function () { return RequestSigner_1.RequestSigner; } })); -exports.VERSION = "2.1.0"; +exports.VERSION = "2.2.0"; })(); window.KVSWebRTC = __webpack_exports__; /******/ })() ; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"kvs-webrtc.js","mappings":";;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEa;;AAEb;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,sBAAsB;AACxC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe;AACf;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA,oBAAoB,SAAS;AAC7B;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;AAEA,kCAAkC,QAAQ;AAC1C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,QAAQ;AACR;AACA,uCAAuC,QAAQ;AAC/C;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;;AAEA;AACA,SAAS,yBAAyB;AAClC;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,8DAA8D,YAAY;AAC1E;AACA,8DAA8D,YAAY;AAC1E;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,qCAAqC,YAA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;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,MAAM;AAC1B;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACO;AACP,6BAA6B,sBAAsB;AACnD;AACA;AACA;AACA;AACO;AACP,kDAAkD,QAAQ;AAC1D,yCAAyC,QAAQ;AACjD,yDAAyD,QAAQ;AACjE;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA,iBAAiB,uFAAuF,cAAc;AACtH,uBAAuB,gCAAgC,qCAAqC,2CAA2C;AACvI,4BAA4B,MAAM,iBAAiB,YAAY;AAC/D,uBAAuB;AACvB,8BAA8B;AAC9B,6BAA6B;AAC7B,4BAA4B;AAC5B;AACA;AACO;AACP;AACA,iBAAiB,6CAA6C,UAAU,sDAAsD,cAAc;AAC5I,0BAA0B,6BAA6B,oBAAoB,gDAAgD,kBAAkB;AAC7I;AACA;AACO;AACP;AACA;AACA,2GAA2G,uFAAuF,cAAc;AAChN,uBAAuB,8BAA8B,gDAAgD,wDAAwD;AAC7J,6CAA6C,sCAAsC,UAAU,mBAAmB,IAAI;AACpH;AACA;AACO;AACP,iCAAiC,uCAAuC,YAAY,KAAK,OAAO;AAChG;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,6CAA6C;AAC7C;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;ACzNA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;ACNA;;;;;;EAME;AACF,gEAA8B;AAArB,iGAAI;AACb,iGAAoD;AAA3C,kIAAe;AACxB,0GAA0D;AAAjD,2IAAkB;AAC3B,qFAA4C;AAAnC,sHAAW;AACpB,2FAAgD;AAAvC,4HAAa;AAET,eAAO,GAAG,OAA2B,CAAC","sources":["webpack://KVSWebRTC/./node_modules/events/events.js","webpack://KVSWebRTC/./src/QueryParams.ts","webpack://KVSWebRTC/./src/RequestSigner.ts","webpack://KVSWebRTC/./src/Role.ts","webpack://KVSWebRTC/./src/SigV4RequestSigner.ts","webpack://KVSWebRTC/./src/SignalingClient.ts","webpack://KVSWebRTC/./src/internal/DateProvider.ts","webpack://KVSWebRTC/./src/internal/utils.ts","webpack://KVSWebRTC/./node_modules/tslib/tslib.es6.js","webpack://KVSWebRTC/external window \"crypto\"","webpack://KVSWebRTC/webpack/bootstrap","webpack://KVSWebRTC/webpack/runtime/define property getters","webpack://KVSWebRTC/webpack/runtime/hasOwnProperty shorthand","webpack://KVSWebRTC/webpack/runtime/make namespace object","webpack://KVSWebRTC/./src/index.ts"],"sourcesContent":["// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n  ? R.apply\n  : function ReflectApply(target, receiver, args) {\n    return Function.prototype.apply.call(target, receiver, args);\n  }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n  ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target)\n      .concat(Object.getOwnPropertySymbols(target));\n  };\n} else {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target);\n  };\n}\n\nfunction ProcessEmitWarning(warning) {\n  if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n  return value !== value;\n}\n\nfunction EventEmitter() {\n  EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n  if (typeof listener !== 'function') {\n    throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n  }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n  enumerable: true,\n  get: function() {\n    return defaultMaxListeners;\n  },\n  set: function(arg) {\n    if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n      throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n    }\n    defaultMaxListeners = arg;\n  }\n});\n\nEventEmitter.init = function() {\n\n  if (this._events === undefined ||\n      this._events === Object.getPrototypeOf(this)._events) {\n    this._events = Object.create(null);\n    this._eventsCount = 0;\n  }\n\n  this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n  if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n    throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n  }\n  this._maxListeners = n;\n  return this;\n};\n\nfunction _getMaxListeners(that) {\n  if (that._maxListeners === undefined)\n    return EventEmitter.defaultMaxListeners;\n  return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n  return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n  var args = [];\n  for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n  var doError = (type === 'error');\n\n  var events = this._events;\n  if (events !== undefined)\n    doError = (doError && events.error === undefined);\n  else if (!doError)\n    return false;\n\n  // If there is no 'error' event listener then throw.\n  if (doError) {\n    var er;\n    if (args.length > 0)\n      er = args[0];\n    if (er instanceof Error) {\n      // Note: The comments on the `throw` lines are intentional, they show\n      // up in Node's output if this results in an unhandled exception.\n      throw er; // Unhandled 'error' event\n    }\n    // At least give some kind of context to the user\n    var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n    err.context = er;\n    throw err; // Unhandled 'error' event\n  }\n\n  var handler = events[type];\n\n  if (handler === undefined)\n    return false;\n\n  if (typeof handler === 'function') {\n    ReflectApply(handler, this, args);\n  } else {\n    var len = handler.length;\n    var listeners = arrayClone(handler, len);\n    for (var i = 0; i < len; ++i)\n      ReflectApply(listeners[i], this, args);\n  }\n\n  return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n  var m;\n  var events;\n  var existing;\n\n  checkListener(listener);\n\n  events = target._events;\n  if (events === undefined) {\n    events = target._events = Object.create(null);\n    target._eventsCount = 0;\n  } else {\n    // To avoid recursion in the case that type === \"newListener\"! Before\n    // adding it to the listeners, first emit \"newListener\".\n    if (events.newListener !== undefined) {\n      target.emit('newListener', type,\n                  listener.listener ? listener.listener : listener);\n\n      // Re-assign `events` because a newListener handler could have caused the\n      // this._events to be assigned to a new object\n      events = target._events;\n    }\n    existing = events[type];\n  }\n\n  if (existing === undefined) {\n    // Optimize the case of one listener. Don't need the extra array object.\n    existing = events[type] = listener;\n    ++target._eventsCount;\n  } else {\n    if (typeof existing === 'function') {\n      // Adding the second element, need to change to array.\n      existing = events[type] =\n        prepend ? [listener, existing] : [existing, listener];\n      // If we've already got an array, just append.\n    } else if (prepend) {\n      existing.unshift(listener);\n    } else {\n      existing.push(listener);\n    }\n\n    // Check for listener leak\n    m = _getMaxListeners(target);\n    if (m > 0 && existing.length > m && !existing.warned) {\n      existing.warned = true;\n      // No error code for this since it is a Warning\n      // eslint-disable-next-line no-restricted-syntax\n      var w = new Error('Possible EventEmitter memory leak detected. ' +\n                          existing.length + ' ' + String(type) + ' listeners ' +\n                          'added. Use emitter.setMaxListeners() to ' +\n                          'increase limit');\n      w.name = 'MaxListenersExceededWarning';\n      w.emitter = target;\n      w.type = type;\n      w.count = existing.length;\n      ProcessEmitWarning(w);\n    }\n  }\n\n  return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n  return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n    function prependListener(type, listener) {\n      return _addListener(this, type, listener, true);\n    };\n\nfunction onceWrapper() {\n  if (!this.fired) {\n    this.target.removeListener(this.type, this.wrapFn);\n    this.fired = true;\n    if (arguments.length === 0)\n      return this.listener.call(this.target);\n    return this.listener.apply(this.target, arguments);\n  }\n}\n\nfunction _onceWrap(target, type, listener) {\n  var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n  var wrapped = onceWrapper.bind(state);\n  wrapped.listener = listener;\n  state.wrapFn = wrapped;\n  return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n  checkListener(listener);\n  this.on(type, _onceWrap(this, type, listener));\n  return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n    function prependOnceListener(type, listener) {\n      checkListener(listener);\n      this.prependListener(type, _onceWrap(this, type, listener));\n      return this;\n    };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n    function removeListener(type, listener) {\n      var list, events, position, i, originalListener;\n\n      checkListener(listener);\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      list = events[type];\n      if (list === undefined)\n        return this;\n\n      if (list === listener || list.listener === listener) {\n        if (--this._eventsCount === 0)\n          this._events = Object.create(null);\n        else {\n          delete events[type];\n          if (events.removeListener)\n            this.emit('removeListener', type, list.listener || listener);\n        }\n      } else if (typeof list !== 'function') {\n        position = -1;\n\n        for (i = list.length - 1; i >= 0; i--) {\n          if (list[i] === listener || list[i].listener === listener) {\n            originalListener = list[i].listener;\n            position = i;\n            break;\n          }\n        }\n\n        if (position < 0)\n          return this;\n\n        if (position === 0)\n          list.shift();\n        else {\n          spliceOne(list, position);\n        }\n\n        if (list.length === 1)\n          events[type] = list[0];\n\n        if (events.removeListener !== undefined)\n          this.emit('removeListener', type, originalListener || listener);\n      }\n\n      return this;\n    };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n    function removeAllListeners(type) {\n      var listeners, events, i;\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      // not listening for removeListener, no need to emit\n      if (events.removeListener === undefined) {\n        if (arguments.length === 0) {\n          this._events = Object.create(null);\n          this._eventsCount = 0;\n        } else if (events[type] !== undefined) {\n          if (--this._eventsCount === 0)\n            this._events = Object.create(null);\n          else\n            delete events[type];\n        }\n        return this;\n      }\n\n      // emit removeListener for all listeners on all events\n      if (arguments.length === 0) {\n        var keys = Object.keys(events);\n        var key;\n        for (i = 0; i < keys.length; ++i) {\n          key = keys[i];\n          if (key === 'removeListener') continue;\n          this.removeAllListeners(key);\n        }\n        this.removeAllListeners('removeListener');\n        this._events = Object.create(null);\n        this._eventsCount = 0;\n        return this;\n      }\n\n      listeners = events[type];\n\n      if (typeof listeners === 'function') {\n        this.removeListener(type, listeners);\n      } else if (listeners !== undefined) {\n        // LIFO order\n        for (i = listeners.length - 1; i >= 0; i--) {\n          this.removeListener(type, listeners[i]);\n        }\n      }\n\n      return this;\n    };\n\nfunction _listeners(target, type, unwrap) {\n  var events = target._events;\n\n  if (events === undefined)\n    return [];\n\n  var evlistener = events[type];\n  if (evlistener === undefined)\n    return [];\n\n  if (typeof evlistener === 'function')\n    return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n  return unwrap ?\n    unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n  return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n  return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  if (typeof emitter.listenerCount === 'function') {\n    return emitter.listenerCount(type);\n  } else {\n    return listenerCount.call(emitter, type);\n  }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n  var events = this._events;\n\n  if (events !== undefined) {\n    var evlistener = events[type];\n\n    if (typeof evlistener === 'function') {\n      return 1;\n    } else if (evlistener !== undefined) {\n      return evlistener.length;\n    }\n  }\n\n  return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n  return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n  var copy = new Array(n);\n  for (var i = 0; i < n; ++i)\n    copy[i] = arr[i];\n  return copy;\n}\n\nfunction spliceOne(list, index) {\n  for (; index + 1 < list.length; index++)\n    list[index] = list[index + 1];\n  list.pop();\n}\n\nfunction unwrapListeners(arr) {\n  var ret = new Array(arr.length);\n  for (var i = 0; i < ret.length; ++i) {\n    ret[i] = arr[i].listener || arr[i];\n  }\n  return ret;\n}\n\nfunction once(emitter, name) {\n  return new Promise(function (resolve, reject) {\n    function errorListener(err) {\n      emitter.removeListener(name, resolver);\n      reject(err);\n    }\n\n    function resolver() {\n      if (typeof emitter.removeListener === 'function') {\n        emitter.removeListener('error', errorListener);\n      }\n      resolve([].slice.call(arguments));\n    };\n\n    eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n    if (name !== 'error') {\n      addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n    }\n  });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n  if (typeof emitter.on === 'function') {\n    eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n  }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n  if (typeof emitter.on === 'function') {\n    if (flags.once) {\n      emitter.once(name, listener);\n    } else {\n      emitter.on(name, listener);\n    }\n  } else if (typeof emitter.addEventListener === 'function') {\n    // EventTarget does not have `error` event semantics like Node\n    // EventEmitters, we do not listen for `error` events here.\n    emitter.addEventListener(name, function wrapListener(arg) {\n      // IE does not have builtin `{ once: true }` support so we\n      // have to do it manually.\n      if (flags.once) {\n        emitter.removeEventListener(name, wrapListener);\n      }\n      listener(arg);\n    });\n  } else {\n    throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n  }\n}\n","export type QueryParams = { [queryParam: string]: string };\n","import { QueryParams } from './QueryParams';\n\nexport interface RequestSigner {\n    getSignedURL: (signalingEndpoint: string, queryParams: QueryParams, date?: Date) => Promise<string>;\n}\n","/**\n * Signaling client role.\n */\nexport enum Role {\n    MASTER = 'MASTER',\n    VIEWER = 'VIEWER',\n}\n","import crypto from 'isomorphic-webcrypto';\n\nimport { QueryParams } from './QueryParams';\nimport { RequestSigner } from './RequestSigner';\nimport { Credentials } from './SignalingClient';\nimport { validateValueNonNil } from './internal/utils';\n\ntype Headers = { [header: string]: string };\n\n/**\n * Utility class for SigV4 signing requests. The AWS SDK cannot be used for this purpose because it does not have support for WebSocket endpoints.\n */\nexport class SigV4RequestSigner implements RequestSigner {\n    private static readonly DEFAULT_ALGORITHM = 'AWS4-HMAC-SHA256';\n    private static readonly DEFAULT_SERVICE = 'kinesisvideo';\n\n    private readonly region: string;\n    private readonly credentials: Credentials;\n    private readonly service: string;\n\n    public constructor(region: string, credentials: Credentials, service: string = SigV4RequestSigner.DEFAULT_SERVICE) {\n        this.region = region;\n        this.credentials = credentials;\n        this.service = service;\n    }\n\n    /**\n     * Creates a SigV4 signed WebSocket URL for the given host/endpoint with the given query params.\n     *\n     * @param endpoint The WebSocket service endpoint including protocol, hostname, and path (if applicable).\n     * @param queryParams Query parameters to include in the URL.\n     * @param date Date to use for request signing. Defaults to NOW.\n     *\n     * Implementation note: Query parameters should be in alphabetical order.\n     *\n     * Note from AWS docs: \"When you add the X-Amz-Security-Token parameter to the query string, some services require that you include this parameter in the\n     * canonical (signed) request. For other services, you add this parameter at the end, after you calculate the signature. For details, see the API reference\n     * documentation for that service.\" KVS Signaling Service requires that the session token is added to the canonical request.\n     *\n     * @see https://docs.aws.amazon.com/AmazonS3/latest/API/sigv4-query-string-auth.html\n     * @see https://gist.github.com/prestomation/24b959e51250a8723b9a5a4f70dcae08\n     */\n    public async getSignedURL(endpoint: string, queryParams: QueryParams, date: Date = new Date()): Promise<string> {\n        // Refresh credentials\n        if (typeof this.credentials.getPromise === 'function') {\n            await this.credentials.getPromise();\n        }\n        validateValueNonNil(this.credentials.accessKeyId, 'credentials.accessKeyId');\n        validateValueNonNil(this.credentials.secretAccessKey, 'credentials.secretAccessKey');\n\n        // Prepare date strings\n        const datetimeString = SigV4RequestSigner.getDateTimeString(date);\n        const dateString = SigV4RequestSigner.getDateString(date);\n\n        // Validate and parse endpoint\n        const protocol = 'wss';\n        const urlProtocol = `${protocol}://`;\n        if (!endpoint.startsWith(urlProtocol)) {\n            throw new Error(`Endpoint '${endpoint}' is not a secure WebSocket endpoint. It should start with '${urlProtocol}'.`);\n        }\n        if (endpoint.includes('?')) {\n            throw new Error(`Endpoint '${endpoint}' should not contain any query parameters.`);\n        }\n        const pathStartIndex = endpoint.indexOf('/', urlProtocol.length);\n        let host;\n        let path;\n        if (pathStartIndex < 0) {\n            host = endpoint.substring(urlProtocol.length);\n            path = '/';\n        } else {\n            host = endpoint.substring(urlProtocol.length, pathStartIndex);\n            path = endpoint.substring(pathStartIndex);\n        }\n\n        const signedHeaders = ['host'].join(';');\n\n        // Prepare method\n        const method = 'GET'; // Method is always GET for signed URLs\n\n        // Prepare canonical query string\n        const credentialScope = dateString + '/' + this.region + '/' + this.service + '/' + 'aws4_request';\n        const canonicalQueryParams = Object.assign({}, queryParams, {\n            'X-Amz-Algorithm': SigV4RequestSigner.DEFAULT_ALGORITHM,\n            'X-Amz-Credential': this.credentials.accessKeyId + '/' + credentialScope,\n            'X-Amz-Date': datetimeString,\n            'X-Amz-Expires': '299',\n            'X-Amz-SignedHeaders': signedHeaders,\n        });\n        if (this.credentials.sessionToken) {\n            Object.assign(canonicalQueryParams, {\n                'X-Amz-Security-Token': this.credentials.sessionToken,\n            });\n        }\n        const canonicalQueryString = SigV4RequestSigner.createQueryString(canonicalQueryParams);\n\n        // Prepare canonical headers\n        const canonicalHeaders = {\n            host,\n        };\n        const canonicalHeadersString = SigV4RequestSigner.createHeadersString(canonicalHeaders);\n\n        // Prepare payload hash\n        const payloadHash = await SigV4RequestSigner.sha256('');\n\n        // Combine canonical request parts into a canonical request string and hash\n        const canonicalRequest = [method, path, canonicalQueryString, canonicalHeadersString, signedHeaders, payloadHash].join('\\n');\n        const canonicalRequestHash = await SigV4RequestSigner.sha256(canonicalRequest);\n\n        // Create signature\n        const stringToSign = [SigV4RequestSigner.DEFAULT_ALGORITHM, datetimeString, credentialScope, canonicalRequestHash].join('\\n');\n        const signingKey = await this.getSignatureKey(dateString);\n        const signature = await SigV4RequestSigner.toHex(await SigV4RequestSigner.hmac(signingKey, stringToSign));\n\n        // Add signature to query params\n        const signedQueryParams = Object.assign({}, canonicalQueryParams, {\n            'X-Amz-Signature': signature,\n        });\n\n        // Create signed URL\n        return protocol + '://' + host + path + '?' + SigV4RequestSigner.createQueryString(signedQueryParams);\n    }\n\n    /**\n     * Utility method for generating the key to use for calculating the signature. This combines together the date string, region, service name, and secret\n     * access key.\n     *\n     * @see https://docs.aws.amazon.com/general/latest/gr/sigv4-calculate-signature.html\n     */\n    private async getSignatureKey(dateString: string): Promise<ArrayBuffer> {\n        const kDate = await SigV4RequestSigner.hmac('AWS4' + this.credentials.secretAccessKey, dateString);\n        const kRegion = await SigV4RequestSigner.hmac(kDate, this.region);\n        const kService = await SigV4RequestSigner.hmac(kRegion, this.service);\n        return await SigV4RequestSigner.hmac(kService, 'aws4_request');\n    }\n\n    /**\n     * Utility method for converting a map of headers to a string for signing.\n     */\n    private static createHeadersString(headers: Headers): string {\n        return Object.keys(headers)\n            .map(header => `${header}:${headers[header]}\\n`)\n            .join();\n    }\n\n    /**\n     * Utility method for converting a map of query parameters to a string with the parameter names sorted.\n     */\n    private static createQueryString(queryParams: QueryParams): string {\n        return Object.keys(queryParams)\n            .sort()\n            .map(key => `${key}=${encodeURIComponent(queryParams[key])}`)\n            .join('&');\n    }\n\n    /**\n     * Gets a datetime string for the given date to use for signing. For example: \"20190927T165210Z\"\n     * @param date\n     */\n    private static getDateTimeString(date: Date): string {\n        return date\n            .toISOString()\n            .replace(/\\.\\d{3}Z$/, 'Z')\n            .replace(/[:\\-]/g, '');\n    }\n\n    /**\n     * Gets a date string for the given date to use for signing. For example: \"20190927\"\n     * @param date\n     */\n    private static getDateString(date: Date): string {\n        return this.getDateTimeString(date).substring(0, 8);\n    }\n\n    private static async sha256(message: string): Promise<string> {\n        const hashBuffer = await crypto.subtle.digest({ name: 'SHA-256' }, this.toUint8Array(message));\n        return this.toHex(hashBuffer);\n    }\n\n    private static async hmac(key: string | ArrayBuffer, message: string): Promise<ArrayBuffer> {\n        const keyBuffer = typeof key === 'string' ? this.toUint8Array(key).buffer : key;\n        const messageBuffer = this.toUint8Array(message).buffer;\n        const cryptoKey = await crypto.subtle.importKey(\n            'raw',\n            keyBuffer,\n            {\n                name: 'HMAC',\n                hash: {\n                    name: 'SHA-256',\n                },\n            },\n            false,\n            ['sign'],\n        );\n        return await crypto.subtle.sign({ name: 'HMAC', hash: { name: 'SHA-256' } }, cryptoKey, messageBuffer);\n    }\n\n    /**\n     * Note that this implementation does not work with two-byte characters.\n     * However, no inputs into a signed signaling service request should have two-byte characters.\n     */\n    private static toUint8Array(input: string): Uint8Array {\n        const buf = new ArrayBuffer(input.length);\n        const bufView = new Uint8Array(buf);\n        for (let i = 0, strLen = input.length; i < strLen; i++) {\n            bufView[i] = input.charCodeAt(i);\n        }\n        return bufView;\n    }\n\n    private static toHex(buffer: ArrayBuffer): string {\n        return Array.from(new Uint8Array(buffer))\n            .map(b => b.toString(16).padStart(2, '0'))\n            .join('');\n    }\n}\n","import { EventEmitter } from 'events';\n\nimport { QueryParams } from './QueryParams';\nimport { RequestSigner } from './RequestSigner';\nimport { Role } from './Role';\nimport { SigV4RequestSigner } from './SigV4RequestSigner';\nimport DateProvider from './internal/DateProvider';\nimport { validateValueNil, validateValueNonNil } from './internal/utils';\n\n/**\n * A partial copy of the credentials from the AWS SDK for JS: https://github.com/aws/aws-sdk-js/blob/master/lib/credentials.d.ts\n * The interface is copied here so that a dependency on the AWS SDK for JS is not needed.\n */\nexport interface Credentials {\n    accessKeyId: string;\n    secretAccessKey: string;\n    sessionToken?: string;\n    getPromise?(): Promise<void>;\n}\n\nexport interface SignalingClientConfig {\n    channelARN: string;\n    channelEndpoint: string;\n    credentials?: Credentials;\n    region: string;\n    requestSigner?: RequestSigner;\n    role: Role;\n    clientId?: string;\n    systemClockOffset?: number;\n}\n\nenum MessageType {\n    SDP_ANSWER = 'SDP_ANSWER',\n    SDP_OFFER = 'SDP_OFFER',\n    ICE_CANDIDATE = 'ICE_CANDIDATE',\n}\n\nenum ReadyState {\n    CONNECTING,\n    OPEN,\n    CLOSING,\n    CLOSED,\n}\n\ninterface WebSocketMessage {\n    messageType: MessageType;\n    messagePayload: string;\n    senderClientId?: string;\n}\n\n/**\n * Client for sending and receiving messages from a KVS Signaling Channel. The client can operate as either the 'MASTER' or a 'VIEWER'.\n *\n * Typically, the 'MASTER' listens for ICE candidates and SDP offers and responds with and SDP answer and its own ICE candidates.\n *\n * Typically, the 'VIEWER' sends an SDP offer and its ICE candidates and then listens for ICE candidates and SDP answers from the 'MASTER'.\n */\nexport class SignalingClient extends EventEmitter {\n    private static DEFAULT_CLIENT_ID = 'MASTER';\n\n    private websocket: WebSocket = null;\n    private readyState = ReadyState.CLOSED;\n    private readonly requestSigner: RequestSigner;\n    private readonly config: SignalingClientConfig;\n    private readonly pendingIceCandidatesByClientId: { [clientId: string]: object[] } = {};\n    private readonly hasReceivedRemoteSDPByClientId: { [clientId: string]: boolean } = {};\n    private readonly dateProvider: DateProvider;\n\n    /**\n     * Creates a new SignalingClient. The connection with the signaling service must be opened with the 'open' method.\n     * @param {SignalingClientConfig} config - Configuration options and parameters.\n     * is not provided, it will be loaded from the global scope.\n     */\n    public constructor(config: SignalingClientConfig) {\n        super();\n\n        // Validate config\n        validateValueNonNil(config, 'SignalingClientConfig');\n        validateValueNonNil(config.role, 'role');\n        if (config.role === Role.VIEWER) {\n            validateValueNonNil(config.clientId, 'clientId');\n        } else {\n            validateValueNil(config.clientId, 'clientId');\n        }\n        validateValueNonNil(config.channelARN, 'channelARN');\n        validateValueNonNil(config.region, 'region');\n        validateValueNonNil(config.channelEndpoint, 'channelEndpoint');\n\n        this.config = { ...config }; // Copy config to new object for immutability.\n\n        if (config.requestSigner) {\n            this.requestSigner = config.requestSigner;\n        } else {\n            validateValueNonNil(config.credentials, 'credentials');\n            this.requestSigner = new SigV4RequestSigner(config.region, config.credentials);\n        }\n\n        this.dateProvider = new DateProvider(config.systemClockOffset || 0);\n\n        // Bind event handlers\n        this.onOpen = this.onOpen.bind(this);\n        this.onMessage = this.onMessage.bind(this);\n        this.onError = this.onError.bind(this);\n        this.onClose = this.onClose.bind(this);\n    }\n\n    /**\n     * Opens the connection with the signaling service. Listen to the 'open' event to be notified when the connection has been opened.\n     */\n    public open(): void {\n        if (this.readyState !== ReadyState.CLOSED) {\n            throw new Error('Client is already open, opening, or closing');\n        }\n        this.readyState = ReadyState.CONNECTING;\n\n        // The process of opening the connection is asynchronous via promises, but the interaction model is to handle asynchronous actions via events.\n        // Therefore, we just kick off the asynchronous process and then return and let it fire events.\n        this.asyncOpen()\n            .then()\n            .catch(err => this.onError(err));\n    }\n\n    /**\n     * Asynchronous implementation of `open`.\n     */\n    private async asyncOpen(): Promise<void> {\n        const queryParams: QueryParams = {\n            'X-Amz-ChannelARN': this.config.channelARN,\n        };\n        if (this.config.role === Role.VIEWER) {\n            queryParams['X-Amz-ClientId'] = this.config.clientId;\n        }\n        const signedURL = await this.requestSigner.getSignedURL(this.config.channelEndpoint, queryParams, this.dateProvider.getDate());\n\n        // If something caused the state to change from CONNECTING, then don't create the WebSocket instance.\n        if (this.readyState !== ReadyState.CONNECTING) {\n            return;\n        }\n\n        this.websocket = new WebSocket(signedURL);\n\n        this.websocket.addEventListener('open', this.onOpen);\n        this.websocket.addEventListener('message', this.onMessage);\n        this.websocket.addEventListener('error', this.onError);\n        this.websocket.addEventListener('close', this.onClose);\n    }\n\n    /**\n     * Closes the connection to the KVS Signaling Service. If already closed or closing, no action is taken. Listen to the 'close' event to be notified when the\n     * connection has been closed.\n     */\n    public close(): void {\n        if (this.websocket !== null) {\n            this.readyState = ReadyState.CLOSING;\n            this.websocket.close();\n        } else if (this.readyState !== ReadyState.CLOSED) {\n            this.onClose();\n        }\n    }\n\n    /**\n     * Sends the given SDP offer to the signaling service.\n     *\n     * Typically, only the 'VIEWER' role should send an SDP offer.\n     * @param {RTCSessionDescription} sdpOffer - SDP offer to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     */\n    public sendSdpOffer(sdpOffer: RTCSessionDescription, recipientClientId?: string): void {\n        this.sendMessage(MessageType.SDP_OFFER, sdpOffer.toJSON(), recipientClientId);\n    }\n\n    /**\n     * Sends the given SDP answer to the signaling service.\n     *\n     * Typically, only the 'MASTER' role should send an SDP answer.\n     * @param {RTCSessionDescription} sdpAnswer - SDP answer to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     */\n    public sendSdpAnswer(sdpAnswer: RTCSessionDescription, recipientClientId?: string): void {\n        this.sendMessage(MessageType.SDP_ANSWER, sdpAnswer.toJSON(), recipientClientId);\n    }\n\n    /**\n     * Sends the given ICE candidate to the signaling service.\n     *\n     * Typically, both the 'VIEWER' role and 'MASTER' role should send ICE candidates.\n     * @param {RTCIceCandidate} iceCandidate - ICE candidate to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     */\n    public sendIceCandidate(iceCandidate: RTCIceCandidate, recipientClientId?: string): void {\n        this.sendMessage(MessageType.ICE_CANDIDATE, iceCandidate.toJSON(), recipientClientId);\n    }\n\n    /**\n     * Validates the WebSocket connection is open and that the recipient client id is present if sending as the 'MASTER'. Encodes the given message payload\n     * and sends the message to the signaling service.\n     */\n    private sendMessage(action: MessageType, messagePayload: object, recipientClientId?: string): void {\n        if (this.readyState !== ReadyState.OPEN) {\n            throw new Error('Could not send message because the connection to the signaling service is not open.');\n        }\n        this.validateRecipientClientId(recipientClientId);\n\n        this.websocket.send(\n            JSON.stringify({\n                action,\n                messagePayload: SignalingClient.serializeJSONObjectAsBase64String(messagePayload),\n                recipientClientId: recipientClientId || undefined,\n            }),\n        );\n    }\n\n    /**\n     * Removes all event listeners from the WebSocket and removes the reference to the WebSocket object.\n     */\n    private cleanupWebSocket(): void {\n        if (this.websocket === null) {\n            return;\n        }\n        this.websocket.removeEventListener('open', this.onOpen);\n        this.websocket.removeEventListener('message', this.onMessage);\n        this.websocket.removeEventListener('error', this.onError);\n        this.websocket.removeEventListener('close', this.onClose);\n        this.websocket = null;\n    }\n\n    /**\n     * WebSocket 'open' event handler. Forwards the event on to listeners.\n     */\n    private onOpen(): void {\n        this.readyState = ReadyState.OPEN;\n        this.emit('open');\n    }\n\n    /**\n     * WebSocket 'message' event handler. Attempts to parse the message and handle it according to the message type.\n     */\n    private onMessage(event: MessageEvent): void {\n        let parsedEventData: WebSocketMessage;\n        let parsedMessagePayload: object;\n        try {\n            parsedEventData = JSON.parse(event.data) as WebSocketMessage;\n            parsedMessagePayload = SignalingClient.parseJSONObjectFromBase64String(parsedEventData.messagePayload);\n        } catch (e) {\n            // For forwards compatibility we ignore messages that are not able to be parsed.\n            // TODO: Consider how to make it easier for users to be aware of dropped messages.\n            return;\n        }\n        const { messageType, senderClientId } = parsedEventData;\n        switch (messageType) {\n            case MessageType.SDP_OFFER:\n                this.emit('sdpOffer', parsedMessagePayload, senderClientId);\n                this.emitPendingIceCandidates(senderClientId);\n                return;\n            case MessageType.SDP_ANSWER:\n                this.emit('sdpAnswer', parsedMessagePayload, senderClientId);\n                this.emitPendingIceCandidates(senderClientId);\n                return;\n            case MessageType.ICE_CANDIDATE:\n                this.emitOrQueueIceCandidate(parsedMessagePayload, senderClientId);\n                return;\n        }\n    }\n\n    /**\n     * Takes the given base64 encoded string and decodes it into a JSON object.\n     */\n    private static parseJSONObjectFromBase64String(base64EncodedString: string): object {\n        return JSON.parse(atob(base64EncodedString));\n    }\n\n    /**\n     * Takes the given JSON object and encodes it into a base64 string.\n     */\n    private static serializeJSONObjectAsBase64String(object: object): string {\n        return btoa(JSON.stringify(object));\n    }\n\n    /**\n     * If an SDP offer or answer has already been received from the given client, then the given ICE candidate is emitted. Otherwise, it is queued up for when\n     * an SDP offer or answer is received.\n     */\n    private emitOrQueueIceCandidate(iceCandidate: object, clientId?: string): void {\n        const clientIdKey = clientId || SignalingClient.DEFAULT_CLIENT_ID;\n        if (this.hasReceivedRemoteSDPByClientId[clientIdKey]) {\n            this.emit('iceCandidate', iceCandidate, clientId);\n        } else {\n            if (!this.pendingIceCandidatesByClientId[clientIdKey]) {\n                this.pendingIceCandidatesByClientId[clientIdKey] = [];\n            }\n            this.pendingIceCandidatesByClientId[clientIdKey].push(iceCandidate);\n        }\n    }\n\n    /**\n     * Emits any pending ICE candidates for the given client and records that an SDP offer or answer has been received from the client.\n     */\n    private emitPendingIceCandidates(clientId?: string): void {\n        const clientIdKey = clientId || SignalingClient.DEFAULT_CLIENT_ID;\n        this.hasReceivedRemoteSDPByClientId[clientIdKey] = true;\n        const pendingIceCandidates = this.pendingIceCandidatesByClientId[clientIdKey];\n        if (!pendingIceCandidates) {\n            return;\n        }\n        delete this.pendingIceCandidatesByClientId[clientIdKey];\n        pendingIceCandidates.forEach(iceCandidate => {\n            this.emit('iceCandidate', iceCandidate, clientId);\n        });\n    }\n\n    /**\n     * Throws an error if the recipient client id is null and the current role is 'MASTER' as all messages sent as 'MASTER' should have a recipient client id.\n     */\n    private validateRecipientClientId(recipientClientId?: string): void {\n        if (this.config.role === Role.VIEWER && recipientClientId) {\n            throw new Error('Unexpected recipient client id. As the VIEWER, messages must not be sent with a recipient client id.');\n        }\n    }\n\n    /**\n     * 'error' event handler. Forwards the error onto listeners.\n     */\n    private onError(error: Error | Event): void {\n        this.emit('error', error);\n    }\n\n    /**\n     * 'close' event handler. Forwards the error onto listeners and cleans up the connection.\n     */\n    private onClose(): void {\n        this.readyState = ReadyState.CLOSED;\n        this.cleanupWebSocket();\n        this.emit('close');\n    }\n}\n","/**\n * Provides dates with an offset to account for local clock skew.\n *\n * Unfortunately, WebSockets in the web do not provide any of the connection information needed to determine the clock skew from a failed connection request.\n * Therefore, a hard coded offset is used that is provided from the AWS SDK.\n *\n * See {@link https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Config.html#correctClockSkew-property}\n */\nexport default class DateProvider {\n    private readonly clockOffsetMs: number;\n\n    public constructor(clockOffsetMs: number) {\n        this.clockOffsetMs = clockOffsetMs;\n    }\n\n    /**\n     * Gets the current date with any configured clock offset applied.\n     */\n    public getDate(): Date {\n        return new Date(Date.now() + this.clockOffsetMs);\n    }\n}\n","/**\n * Validates that the given value is not null, undefined, or empty string and throws an error if the condition is not met.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function validateValueNonNil(value: any, valueName: string): void {\n    if (value === null) {\n        throw new Error(`${valueName} cannot be null`);\n    } else if (value === undefined) {\n        throw new Error(`${valueName} cannot be undefined`);\n    } else if (value === '') {\n        throw new Error(`${valueName} cannot be empty`);\n    }\n}\n\n/**\n * Validates that the given value is null, undefined, or empty string and throws an error if the condition is not met.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function validateValueNil(value: any, valueName: string): void {\n    if (value !== null && value !== undefined && value !== '') {\n        throw new Error(`${valueName} should be null`);\n    }\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\n","module.exports = window[\"crypto\"];","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/*!\nAmazon Kinesis Video Streams WebRTC SDK for JavaScript\nCopyright 2019-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n\nThis product includes software developed at\nAmazon Web Services, Inc. (http://aws.amazon.com/).\n*/\nexport { Role } from './Role';\nexport { SignalingClient } from './SignalingClient';\nexport { SigV4RequestSigner } from './SigV4RequestSigner';\nexport { QueryParams } from './QueryParams';\nexport { RequestSigner } from './RequestSigner';\n\nexport const VERSION = process.env.PACKAGE_VERSION;\n"],"names":[],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"kvs-webrtc.js","mappings":";;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEa;;AAEb;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,sBAAsB;AACxC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe;AACf;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA,oBAAoB,SAAS;AAC7B;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;AAEA,kCAAkC,QAAQ;AAC1C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,QAAQ;AACR;AACA,uCAAuC,QAAQ;AAC/C;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;;AAEA;AACA,SAAS,yBAAyB;AAClC;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,8DAA8D,YAAY;AAC1E;AACA,8DAA8D,YAAY;AAC1E;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,qCAAqC,YAA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A;AACA;AACA,WAAW,gBAAgB,sCAAsC,kBAAkB;AACnF,0BAA0B;AAC1B;AACA;AACA;AACO;AACP;AACA,oBAAoB;AACpB;AACA;AACA;AACO;AACP;AACA,iDAAiD,OAAO;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,6DAA6D,cAAc;AAC3E;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;AACA;AACO;AACP,oCAAoC;AACpC;AACA;AACO;AACP;AACA;AACA;AACO;AACP,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AACO;AACP,cAAc,6BAA6B,0BAA0B,cAAc,qBAAqB;AACxG,iBAAiB,oDAAoD,qEAAqE,cAAc;AACxJ,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC,mCAAmC,SAAS;AAC5C,mCAAmC,WAAW,UAAU;AACxD,0CAA0C,cAAc;AACxD;AACA,8GAA8G,OAAO;AACrH,iFAAiF,iBAAiB;AAClG,yDAAyD,gBAAgB,QAAQ;AACjF,+CAA+C,gBAAgB,gBAAgB;AAC/E;AACA,kCAAkC;AAClC;AACA;AACA,UAAU,YAAY,aAAa,SAAS,UAAU;AACtD,oCAAoC,SAAS;AAC7C;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,MAAM;AAC1B;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACO;AACP,6BAA6B,sBAAsB;AACnD;AACA;AACA;AACA;AACO;AACP,kDAAkD,QAAQ;AAC1D,yCAAyC,QAAQ;AACjD,yDAAyD,QAAQ;AACjE;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA,iBAAiB,uFAAuF,cAAc;AACtH,uBAAuB,gCAAgC,qCAAqC,2CAA2C;AACvI,4BAA4B,MAAM,iBAAiB,YAAY;AAC/D,uBAAuB;AACvB,8BAA8B;AAC9B,6BAA6B;AAC7B,4BAA4B;AAC5B;AACA;AACO;AACP;AACA,iBAAiB,6CAA6C,UAAU,sDAAsD,cAAc;AAC5I,0BAA0B,6BAA6B,oBAAoB,gDAAgD,kBAAkB;AAC7I;AACA;AACO;AACP;AACA;AACA,2GAA2G,uFAAuF,cAAc;AAChN,uBAAuB,8BAA8B,gDAAgD,wDAAwD;AAC7J,6CAA6C,sCAAsC,UAAU,mBAAmB,IAAI;AACpH;AACA;AACO;AACP,iCAAiC,uCAAuC,YAAY,KAAK,OAAO;AAChG;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,6CAA6C;AAC7C;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;ACzNa;;AAEb;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;ACPA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;WCPD;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;ACNA;;;;;;EAME;AACF,gEAA8B;AAArB,iGAAI;AACb,iGAAoD;AAA3C,kIAAe;AACxB,0GAA0D;AAAjD,2IAAkB;AAC3B,qFAA4C;AAAnC,sHAAW;AACpB,2FAAgD;AAAvC,4HAAa;AAET,eAAO,GAAG,OAA2B,CAAC","sources":["webpack://KVSWebRTC/./node_modules/events/events.js","webpack://KVSWebRTC/./src/QueryParams.ts","webpack://KVSWebRTC/./src/RequestSigner.ts","webpack://KVSWebRTC/./src/Role.ts","webpack://KVSWebRTC/./src/SigV4RequestSigner.ts","webpack://KVSWebRTC/./src/SignalingClient.ts","webpack://KVSWebRTC/./src/internal/DateProvider.ts","webpack://KVSWebRTC/./src/internal/utils.ts","webpack://KVSWebRTC/./node_modules/tslib/tslib.es6.js","webpack://KVSWebRTC/./node_modules/ws/browser.js","webpack://KVSWebRTC/external window \"crypto\"","webpack://KVSWebRTC/webpack/bootstrap","webpack://KVSWebRTC/webpack/runtime/define property getters","webpack://KVSWebRTC/webpack/runtime/global","webpack://KVSWebRTC/webpack/runtime/hasOwnProperty shorthand","webpack://KVSWebRTC/webpack/runtime/make namespace object","webpack://KVSWebRTC/./src/index.ts"],"sourcesContent":["// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n  ? R.apply\n  : function ReflectApply(target, receiver, args) {\n    return Function.prototype.apply.call(target, receiver, args);\n  }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n  ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target)\n      .concat(Object.getOwnPropertySymbols(target));\n  };\n} else {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target);\n  };\n}\n\nfunction ProcessEmitWarning(warning) {\n  if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n  return value !== value;\n}\n\nfunction EventEmitter() {\n  EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n  if (typeof listener !== 'function') {\n    throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n  }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n  enumerable: true,\n  get: function() {\n    return defaultMaxListeners;\n  },\n  set: function(arg) {\n    if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n      throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n    }\n    defaultMaxListeners = arg;\n  }\n});\n\nEventEmitter.init = function() {\n\n  if (this._events === undefined ||\n      this._events === Object.getPrototypeOf(this)._events) {\n    this._events = Object.create(null);\n    this._eventsCount = 0;\n  }\n\n  this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n  if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n    throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n  }\n  this._maxListeners = n;\n  return this;\n};\n\nfunction _getMaxListeners(that) {\n  if (that._maxListeners === undefined)\n    return EventEmitter.defaultMaxListeners;\n  return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n  return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n  var args = [];\n  for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n  var doError = (type === 'error');\n\n  var events = this._events;\n  if (events !== undefined)\n    doError = (doError && events.error === undefined);\n  else if (!doError)\n    return false;\n\n  // If there is no 'error' event listener then throw.\n  if (doError) {\n    var er;\n    if (args.length > 0)\n      er = args[0];\n    if (er instanceof Error) {\n      // Note: The comments on the `throw` lines are intentional, they show\n      // up in Node's output if this results in an unhandled exception.\n      throw er; // Unhandled 'error' event\n    }\n    // At least give some kind of context to the user\n    var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n    err.context = er;\n    throw err; // Unhandled 'error' event\n  }\n\n  var handler = events[type];\n\n  if (handler === undefined)\n    return false;\n\n  if (typeof handler === 'function') {\n    ReflectApply(handler, this, args);\n  } else {\n    var len = handler.length;\n    var listeners = arrayClone(handler, len);\n    for (var i = 0; i < len; ++i)\n      ReflectApply(listeners[i], this, args);\n  }\n\n  return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n  var m;\n  var events;\n  var existing;\n\n  checkListener(listener);\n\n  events = target._events;\n  if (events === undefined) {\n    events = target._events = Object.create(null);\n    target._eventsCount = 0;\n  } else {\n    // To avoid recursion in the case that type === \"newListener\"! Before\n    // adding it to the listeners, first emit \"newListener\".\n    if (events.newListener !== undefined) {\n      target.emit('newListener', type,\n                  listener.listener ? listener.listener : listener);\n\n      // Re-assign `events` because a newListener handler could have caused the\n      // this._events to be assigned to a new object\n      events = target._events;\n    }\n    existing = events[type];\n  }\n\n  if (existing === undefined) {\n    // Optimize the case of one listener. Don't need the extra array object.\n    existing = events[type] = listener;\n    ++target._eventsCount;\n  } else {\n    if (typeof existing === 'function') {\n      // Adding the second element, need to change to array.\n      existing = events[type] =\n        prepend ? [listener, existing] : [existing, listener];\n      // If we've already got an array, just append.\n    } else if (prepend) {\n      existing.unshift(listener);\n    } else {\n      existing.push(listener);\n    }\n\n    // Check for listener leak\n    m = _getMaxListeners(target);\n    if (m > 0 && existing.length > m && !existing.warned) {\n      existing.warned = true;\n      // No error code for this since it is a Warning\n      // eslint-disable-next-line no-restricted-syntax\n      var w = new Error('Possible EventEmitter memory leak detected. ' +\n                          existing.length + ' ' + String(type) + ' listeners ' +\n                          'added. Use emitter.setMaxListeners() to ' +\n                          'increase limit');\n      w.name = 'MaxListenersExceededWarning';\n      w.emitter = target;\n      w.type = type;\n      w.count = existing.length;\n      ProcessEmitWarning(w);\n    }\n  }\n\n  return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n  return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n    function prependListener(type, listener) {\n      return _addListener(this, type, listener, true);\n    };\n\nfunction onceWrapper() {\n  if (!this.fired) {\n    this.target.removeListener(this.type, this.wrapFn);\n    this.fired = true;\n    if (arguments.length === 0)\n      return this.listener.call(this.target);\n    return this.listener.apply(this.target, arguments);\n  }\n}\n\nfunction _onceWrap(target, type, listener) {\n  var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n  var wrapped = onceWrapper.bind(state);\n  wrapped.listener = listener;\n  state.wrapFn = wrapped;\n  return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n  checkListener(listener);\n  this.on(type, _onceWrap(this, type, listener));\n  return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n    function prependOnceListener(type, listener) {\n      checkListener(listener);\n      this.prependListener(type, _onceWrap(this, type, listener));\n      return this;\n    };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n    function removeListener(type, listener) {\n      var list, events, position, i, originalListener;\n\n      checkListener(listener);\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      list = events[type];\n      if (list === undefined)\n        return this;\n\n      if (list === listener || list.listener === listener) {\n        if (--this._eventsCount === 0)\n          this._events = Object.create(null);\n        else {\n          delete events[type];\n          if (events.removeListener)\n            this.emit('removeListener', type, list.listener || listener);\n        }\n      } else if (typeof list !== 'function') {\n        position = -1;\n\n        for (i = list.length - 1; i >= 0; i--) {\n          if (list[i] === listener || list[i].listener === listener) {\n            originalListener = list[i].listener;\n            position = i;\n            break;\n          }\n        }\n\n        if (position < 0)\n          return this;\n\n        if (position === 0)\n          list.shift();\n        else {\n          spliceOne(list, position);\n        }\n\n        if (list.length === 1)\n          events[type] = list[0];\n\n        if (events.removeListener !== undefined)\n          this.emit('removeListener', type, originalListener || listener);\n      }\n\n      return this;\n    };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n    function removeAllListeners(type) {\n      var listeners, events, i;\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      // not listening for removeListener, no need to emit\n      if (events.removeListener === undefined) {\n        if (arguments.length === 0) {\n          this._events = Object.create(null);\n          this._eventsCount = 0;\n        } else if (events[type] !== undefined) {\n          if (--this._eventsCount === 0)\n            this._events = Object.create(null);\n          else\n            delete events[type];\n        }\n        return this;\n      }\n\n      // emit removeListener for all listeners on all events\n      if (arguments.length === 0) {\n        var keys = Object.keys(events);\n        var key;\n        for (i = 0; i < keys.length; ++i) {\n          key = keys[i];\n          if (key === 'removeListener') continue;\n          this.removeAllListeners(key);\n        }\n        this.removeAllListeners('removeListener');\n        this._events = Object.create(null);\n        this._eventsCount = 0;\n        return this;\n      }\n\n      listeners = events[type];\n\n      if (typeof listeners === 'function') {\n        this.removeListener(type, listeners);\n      } else if (listeners !== undefined) {\n        // LIFO order\n        for (i = listeners.length - 1; i >= 0; i--) {\n          this.removeListener(type, listeners[i]);\n        }\n      }\n\n      return this;\n    };\n\nfunction _listeners(target, type, unwrap) {\n  var events = target._events;\n\n  if (events === undefined)\n    return [];\n\n  var evlistener = events[type];\n  if (evlistener === undefined)\n    return [];\n\n  if (typeof evlistener === 'function')\n    return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n  return unwrap ?\n    unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n  return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n  return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  if (typeof emitter.listenerCount === 'function') {\n    return emitter.listenerCount(type);\n  } else {\n    return listenerCount.call(emitter, type);\n  }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n  var events = this._events;\n\n  if (events !== undefined) {\n    var evlistener = events[type];\n\n    if (typeof evlistener === 'function') {\n      return 1;\n    } else if (evlistener !== undefined) {\n      return evlistener.length;\n    }\n  }\n\n  return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n  return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n  var copy = new Array(n);\n  for (var i = 0; i < n; ++i)\n    copy[i] = arr[i];\n  return copy;\n}\n\nfunction spliceOne(list, index) {\n  for (; index + 1 < list.length; index++)\n    list[index] = list[index + 1];\n  list.pop();\n}\n\nfunction unwrapListeners(arr) {\n  var ret = new Array(arr.length);\n  for (var i = 0; i < ret.length; ++i) {\n    ret[i] = arr[i].listener || arr[i];\n  }\n  return ret;\n}\n\nfunction once(emitter, name) {\n  return new Promise(function (resolve, reject) {\n    function errorListener(err) {\n      emitter.removeListener(name, resolver);\n      reject(err);\n    }\n\n    function resolver() {\n      if (typeof emitter.removeListener === 'function') {\n        emitter.removeListener('error', errorListener);\n      }\n      resolve([].slice.call(arguments));\n    };\n\n    eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n    if (name !== 'error') {\n      addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n    }\n  });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n  if (typeof emitter.on === 'function') {\n    eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n  }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n  if (typeof emitter.on === 'function') {\n    if (flags.once) {\n      emitter.once(name, listener);\n    } else {\n      emitter.on(name, listener);\n    }\n  } else if (typeof emitter.addEventListener === 'function') {\n    // EventTarget does not have `error` event semantics like Node\n    // EventEmitters, we do not listen for `error` events here.\n    emitter.addEventListener(name, function wrapListener(arg) {\n      // IE does not have builtin `{ once: true }` support so we\n      // have to do it manually.\n      if (flags.once) {\n        emitter.removeEventListener(name, wrapListener);\n      }\n      listener(arg);\n    });\n  } else {\n    throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n  }\n}\n","export type QueryParams = { [queryParam: string]: string };\n","import { QueryParams } from './QueryParams';\n\nexport interface RequestSigner {\n    getSignedURL: (signalingEndpoint: string, queryParams: QueryParams, date?: Date) => Promise<string>;\n}\n","/**\n * Signaling client role.\n */\nexport enum Role {\n    MASTER = 'MASTER',\n    VIEWER = 'VIEWER',\n}\n","import crypto from 'isomorphic-webcrypto';\n\nimport { QueryParams } from './QueryParams';\nimport { RequestSigner } from './RequestSigner';\nimport { Credentials } from './SignalingClient';\nimport { validateValueNonNil } from './internal/utils';\n\ntype Headers = { [header: string]: string };\n\n/**\n * Utility class for SigV4 signing requests. The AWS SDK cannot be used for this purpose because it does not have support for WebSocket endpoints.\n */\nexport class SigV4RequestSigner implements RequestSigner {\n    private static readonly DEFAULT_ALGORITHM = 'AWS4-HMAC-SHA256';\n    private static readonly DEFAULT_SERVICE = 'kinesisvideo';\n\n    private readonly region: string;\n    private readonly credentials: Credentials;\n    private readonly service: string;\n\n    public constructor(region: string, credentials: Credentials, service: string = SigV4RequestSigner.DEFAULT_SERVICE) {\n        this.region = region;\n        this.credentials = credentials;\n        this.service = service;\n    }\n\n    /**\n     * Creates a SigV4 signed WebSocket URL for the given host/endpoint with the given query params.\n     *\n     * @param endpoint The WebSocket service endpoint including protocol, hostname, and path (if applicable).\n     * @param queryParams Query parameters to include in the URL.\n     * @param date Date to use for request signing. Defaults to NOW.\n     *\n     * Implementation note: Query parameters should be in alphabetical order.\n     *\n     * Note from AWS docs: \"When you add the X-Amz-Security-Token parameter to the query string, some services require that you include this parameter in the\n     * canonical (signed) request. For other services, you add this parameter at the end, after you calculate the signature. For details, see the API reference\n     * documentation for that service.\" KVS Signaling Service requires that the session token is added to the canonical request.\n     *\n     * @see https://docs.aws.amazon.com/AmazonS3/latest/API/sigv4-query-string-auth.html\n     * @see https://gist.github.com/prestomation/24b959e51250a8723b9a5a4f70dcae08\n     */\n    public async getSignedURL(endpoint: string, queryParams: QueryParams, date: Date = new Date()): Promise<string> {\n        // Refresh credentials\n        if (typeof this.credentials.getPromise === 'function') {\n            await this.credentials.getPromise();\n        }\n        validateValueNonNil(this.credentials.accessKeyId, 'credentials.accessKeyId');\n        validateValueNonNil(this.credentials.secretAccessKey, 'credentials.secretAccessKey');\n\n        // Prepare date strings\n        const datetimeString = SigV4RequestSigner.getDateTimeString(date);\n        const dateString = SigV4RequestSigner.getDateString(date);\n\n        // Validate and parse endpoint\n        const protocol = 'wss';\n        const urlProtocol = `${protocol}://`;\n        if (!endpoint.startsWith(urlProtocol)) {\n            throw new Error(`Endpoint '${endpoint}' is not a secure WebSocket endpoint. It should start with '${urlProtocol}'.`);\n        }\n        if (endpoint.includes('?')) {\n            throw new Error(`Endpoint '${endpoint}' should not contain any query parameters.`);\n        }\n        const pathStartIndex = endpoint.indexOf('/', urlProtocol.length);\n        let host;\n        let path;\n        if (pathStartIndex < 0) {\n            host = endpoint.substring(urlProtocol.length);\n            path = '/';\n        } else {\n            host = endpoint.substring(urlProtocol.length, pathStartIndex);\n            path = endpoint.substring(pathStartIndex);\n        }\n\n        const signedHeaders = ['host'].join(';');\n\n        // Prepare method\n        const method = 'GET'; // Method is always GET for signed URLs\n\n        // Prepare canonical query string\n        const credentialScope = dateString + '/' + this.region + '/' + this.service + '/' + 'aws4_request';\n        const canonicalQueryParams = Object.assign({}, queryParams, {\n            'X-Amz-Algorithm': SigV4RequestSigner.DEFAULT_ALGORITHM,\n            'X-Amz-Credential': this.credentials.accessKeyId + '/' + credentialScope,\n            'X-Amz-Date': datetimeString,\n            'X-Amz-Expires': '299',\n            'X-Amz-SignedHeaders': signedHeaders,\n        });\n        if (this.credentials.sessionToken) {\n            Object.assign(canonicalQueryParams, {\n                'X-Amz-Security-Token': this.credentials.sessionToken,\n            });\n        }\n        const canonicalQueryString = SigV4RequestSigner.createQueryString(canonicalQueryParams);\n\n        // Prepare canonical headers\n        const canonicalHeaders = {\n            host,\n        };\n        const canonicalHeadersString = SigV4RequestSigner.createHeadersString(canonicalHeaders);\n\n        // Prepare payload hash\n        const payloadHash = await SigV4RequestSigner.sha256('');\n\n        // Combine canonical request parts into a canonical request string and hash\n        const canonicalRequest = [method, path, canonicalQueryString, canonicalHeadersString, signedHeaders, payloadHash].join('\\n');\n        const canonicalRequestHash = await SigV4RequestSigner.sha256(canonicalRequest);\n\n        // Create signature\n        const stringToSign = [SigV4RequestSigner.DEFAULT_ALGORITHM, datetimeString, credentialScope, canonicalRequestHash].join('\\n');\n        const signingKey = await this.getSignatureKey(dateString);\n        const signature = await SigV4RequestSigner.toHex(await SigV4RequestSigner.hmac(signingKey, stringToSign));\n\n        // Add signature to query params\n        const signedQueryParams = Object.assign({}, canonicalQueryParams, {\n            'X-Amz-Signature': signature,\n        });\n\n        // Create signed URL\n        return protocol + '://' + host + path + '?' + SigV4RequestSigner.createQueryString(signedQueryParams);\n    }\n\n    /**\n     * Utility method for generating the key to use for calculating the signature. This combines together the date string, region, service name, and secret\n     * access key.\n     *\n     * @see https://docs.aws.amazon.com/general/latest/gr/sigv4-calculate-signature.html\n     */\n    private async getSignatureKey(dateString: string): Promise<ArrayBuffer> {\n        const kDate = await SigV4RequestSigner.hmac('AWS4' + this.credentials.secretAccessKey, dateString);\n        const kRegion = await SigV4RequestSigner.hmac(kDate, this.region);\n        const kService = await SigV4RequestSigner.hmac(kRegion, this.service);\n        return await SigV4RequestSigner.hmac(kService, 'aws4_request');\n    }\n\n    /**\n     * Utility method for converting a map of headers to a string for signing.\n     */\n    private static createHeadersString(headers: Headers): string {\n        return Object.keys(headers)\n            .map(header => `${header}:${headers[header]}\\n`)\n            .join();\n    }\n\n    /**\n     * Utility method for converting a map of query parameters to a string with the parameter names sorted.\n     */\n    private static createQueryString(queryParams: QueryParams): string {\n        return Object.keys(queryParams)\n            .sort()\n            .map(key => `${key}=${encodeURIComponent(queryParams[key])}`)\n            .join('&');\n    }\n\n    /**\n     * Gets a datetime string for the given date to use for signing. For example: \"20190927T165210Z\"\n     * @param date\n     */\n    private static getDateTimeString(date: Date): string {\n        return date\n            .toISOString()\n            .replace(/\\.\\d{3}Z$/, 'Z')\n            .replace(/[:\\-]/g, '');\n    }\n\n    /**\n     * Gets a date string for the given date to use for signing. For example: \"20190927\"\n     * @param date\n     */\n    private static getDateString(date: Date): string {\n        return this.getDateTimeString(date).substring(0, 8);\n    }\n\n    private static async sha256(message: string): Promise<string> {\n        const hashBuffer = await crypto.subtle.digest({ name: 'SHA-256' }, this.toUint8Array(message));\n        return this.toHex(hashBuffer);\n    }\n\n    private static async hmac(key: string | ArrayBuffer, message: string): Promise<ArrayBuffer> {\n        const keyBuffer = typeof key === 'string' ? this.toUint8Array(key).buffer : key;\n        const messageBuffer = this.toUint8Array(message).buffer;\n        const cryptoKey = await crypto.subtle.importKey(\n            'raw',\n            keyBuffer,\n            {\n                name: 'HMAC',\n                hash: {\n                    name: 'SHA-256',\n                },\n            },\n            false,\n            ['sign'],\n        );\n        return await crypto.subtle.sign({ name: 'HMAC', hash: { name: 'SHA-256' } }, cryptoKey, messageBuffer);\n    }\n\n    /**\n     * Note that this implementation does not work with two-byte characters.\n     * However, no inputs into a signed signaling service request should have two-byte characters.\n     */\n    private static toUint8Array(input: string): Uint8Array {\n        const buf = new ArrayBuffer(input.length);\n        const bufView = new Uint8Array(buf);\n        for (let i = 0, strLen = input.length; i < strLen; i++) {\n            bufView[i] = input.charCodeAt(i);\n        }\n        return bufView;\n    }\n\n    private static toHex(buffer: ArrayBuffer): string {\n        return Array.from(new Uint8Array(buffer))\n            .map(b => b.toString(16).padStart(2, '0'))\n            .join('');\n    }\n}\n","import { EventEmitter } from 'events';\n\nimport { QueryParams } from './QueryParams';\nimport { RequestSigner } from './RequestSigner';\nimport { Role } from './Role';\nimport { SigV4RequestSigner } from './SigV4RequestSigner';\nimport DateProvider from './internal/DateProvider';\nimport { validateValueNil, validateValueNonNil } from './internal/utils';\n\n/**\n * A partial copy of the credentials from the AWS SDK for JS: https://github.com/aws/aws-sdk-js/blob/master/lib/credentials.d.ts\n * The interface is copied here so that a dependency on the AWS SDK for JS is not needed.\n */\nexport interface Credentials {\n    accessKeyId: string;\n    secretAccessKey: string;\n    sessionToken?: string;\n    getPromise?(): Promise<void>;\n}\n\nexport interface SignalingClientConfig {\n    channelARN: string;\n    channelEndpoint: string;\n    credentials?: Credentials;\n    region: string;\n    requestSigner?: RequestSigner;\n    role: Role;\n    clientId?: string;\n    systemClockOffset?: number;\n}\n\nenum MessageType {\n    SDP_ANSWER = 'SDP_ANSWER',\n    SDP_OFFER = 'SDP_OFFER',\n    ICE_CANDIDATE = 'ICE_CANDIDATE',\n    STATUS_RESPONSE = 'STATUS_RESPONSE',\n}\n\nenum ReadyState {\n    CONNECTING,\n    OPEN,\n    CLOSING,\n    CLOSED,\n}\n\ninterface WebSocketMessage {\n    messageType: MessageType;\n    messagePayload?: string;\n    senderClientId?: string;\n    statusResponse?: StatusResponse;\n}\n\nexport interface StatusResponse {\n    correlationId: 'string';\n    success: 'boolean';\n    errorType?: 'string';\n    statusCode?: 'string';\n    description?: 'string';\n}\n\n/**\n * Client for sending and receiving messages from a KVS Signaling Channel. The client can operate as either the 'MASTER' or a 'VIEWER'.\n *\n * Typically, the 'MASTER' listens for ICE candidates and SDP offers and responds with and SDP answer and its own ICE candidates.\n *\n * Typically, the 'VIEWER' sends an SDP offer and its ICE candidates and then listens for ICE candidates and SDP answers from the 'MASTER'.\n */\nexport class SignalingClient extends EventEmitter {\n    private static DEFAULT_CLIENT_ID = 'MASTER';\n\n    private websocket: WebSocket = null;\n    private readyState = ReadyState.CLOSED;\n    private readonly requestSigner: RequestSigner;\n    private readonly config: SignalingClientConfig;\n    private readonly pendingIceCandidatesByClientId: { [clientId: string]: object[] } = {};\n    private readonly hasReceivedRemoteSDPByClientId: { [clientId: string]: boolean } = {};\n    private readonly dateProvider: DateProvider;\n\n    /**\n     * Creates a new SignalingClient. The connection with the signaling service must be opened with the 'open' method.\n     * @param {SignalingClientConfig} config - Configuration options and parameters.\n     * is not provided, it will be loaded from the global scope.\n     */\n    public constructor(config: SignalingClientConfig) {\n        super();\n\n        // Validate config\n        validateValueNonNil(config, 'SignalingClientConfig');\n        validateValueNonNil(config.role, 'role');\n        if (config.role === Role.VIEWER) {\n            validateValueNonNil(config.clientId, 'clientId');\n        } else {\n            validateValueNil(config.clientId, 'clientId');\n        }\n        validateValueNonNil(config.channelARN, 'channelARN');\n        validateValueNonNil(config.region, 'region');\n        validateValueNonNil(config.channelEndpoint, 'channelEndpoint');\n\n        this.config = { ...config }; // Copy config to new object for immutability.\n\n        if (config.requestSigner) {\n            this.requestSigner = config.requestSigner;\n        } else {\n            validateValueNonNil(config.credentials, 'credentials');\n            this.requestSigner = new SigV4RequestSigner(config.region, config.credentials);\n        }\n\n        this.dateProvider = new DateProvider(config.systemClockOffset || 0);\n\n        // Bind event handlers\n        this.onOpen = this.onOpen.bind(this);\n        this.onMessage = this.onMessage.bind(this);\n        this.onError = this.onError.bind(this);\n        this.onClose = this.onClose.bind(this);\n    }\n\n    /**\n     * Opens the connection with the signaling service. Listen to the 'open' event to be notified when the connection has been opened.\n     */\n    public open(): void {\n        if (this.readyState !== ReadyState.CLOSED) {\n            throw new Error('Client is already open, opening, or closing');\n        }\n        this.readyState = ReadyState.CONNECTING;\n\n        // The process of opening the connection is asynchronous via promises, but the interaction model is to handle asynchronous actions via events.\n        // Therefore, we just kick off the asynchronous process and then return and let it fire events.\n        this.asyncOpen()\n            .then()\n            .catch(err => this.onError(err));\n    }\n\n    /**\n     * Asynchronous implementation of `open`.\n     */\n    private async asyncOpen(): Promise<void> {\n        const queryParams: QueryParams = {\n            'X-Amz-ChannelARN': this.config.channelARN,\n        };\n        if (this.config.role === Role.VIEWER) {\n            queryParams['X-Amz-ClientId'] = this.config.clientId;\n        }\n        const signedURL = await this.requestSigner.getSignedURL(this.config.channelEndpoint, queryParams, this.dateProvider.getDate());\n\n        // If something caused the state to change from CONNECTING, then don't create the WebSocket instance.\n        if (this.readyState !== ReadyState.CONNECTING) {\n            return;\n        }\n\n        /* istanbul ignore next */\n        this.websocket = new (global.WebSocket || require('ws'))(signedURL);\n\n        this.websocket.addEventListener('open', this.onOpen);\n        this.websocket.addEventListener('message', this.onMessage);\n        this.websocket.addEventListener('error', this.onError);\n        this.websocket.addEventListener('close', this.onClose);\n    }\n\n    /**\n     * Closes the connection to the KVS Signaling Service. If already closed or closing, no action is taken. Listen to the 'close' event to be notified when the\n     * connection has been closed.\n     */\n    public close(): void {\n        if (this.websocket !== null) {\n            this.readyState = ReadyState.CLOSING;\n            this.websocket.close();\n        } else if (this.readyState !== ReadyState.CLOSED) {\n            this.onClose();\n        }\n    }\n\n    /**\n     * Sends the given SDP offer to the signaling service.\n     *\n     * Typically, only the 'VIEWER' role should send an SDP offer.\n     * @param {RTCSessionDescription} sdpOffer - SDP offer to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error,\n     * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned.\n     */\n    public sendSdpOffer(sdpOffer: RTCSessionDescription, recipientClientId?: string, correlationId?: string): void {\n        this.sendMessage(MessageType.SDP_OFFER, sdpOffer, recipientClientId, correlationId);\n    }\n\n    /**\n     * Sends the given SDP answer to the signaling service.\n     *\n     * Typically, only the 'MASTER' role should send an SDP answer.\n     * @param {RTCSessionDescription} sdpAnswer - SDP answer to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error,\n     * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned.\n     */\n    public sendSdpAnswer(sdpAnswer: RTCSessionDescription, recipientClientId?: string, correlationId?: string): void {\n        this.sendMessage(MessageType.SDP_ANSWER, sdpAnswer, recipientClientId, correlationId);\n    }\n\n    /**\n     * Sends the given ICE candidate to the signaling service.\n     *\n     * Typically, both the 'VIEWER' role and 'MASTER' role should send ICE candidates.\n     * @param {RTCIceCandidate} iceCandidate - ICE candidate to send.\n     * @param {string} [recipientClientId] - ID of the client to send the message to. Required for 'MASTER' role. Should not be present for 'VIEWER' role.\n     * @param {string} [correlationId] - Unique ID for this message. If this is present and there is an error,\n     * Signaling will send a StatusResponse message describing the error. If this is not present, no error will be returned.\n     */\n    public sendIceCandidate(iceCandidate: RTCIceCandidate, recipientClientId?: string, correlationId?: string): void {\n        this.sendMessage(MessageType.ICE_CANDIDATE, iceCandidate, recipientClientId, correlationId);\n    }\n\n    /**\n     * Validates the WebSocket connection is open and that the recipient client id is present if sending as the 'MASTER'. Encodes the given message payload\n     * and sends the message to the signaling service.\n     */\n    private sendMessage(action: MessageType, messagePayload: object, recipientClientId?: string, correlationId?: string): void {\n        if (this.readyState !== ReadyState.OPEN) {\n            throw new Error('Could not send message because the connection to the signaling service is not open.');\n        }\n        this.validateRecipientClientId(recipientClientId);\n        this.validateCorrelationId(correlationId);\n\n        this.websocket.send(\n            JSON.stringify({\n                action,\n                messagePayload: SignalingClient.serializeJSONObjectAsBase64String(messagePayload),\n                recipientClientId: recipientClientId || undefined,\n                correlationId: correlationId || undefined,\n            }),\n        );\n    }\n\n    /**\n     * Removes all event listeners from the WebSocket and removes the reference to the WebSocket object.\n     */\n    private cleanupWebSocket(): void {\n        if (this.websocket === null) {\n            return;\n        }\n        this.websocket.removeEventListener('open', this.onOpen);\n        this.websocket.removeEventListener('message', this.onMessage);\n        this.websocket.removeEventListener('error', this.onError);\n        this.websocket.removeEventListener('close', this.onClose);\n        this.websocket = null;\n    }\n\n    /**\n     * WebSocket 'open' event handler. Forwards the event on to listeners.\n     */\n    private onOpen(): void {\n        this.readyState = ReadyState.OPEN;\n        this.emit('open');\n    }\n\n    /**\n     * WebSocket 'message' event handler. Attempts to parse the message and handle it according to the message type.\n     */\n    private onMessage(event: MessageEvent): void {\n        let parsedEventData: WebSocketMessage;\n        let parsedMessagePayload: object;\n        try {\n            parsedEventData = JSON.parse(event.data) as WebSocketMessage;\n        } catch (e) {\n            // For forwards compatibility we ignore messages that are not able to be parsed.\n            // TODO: Consider how to make it easier for users to be aware of dropped messages.\n            return;\n        }\n        try {\n            parsedMessagePayload = SignalingClient.parseJSONObjectFromBase64String(parsedEventData.messagePayload);\n        } catch (e) {\n            // TODO: Consider how to make it easier for users to be aware of dropped messages.\n        }\n        const { messageType, senderClientId, statusResponse } = parsedEventData;\n        if (!parsedMessagePayload && !statusResponse) {\n            // TODO: Consider how to make it easier for users to be aware of dropped messages.\n            return;\n        }\n\n        switch (messageType) {\n            case MessageType.SDP_OFFER:\n                this.emit('sdpOffer', parsedMessagePayload, senderClientId);\n                this.emitPendingIceCandidates(senderClientId);\n                return;\n            case MessageType.SDP_ANSWER:\n                this.emit('sdpAnswer', parsedMessagePayload, senderClientId);\n                this.emitPendingIceCandidates(senderClientId);\n                return;\n            case MessageType.ICE_CANDIDATE:\n                this.emitOrQueueIceCandidate(parsedMessagePayload, senderClientId);\n                return;\n            case MessageType.STATUS_RESPONSE:\n                this.emit('statusResponse', statusResponse);\n                return;\n        }\n    }\n\n    /**\n     * Takes the given base64 encoded string and decodes it into a JSON object.\n     */\n    private static parseJSONObjectFromBase64String(base64EncodedString: string): object {\n        try {\n            return JSON.parse(atob(base64EncodedString));\n        } catch (e) {\n            return JSON.parse(Buffer.from(base64EncodedString, 'base64').toString());\n        }\n    }\n\n    /**\n     * Takes the given JSON object and encodes it into a base64 string.\n     */\n    private static serializeJSONObjectAsBase64String(object: object): string {\n        try {\n            return btoa(JSON.stringify(object));\n        } catch (e) {\n            return Buffer.from(JSON.stringify(object)).toString('base64');\n        }\n    }\n\n    /**\n     * If an SDP offer or answer has already been received from the given client, then the given ICE candidate is emitted. Otherwise, it is queued up for when\n     * an SDP offer or answer is received.\n     */\n    private emitOrQueueIceCandidate(iceCandidate: object, clientId?: string): void {\n        const clientIdKey = clientId || SignalingClient.DEFAULT_CLIENT_ID;\n        if (this.hasReceivedRemoteSDPByClientId[clientIdKey]) {\n            this.emit('iceCandidate', iceCandidate, clientId);\n        } else {\n            if (!this.pendingIceCandidatesByClientId[clientIdKey]) {\n                this.pendingIceCandidatesByClientId[clientIdKey] = [];\n            }\n            this.pendingIceCandidatesByClientId[clientIdKey].push(iceCandidate);\n        }\n    }\n\n    /**\n     * Emits any pending ICE candidates for the given client and records that an SDP offer or answer has been received from the client.\n     */\n    private emitPendingIceCandidates(clientId?: string): void {\n        const clientIdKey = clientId || SignalingClient.DEFAULT_CLIENT_ID;\n        this.hasReceivedRemoteSDPByClientId[clientIdKey] = true;\n        const pendingIceCandidates = this.pendingIceCandidatesByClientId[clientIdKey];\n        if (!pendingIceCandidates) {\n            return;\n        }\n        delete this.pendingIceCandidatesByClientId[clientIdKey];\n        pendingIceCandidates.forEach(iceCandidate => {\n            this.emit('iceCandidate', iceCandidate, clientId);\n        });\n    }\n\n    /**\n     * Throws an error if the recipient client id is null and the current role is 'MASTER' as all messages sent as 'MASTER' should have a recipient client id.\n     */\n    private validateRecipientClientId(recipientClientId?: string): void {\n        if (this.config.role === Role.VIEWER && recipientClientId) {\n            throw new Error('Unexpected recipient client id. As the VIEWER, messages must not be sent with a recipient client id.');\n        }\n    }\n\n    /**\n     * Throws an error if the correlationId does not fit the constraints mentioned in {@link https://docs.aws.amazon.com/kinesisvideostreams-webrtc-dg/latest/devguide/kvswebrtc-websocket-apis4.html the documentation}.\n     */\n    private validateCorrelationId(correlationId?: string): void {\n        if (correlationId && !/^[a-zA-Z0-9_.-]{1,256}$/.test(correlationId)) {\n            throw new Error('Correlation id does not fit the constraint!');\n        }\n    }\n\n    /**\n     * 'error' event handler. Forwards the error onto listeners.\n     */\n    private onError(error: Error | Event): void {\n        this.emit('error', error);\n    }\n\n    /**\n     * 'close' event handler. Forwards the error onto listeners and cleans up the connection.\n     */\n    private onClose(): void {\n        this.readyState = ReadyState.CLOSED;\n        this.cleanupWebSocket();\n        this.emit('close');\n    }\n}\n","/**\n * Provides dates with an offset to account for local clock skew.\n *\n * Unfortunately, WebSockets in the web do not provide any of the connection information needed to determine the clock skew from a failed connection request.\n * Therefore, a hard coded offset is used that is provided from the AWS SDK.\n *\n * See {@link https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Config.html#correctClockSkew-property}\n */\nexport default class DateProvider {\n    private readonly clockOffsetMs: number;\n\n    public constructor(clockOffsetMs: number) {\n        this.clockOffsetMs = clockOffsetMs;\n    }\n\n    /**\n     * Gets the current date with any configured clock offset applied.\n     */\n    public getDate(): Date {\n        return new Date(Date.now() + this.clockOffsetMs);\n    }\n}\n","/**\n * Validates that the given value is not null, undefined, or empty string and throws an error if the condition is not met.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function validateValueNonNil(value: any, valueName: string): void {\n    if (value === null) {\n        throw new Error(`${valueName} cannot be null`);\n    } else if (value === undefined) {\n        throw new Error(`${valueName} cannot be undefined`);\n    } else if (value === '') {\n        throw new Error(`${valueName} cannot be empty`);\n    }\n}\n\n/**\n * Validates that the given value is null, undefined, or empty string and throws an error if the condition is not met.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function validateValueNil(value: any, valueName: string): void {\n    if (value !== null && value !== undefined && value !== '') {\n        throw new Error(`${valueName} should be null`);\n    }\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\n","'use strict';\n\nmodule.exports = function () {\n  throw new Error(\n    'ws does not work in the browser. Browser clients must use the native ' +\n      'WebSocket object'\n  );\n};\n","module.exports = window[\"crypto\"];","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/*!\nAmazon Kinesis Video Streams WebRTC SDK for JavaScript\nCopyright 2019-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n\nThis product includes software developed at\nAmazon Web Services, Inc. (http://aws.amazon.com/).\n*/\nexport { Role } from './Role';\nexport { SignalingClient } from './SignalingClient';\nexport { SigV4RequestSigner } from './SigV4RequestSigner';\nexport { QueryParams } from './QueryParams';\nexport { RequestSigner } from './RequestSigner';\n\nexport const VERSION = process.env.PACKAGE_VERSION;\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/kvs-webrtc.min.js b/kvs-webrtc.min.js index 1d3448b..9dea6db 100644 --- a/kvs-webrtc.min.js +++ b/kvs-webrtc.min.js @@ -1,7 +1,7 @@ -/* Amazon Kinesis Video Streams WebRTC SDK for JavaScript v2.1.0 +/* Amazon Kinesis Video Streams WebRTC SDK for JavaScript v2.2.0 Copyright 2019-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. This product includes software developed at Amazon Web Services, Inc. (http://aws.amazon.com/). -License at kvs-webrtc.LICENSE */(()=>{"use strict";var e={187:e=>{var t,n="object"==typeof Reflect?Reflect:null,r=n&&"function"==typeof n.apply?n.apply:function(e,t,n){return Function.prototype.apply.call(e,t,n)};t=n&&"function"==typeof n.ownKeys?n.ownKeys:Object.getOwnPropertySymbols?function(e){return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e))}:function(e){return Object.getOwnPropertyNames(e)};var i=Number.isNaN||function(e){return e!=e};function o(){o.init.call(this)}e.exports=o,e.exports.once=function(e,t){return new Promise((function(n,r){function i(n){e.removeListener(t,o),r(n)}function o(){"function"==typeof e.removeListener&&e.removeListener("error",i),n([].slice.call(arguments))}v(e,t,o,{once:!0}),"error"!==t&&function(e,t,n){"function"==typeof e.on&&v(e,"error",t,n)}(e,i,{once:!0})}))},o.EventEmitter=o,o.prototype._events=void 0,o.prototype._eventsCount=0,o.prototype._maxListeners=void 0;var s=10;function a(e){if("function"!=typeof e)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof e)}function c(e){return void 0===e._maxListeners?o.defaultMaxListeners:e._maxListeners}function u(e,t,n,r){var i,o,s,u;if(a(n),void 0===(o=e._events)?(o=e._events=Object.create(null),e._eventsCount=0):(void 0!==o.newListener&&(e.emit("newListener",t,n.listener?n.listener:n),o=e._events),s=o[t]),void 0===s)s=o[t]=n,++e._eventsCount;else if("function"==typeof s?s=o[t]=r?[n,s]:[s,n]:r?s.unshift(n):s.push(n),(i=c(e))>0&&s.length>i&&!s.warned){s.warned=!0;var l=new Error("Possible EventEmitter memory leak detected. "+s.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");l.name="MaxListenersExceededWarning",l.emitter=e,l.type=t,l.count=s.length,u=l,console&&console.warn&&console.warn(u)}return e}function l(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function f(e,t,n){var r={fired:!1,wrapFn:void 0,target:e,type:t,listener:n},i=l.bind(r);return i.listener=n,r.wrapFn=i,i}function d(e,t,n){var r=e._events;if(void 0===r)return[];var i=r[t];return void 0===i?[]:"function"==typeof i?n?[i.listener||i]:[i]:n?function(e){for(var t=new Array(e.length),n=0;n0&&(s=t[0]),s instanceof Error)throw s;var a=new Error("Unhandled error."+(s?" ("+s.message+")":""));throw a.context=s,a}var c=o[e];if(void 0===c)return!1;if("function"==typeof c)r(c,this,t);else{var u=c.length,l=p(c,u);for(n=0;n=0;o--)if(n[o]===t||n[o].listener===t){s=n[o].listener,i=o;break}if(i<0)return this;0===i?n.shift():function(e,t){for(;t+1=0;r--)this.removeListener(e,t[r]);return this},o.prototype.listeners=function(e){return d(this,e,!0)},o.prototype.rawListeners=function(e){return d(this,e,!1)},o.listenerCount=function(e,t){return"function"==typeof e.listenerCount?e.listenerCount(t):h.call(e,t)},o.prototype.listenerCount=h,o.prototype.eventNames=function(){return this._eventsCount>0?t(this._events):[]}},14:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},117:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},500:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Role=void 0,function(e){e.MASTER="MASTER",e.VIEWER="VIEWER"}(t.Role||(t.Role={}))},499:(e,t,n)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.SigV4RequestSigner=void 0;var r=n(655),i=r.__importDefault(n(595)),o=n(40),s=function(){function e(t,n,r){void 0===r&&(r=e.DEFAULT_SERVICE),this.region=t,this.credentials=n,this.service=r}return e.prototype.getSignedURL=function(t,n,i){return void 0===i&&(i=new Date),r.__awaiter(this,void 0,Promise,(function(){var s,a,c,u,l,f,d,h,p,v,y,g,m,_,b,S,w,O,E,C,I,N,P;return r.__generator(this,(function(r){switch(r.label){case 0:return"function"!=typeof this.credentials.getPromise?[3,2]:[4,this.credentials.getPromise()];case 1:r.sent(),r.label=2;case 2:if((0,o.validateValueNonNil)(this.credentials.accessKeyId,"credentials.accessKeyId"),(0,o.validateValueNonNil)(this.credentials.secretAccessKey,"credentials.secretAccessKey"),s=e.getDateTimeString(i),a=e.getDateString(i),u="".concat(c="wss","://"),!t.startsWith(u))throw new Error("Endpoint '".concat(t,"' is not a secure WebSocket endpoint. It should start with '").concat(u,"'."));if(t.includes("?"))throw new Error("Endpoint '".concat(t,"' should not contain any query parameters."));return(l=t.indexOf("/",u.length))<0?(f=t.substring(u.length),d="/"):(f=t.substring(u.length,l),d=t.substring(l)),h=["host"].join(";"),p="GET",v=a+"/"+this.region+"/"+this.service+"/aws4_request",y=Object.assign({},n,{"X-Amz-Algorithm":e.DEFAULT_ALGORITHM,"X-Amz-Credential":this.credentials.accessKeyId+"/"+v,"X-Amz-Date":s,"X-Amz-Expires":"299","X-Amz-SignedHeaders":h}),this.credentials.sessionToken&&Object.assign(y,{"X-Amz-Security-Token":this.credentials.sessionToken}),g=e.createQueryString(y),m={host:f},_=e.createHeadersString(m),[4,e.sha256("")];case 3:return b=r.sent(),S=[p,d,g,_,h,b].join("\n"),[4,e.sha256(S)];case 4:return w=r.sent(),O=[e.DEFAULT_ALGORITHM,s,v,w].join("\n"),[4,this.getSignatureKey(a)];case 5:return E=r.sent(),N=(I=e).toHex,[4,e.hmac(E,O)];case 6:return[4,N.apply(I,[r.sent()])];case 7:return C=r.sent(),P=Object.assign({},y,{"X-Amz-Signature":C}),[2,c+"://"+f+d+"?"+e.createQueryString(P)]}}))}))},e.prototype.getSignatureKey=function(t){return r.__awaiter(this,void 0,Promise,(function(){var n,i,o;return r.__generator(this,(function(r){switch(r.label){case 0:return[4,e.hmac("AWS4"+this.credentials.secretAccessKey,t)];case 1:return n=r.sent(),[4,e.hmac(n,this.region)];case 2:return i=r.sent(),[4,e.hmac(i,this.service)];case 3:return o=r.sent(),[4,e.hmac(o,"aws4_request")];case 4:return[2,r.sent()]}}))}))},e.createHeadersString=function(e){return Object.keys(e).map((function(t){return"".concat(t,":").concat(e[t],"\n")})).join()},e.createQueryString=function(e){return Object.keys(e).sort().map((function(t){return"".concat(t,"=").concat(encodeURIComponent(e[t]))})).join("&")},e.getDateTimeString=function(e){return e.toISOString().replace(/\.\d{3}Z$/,"Z").replace(/[:\-]/g,"")},e.getDateString=function(e){return this.getDateTimeString(e).substring(0,8)},e.sha256=function(e){return r.__awaiter(this,void 0,Promise,(function(){var t;return r.__generator(this,(function(n){switch(n.label){case 0:return[4,i.default.subtle.digest({name:"SHA-256"},this.toUint8Array(e))];case 1:return t=n.sent(),[2,this.toHex(t)]}}))}))},e.hmac=function(e,t){return r.__awaiter(this,void 0,Promise,(function(){var n,o,s;return r.__generator(this,(function(r){switch(r.label){case 0:return n="string"==typeof e?this.toUint8Array(e).buffer:e,o=this.toUint8Array(t).buffer,[4,i.default.subtle.importKey("raw",n,{name:"HMAC",hash:{name:"SHA-256"}},!1,["sign"])];case 1:return s=r.sent(),[4,i.default.subtle.sign({name:"HMAC",hash:{name:"SHA-256"}},s,o)];case 2:return[2,r.sent()]}}))}))},e.toUint8Array=function(e){for(var t=new ArrayBuffer(e.length),n=new Uint8Array(t),r=0,i=e.length;r{Object.defineProperty(t,"__esModule",{value:!0}),t.SignalingClient=void 0;var r,i,o=n(655),s=n(187),a=n(500),c=n(499),u=o.__importDefault(n(540)),l=n(40);!function(e){e.SDP_ANSWER="SDP_ANSWER",e.SDP_OFFER="SDP_OFFER",e.ICE_CANDIDATE="ICE_CANDIDATE"}(r||(r={})),function(e){e[e.CONNECTING=0]="CONNECTING",e[e.OPEN=1]="OPEN",e[e.CLOSING=2]="CLOSING",e[e.CLOSED=3]="CLOSED"}(i||(i={}));var f=function(e){function t(t){var n=e.call(this)||this;return n.websocket=null,n.readyState=i.CLOSED,n.pendingIceCandidatesByClientId={},n.hasReceivedRemoteSDPByClientId={},(0,l.validateValueNonNil)(t,"SignalingClientConfig"),(0,l.validateValueNonNil)(t.role,"role"),t.role===a.Role.VIEWER?(0,l.validateValueNonNil)(t.clientId,"clientId"):(0,l.validateValueNil)(t.clientId,"clientId"),(0,l.validateValueNonNil)(t.channelARN,"channelARN"),(0,l.validateValueNonNil)(t.region,"region"),(0,l.validateValueNonNil)(t.channelEndpoint,"channelEndpoint"),n.config=o.__assign({},t),t.requestSigner?n.requestSigner=t.requestSigner:((0,l.validateValueNonNil)(t.credentials,"credentials"),n.requestSigner=new c.SigV4RequestSigner(t.region,t.credentials)),n.dateProvider=new u.default(t.systemClockOffset||0),n.onOpen=n.onOpen.bind(n),n.onMessage=n.onMessage.bind(n),n.onError=n.onError.bind(n),n.onClose=n.onClose.bind(n),n}return o.__extends(t,e),t.prototype.open=function(){var e=this;if(this.readyState!==i.CLOSED)throw new Error("Client is already open, opening, or closing");this.readyState=i.CONNECTING,this.asyncOpen().then().catch((function(t){return e.onError(t)}))},t.prototype.asyncOpen=function(){return o.__awaiter(this,void 0,Promise,(function(){var e,t;return o.__generator(this,(function(n){switch(n.label){case 0:return e={"X-Amz-ChannelARN":this.config.channelARN},this.config.role===a.Role.VIEWER&&(e["X-Amz-ClientId"]=this.config.clientId),[4,this.requestSigner.getSignedURL(this.config.channelEndpoint,e,this.dateProvider.getDate())];case 1:return t=n.sent(),this.readyState!==i.CONNECTING?[2]:(this.websocket=new WebSocket(t),this.websocket.addEventListener("open",this.onOpen),this.websocket.addEventListener("message",this.onMessage),this.websocket.addEventListener("error",this.onError),this.websocket.addEventListener("close",this.onClose),[2])}}))}))},t.prototype.close=function(){null!==this.websocket?(this.readyState=i.CLOSING,this.websocket.close()):this.readyState!==i.CLOSED&&this.onClose()},t.prototype.sendSdpOffer=function(e,t){this.sendMessage(r.SDP_OFFER,e.toJSON(),t)},t.prototype.sendSdpAnswer=function(e,t){this.sendMessage(r.SDP_ANSWER,e.toJSON(),t)},t.prototype.sendIceCandidate=function(e,t){this.sendMessage(r.ICE_CANDIDATE,e.toJSON(),t)},t.prototype.sendMessage=function(e,n,r){if(this.readyState!==i.OPEN)throw new Error("Could not send message because the connection to the signaling service is not open.");this.validateRecipientClientId(r),this.websocket.send(JSON.stringify({action:e,messagePayload:t.serializeJSONObjectAsBase64String(n),recipientClientId:r||void 0}))},t.prototype.cleanupWebSocket=function(){null!==this.websocket&&(this.websocket.removeEventListener("open",this.onOpen),this.websocket.removeEventListener("message",this.onMessage),this.websocket.removeEventListener("error",this.onError),this.websocket.removeEventListener("close",this.onClose),this.websocket=null)},t.prototype.onOpen=function(){this.readyState=i.OPEN,this.emit("open")},t.prototype.onMessage=function(e){var n,i;try{n=JSON.parse(e.data),i=t.parseJSONObjectFromBase64String(n.messagePayload)}catch(e){return}var o=n.messageType,s=n.senderClientId;switch(o){case r.SDP_OFFER:return this.emit("sdpOffer",i,s),void this.emitPendingIceCandidates(s);case r.SDP_ANSWER:return this.emit("sdpAnswer",i,s),void this.emitPendingIceCandidates(s);case r.ICE_CANDIDATE:return void this.emitOrQueueIceCandidate(i,s)}},t.parseJSONObjectFromBase64String=function(e){return JSON.parse(atob(e))},t.serializeJSONObjectAsBase64String=function(e){return btoa(JSON.stringify(e))},t.prototype.emitOrQueueIceCandidate=function(e,n){var r=n||t.DEFAULT_CLIENT_ID;this.hasReceivedRemoteSDPByClientId[r]?this.emit("iceCandidate",e,n):(this.pendingIceCandidatesByClientId[r]||(this.pendingIceCandidatesByClientId[r]=[]),this.pendingIceCandidatesByClientId[r].push(e))},t.prototype.emitPendingIceCandidates=function(e){var n=this,r=e||t.DEFAULT_CLIENT_ID;this.hasReceivedRemoteSDPByClientId[r]=!0;var i=this.pendingIceCandidatesByClientId[r];i&&(delete this.pendingIceCandidatesByClientId[r],i.forEach((function(t){n.emit("iceCandidate",t,e)})))},t.prototype.validateRecipientClientId=function(e){if(this.config.role===a.Role.VIEWER&&e)throw new Error("Unexpected recipient client id. As the VIEWER, messages must not be sent with a recipient client id.")},t.prototype.onError=function(e){this.emit("error",e)},t.prototype.onClose=function(){this.readyState=i.CLOSED,this.cleanupWebSocket(),this.emit("close")},t.DEFAULT_CLIENT_ID="MASTER",t}(s.EventEmitter);t.SignalingClient=f},540:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0});var n=function(){function e(e){this.clockOffsetMs=e}return e.prototype.getDate=function(){return new Date(Date.now()+this.clockOffsetMs)},e}();t.default=n},40:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.validateValueNil=t.validateValueNonNil=void 0,t.validateValueNonNil=function(e,t){if(null===e)throw new Error("".concat(t," cannot be null"));if(void 0===e)throw new Error("".concat(t," cannot be undefined"));if(""===e)throw new Error("".concat(t," cannot be empty"))},t.validateValueNil=function(e,t){if(null!=e&&""!==e)throw new Error("".concat(t," should be null"))}},655:(e,t,n)=>{n.r(t),n.d(t,{__assign:()=>o,__asyncDelegator:()=>b,__asyncGenerator:()=>_,__asyncValues:()=>S,__await:()=>m,__awaiter:()=>l,__classPrivateFieldGet:()=>C,__classPrivateFieldSet:()=>I,__createBinding:()=>d,__decorate:()=>a,__exportStar:()=>h,__extends:()=>i,__generator:()=>f,__importDefault:()=>E,__importStar:()=>O,__makeTemplateObject:()=>w,__metadata:()=>u,__param:()=>c,__read:()=>v,__rest:()=>s,__spread:()=>y,__spreadArrays:()=>g,__values:()=>p});var r=function(e,t){return r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])},r(e,t)};function i(e,t){function n(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var o=function(){return o=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=0;a--)(i=e[a])&&(s=(o<3?i(s):o>3?i(t,n,s):i(t,n))||s);return o>3&&s&&Object.defineProperty(t,n,s),s}function c(e,t){return function(n,r){t(n,r,e)}}function u(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function l(e,t,n,r){return new(n||(n=Promise))((function(i,o){function s(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?i(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(s,a)}c((r=r.apply(e,t||[])).next())}))}function f(e,t){var n,r,i,o,s={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return o={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function a(o){return function(a){return function(o){if(n)throw new TypeError("Generator is already executing.");for(;s;)try{if(n=1,r&&(i=2&o[0]?r.return:o[0]?r.throw||((i=r.return)&&i.call(r),0):r.next)&&!(i=i.call(r,o[1])).done)return i;switch(r=0,i&&(o=[2&o[0],i.value]),o[0]){case 0:case 1:i=o;break;case 4:return s.label++,{value:o[1],done:!1};case 5:s.label++,r=o[1],o=[0];continue;case 7:o=s.ops.pop(),s.trys.pop();continue;default:if(!(i=s.trys,(i=i.length>0&&i[i.length-1])||6!==o[0]&&2!==o[0])){s=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function v(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,i,o=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=o.next()).done;)s.push(r.value)}catch(e){i={error:e}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(i)throw i.error}}return s}function y(){for(var e=[],t=0;t1||a(e,t)}))})}function a(e,t){try{(n=i[e](t)).value instanceof m?Promise.resolve(n.value.v).then(c,u):l(o[0][2],n)}catch(e){l(o[0][3],e)}var n}function c(e){a("next",e)}function u(e){a("throw",e)}function l(e,t){e(t),o.shift(),o.length&&a(o[0][0],o[0][1])}}function b(e){var t,n;return t={},r("next"),r("throw",(function(e){throw e})),r("return"),t[Symbol.iterator]=function(){return this},t;function r(r,i){t[r]=e[r]?function(t){return(n=!n)?{value:m(e[r](t)),done:"return"===r}:i?i(t):t}:i}}function S(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t,n=e[Symbol.asyncIterator];return n?n.call(e):(e=p(e),t={},r("next"),r("throw"),r("return"),t[Symbol.asyncIterator]=function(){return this},t);function r(n){t[n]=e[n]&&function(t){return new Promise((function(r,i){(function(e,t,n,r){Promise.resolve(r).then((function(t){e({value:t,done:n})}),t)})(r,i,(t=e[n](t)).done,t.value)}))}}}function w(e,t){return Object.defineProperty?Object.defineProperty(e,"raw",{value:t}):e.raw=t,e}function O(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)Object.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t.default=e,t}function E(e){return e&&e.__esModule?e:{default:e}}function C(e,t){if(!t.has(e))throw new TypeError("attempted to get private field on non-instance");return t.get(e)}function I(e,t,n){if(!t.has(e))throw new TypeError("attempted to set private field on non-instance");return t.set(e,n),n}},595:e=>{e.exports=window.crypto}},t={};function n(r){var i=t[r];if(void 0!==i)return i.exports;var o=t[r]={exports:{}};return e[r](o,o.exports,n),o.exports}n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var r={};(()=>{var e=r;Object.defineProperty(e,"__esModule",{value:!0}),e.VERSION=e.RequestSigner=e.QueryParams=e.SigV4RequestSigner=e.SignalingClient=e.Role=void 0;var t=n(500);Object.defineProperty(e,"Role",{enumerable:!0,get:function(){return t.Role}});var i=n(963);Object.defineProperty(e,"SignalingClient",{enumerable:!0,get:function(){return i.SignalingClient}});var o=n(499);Object.defineProperty(e,"SigV4RequestSigner",{enumerable:!0,get:function(){return o.SigV4RequestSigner}});var s=n(14);Object.defineProperty(e,"QueryParams",{enumerable:!0,get:function(){return s.QueryParams}});var a=n(117);Object.defineProperty(e,"RequestSigner",{enumerable:!0,get:function(){return a.RequestSigner}}),e.VERSION="2.1.0"})(),window.KVSWebRTC=r})(); \ No newline at end of file +License at kvs-webrtc.LICENSE */(()=>{"use strict";var e={187:e=>{var t,n="object"==typeof Reflect?Reflect:null,r=n&&"function"==typeof n.apply?n.apply:function(e,t,n){return Function.prototype.apply.call(e,t,n)};t=n&&"function"==typeof n.ownKeys?n.ownKeys:Object.getOwnPropertySymbols?function(e){return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e))}:function(e){return Object.getOwnPropertyNames(e)};var i=Number.isNaN||function(e){return e!=e};function o(){o.init.call(this)}e.exports=o,e.exports.once=function(e,t){return new Promise((function(n,r){function i(n){e.removeListener(t,o),r(n)}function o(){"function"==typeof e.removeListener&&e.removeListener("error",i),n([].slice.call(arguments))}v(e,t,o,{once:!0}),"error"!==t&&function(e,t,n){"function"==typeof e.on&&v(e,"error",t,n)}(e,i,{once:!0})}))},o.EventEmitter=o,o.prototype._events=void 0,o.prototype._eventsCount=0,o.prototype._maxListeners=void 0;var s=10;function a(e){if("function"!=typeof e)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof e)}function c(e){return void 0===e._maxListeners?o.defaultMaxListeners:e._maxListeners}function u(e,t,n,r){var i,o,s,u;if(a(n),void 0===(o=e._events)?(o=e._events=Object.create(null),e._eventsCount=0):(void 0!==o.newListener&&(e.emit("newListener",t,n.listener?n.listener:n),o=e._events),s=o[t]),void 0===s)s=o[t]=n,++e._eventsCount;else if("function"==typeof s?s=o[t]=r?[n,s]:[s,n]:r?s.unshift(n):s.push(n),(i=c(e))>0&&s.length>i&&!s.warned){s.warned=!0;var l=new Error("Possible EventEmitter memory leak detected. "+s.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");l.name="MaxListenersExceededWarning",l.emitter=e,l.type=t,l.count=s.length,u=l,console&&console.warn&&console.warn(u)}return e}function l(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function f(e,t,n){var r={fired:!1,wrapFn:void 0,target:e,type:t,listener:n},i=l.bind(r);return i.listener=n,r.wrapFn=i,i}function d(e,t,n){var r=e._events;if(void 0===r)return[];var i=r[t];return void 0===i?[]:"function"==typeof i?n?[i.listener||i]:[i]:n?function(e){for(var t=new Array(e.length),n=0;n0&&(s=t[0]),s instanceof Error)throw s;var a=new Error("Unhandled error."+(s?" ("+s.message+")":""));throw a.context=s,a}var c=o[e];if(void 0===c)return!1;if("function"==typeof c)r(c,this,t);else{var u=c.length,l=p(c,u);for(n=0;n=0;o--)if(n[o]===t||n[o].listener===t){s=n[o].listener,i=o;break}if(i<0)return this;0===i?n.shift():function(e,t){for(;t+1=0;r--)this.removeListener(e,t[r]);return this},o.prototype.listeners=function(e){return d(this,e,!0)},o.prototype.rawListeners=function(e){return d(this,e,!1)},o.listenerCount=function(e,t){return"function"==typeof e.listenerCount?e.listenerCount(t):h.call(e,t)},o.prototype.listenerCount=h,o.prototype.eventNames=function(){return this._eventsCount>0?t(this._events):[]}},14:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},117:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},500:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Role=void 0,function(e){e.MASTER="MASTER",e.VIEWER="VIEWER"}(t.Role||(t.Role={}))},499:(e,t,n)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.SigV4RequestSigner=void 0;var r=n(655),i=r.__importDefault(n(595)),o=n(40),s=function(){function e(t,n,r){void 0===r&&(r=e.DEFAULT_SERVICE),this.region=t,this.credentials=n,this.service=r}return e.prototype.getSignedURL=function(t,n,i){return void 0===i&&(i=new Date),r.__awaiter(this,void 0,Promise,(function(){var s,a,c,u,l,f,d,h,p,v,y,g,m,b,_,S,w,E,O,C,I,N,P;return r.__generator(this,(function(r){switch(r.label){case 0:return"function"!=typeof this.credentials.getPromise?[3,2]:[4,this.credentials.getPromise()];case 1:r.sent(),r.label=2;case 2:if((0,o.validateValueNonNil)(this.credentials.accessKeyId,"credentials.accessKeyId"),(0,o.validateValueNonNil)(this.credentials.secretAccessKey,"credentials.secretAccessKey"),s=e.getDateTimeString(i),a=e.getDateString(i),u="".concat(c="wss","://"),!t.startsWith(u))throw new Error("Endpoint '".concat(t,"' is not a secure WebSocket endpoint. It should start with '").concat(u,"'."));if(t.includes("?"))throw new Error("Endpoint '".concat(t,"' should not contain any query parameters."));return(l=t.indexOf("/",u.length))<0?(f=t.substring(u.length),d="/"):(f=t.substring(u.length,l),d=t.substring(l)),h=["host"].join(";"),p="GET",v=a+"/"+this.region+"/"+this.service+"/aws4_request",y=Object.assign({},n,{"X-Amz-Algorithm":e.DEFAULT_ALGORITHM,"X-Amz-Credential":this.credentials.accessKeyId+"/"+v,"X-Amz-Date":s,"X-Amz-Expires":"299","X-Amz-SignedHeaders":h}),this.credentials.sessionToken&&Object.assign(y,{"X-Amz-Security-Token":this.credentials.sessionToken}),g=e.createQueryString(y),m={host:f},b=e.createHeadersString(m),[4,e.sha256("")];case 3:return _=r.sent(),S=[p,d,g,b,h,_].join("\n"),[4,e.sha256(S)];case 4:return w=r.sent(),E=[e.DEFAULT_ALGORITHM,s,v,w].join("\n"),[4,this.getSignatureKey(a)];case 5:return O=r.sent(),N=(I=e).toHex,[4,e.hmac(O,E)];case 6:return[4,N.apply(I,[r.sent()])];case 7:return C=r.sent(),P=Object.assign({},y,{"X-Amz-Signature":C}),[2,c+"://"+f+d+"?"+e.createQueryString(P)]}}))}))},e.prototype.getSignatureKey=function(t){return r.__awaiter(this,void 0,Promise,(function(){var n,i,o;return r.__generator(this,(function(r){switch(r.label){case 0:return[4,e.hmac("AWS4"+this.credentials.secretAccessKey,t)];case 1:return n=r.sent(),[4,e.hmac(n,this.region)];case 2:return i=r.sent(),[4,e.hmac(i,this.service)];case 3:return o=r.sent(),[4,e.hmac(o,"aws4_request")];case 4:return[2,r.sent()]}}))}))},e.createHeadersString=function(e){return Object.keys(e).map((function(t){return"".concat(t,":").concat(e[t],"\n")})).join()},e.createQueryString=function(e){return Object.keys(e).sort().map((function(t){return"".concat(t,"=").concat(encodeURIComponent(e[t]))})).join("&")},e.getDateTimeString=function(e){return e.toISOString().replace(/\.\d{3}Z$/,"Z").replace(/[:\-]/g,"")},e.getDateString=function(e){return this.getDateTimeString(e).substring(0,8)},e.sha256=function(e){return r.__awaiter(this,void 0,Promise,(function(){var t;return r.__generator(this,(function(n){switch(n.label){case 0:return[4,i.default.subtle.digest({name:"SHA-256"},this.toUint8Array(e))];case 1:return t=n.sent(),[2,this.toHex(t)]}}))}))},e.hmac=function(e,t){return r.__awaiter(this,void 0,Promise,(function(){var n,o,s;return r.__generator(this,(function(r){switch(r.label){case 0:return n="string"==typeof e?this.toUint8Array(e).buffer:e,o=this.toUint8Array(t).buffer,[4,i.default.subtle.importKey("raw",n,{name:"HMAC",hash:{name:"SHA-256"}},!1,["sign"])];case 1:return s=r.sent(),[4,i.default.subtle.sign({name:"HMAC",hash:{name:"SHA-256"}},s,o)];case 2:return[2,r.sent()]}}))}))},e.toUint8Array=function(e){for(var t=new ArrayBuffer(e.length),n=new Uint8Array(t),r=0,i=e.length;r{Object.defineProperty(t,"__esModule",{value:!0}),t.SignalingClient=void 0;var r,i,o=n(655),s=n(187),a=n(500),c=n(499),u=o.__importDefault(n(540)),l=n(40);!function(e){e.SDP_ANSWER="SDP_ANSWER",e.SDP_OFFER="SDP_OFFER",e.ICE_CANDIDATE="ICE_CANDIDATE",e.STATUS_RESPONSE="STATUS_RESPONSE"}(r||(r={})),function(e){e[e.CONNECTING=0]="CONNECTING",e[e.OPEN=1]="OPEN",e[e.CLOSING=2]="CLOSING",e[e.CLOSED=3]="CLOSED"}(i||(i={}));var f=function(e){function t(t){var n=e.call(this)||this;return n.websocket=null,n.readyState=i.CLOSED,n.pendingIceCandidatesByClientId={},n.hasReceivedRemoteSDPByClientId={},(0,l.validateValueNonNil)(t,"SignalingClientConfig"),(0,l.validateValueNonNil)(t.role,"role"),t.role===a.Role.VIEWER?(0,l.validateValueNonNil)(t.clientId,"clientId"):(0,l.validateValueNil)(t.clientId,"clientId"),(0,l.validateValueNonNil)(t.channelARN,"channelARN"),(0,l.validateValueNonNil)(t.region,"region"),(0,l.validateValueNonNil)(t.channelEndpoint,"channelEndpoint"),n.config=o.__assign({},t),t.requestSigner?n.requestSigner=t.requestSigner:((0,l.validateValueNonNil)(t.credentials,"credentials"),n.requestSigner=new c.SigV4RequestSigner(t.region,t.credentials)),n.dateProvider=new u.default(t.systemClockOffset||0),n.onOpen=n.onOpen.bind(n),n.onMessage=n.onMessage.bind(n),n.onError=n.onError.bind(n),n.onClose=n.onClose.bind(n),n}return o.__extends(t,e),t.prototype.open=function(){var e=this;if(this.readyState!==i.CLOSED)throw new Error("Client is already open, opening, or closing");this.readyState=i.CONNECTING,this.asyncOpen().then().catch((function(t){return e.onError(t)}))},t.prototype.asyncOpen=function(){return o.__awaiter(this,void 0,Promise,(function(){var e,t;return o.__generator(this,(function(r){switch(r.label){case 0:return e={"X-Amz-ChannelARN":this.config.channelARN},this.config.role===a.Role.VIEWER&&(e["X-Amz-ClientId"]=this.config.clientId),[4,this.requestSigner.getSignedURL(this.config.channelEndpoint,e,this.dateProvider.getDate())];case 1:return t=r.sent(),this.readyState!==i.CONNECTING?[2]:(this.websocket=new(n.g.WebSocket||n(26))(t),this.websocket.addEventListener("open",this.onOpen),this.websocket.addEventListener("message",this.onMessage),this.websocket.addEventListener("error",this.onError),this.websocket.addEventListener("close",this.onClose),[2])}}))}))},t.prototype.close=function(){null!==this.websocket?(this.readyState=i.CLOSING,this.websocket.close()):this.readyState!==i.CLOSED&&this.onClose()},t.prototype.sendSdpOffer=function(e,t,n){this.sendMessage(r.SDP_OFFER,e,t,n)},t.prototype.sendSdpAnswer=function(e,t,n){this.sendMessage(r.SDP_ANSWER,e,t,n)},t.prototype.sendIceCandidate=function(e,t,n){this.sendMessage(r.ICE_CANDIDATE,e,t,n)},t.prototype.sendMessage=function(e,n,r,o){if(this.readyState!==i.OPEN)throw new Error("Could not send message because the connection to the signaling service is not open.");this.validateRecipientClientId(r),this.validateCorrelationId(o),this.websocket.send(JSON.stringify({action:e,messagePayload:t.serializeJSONObjectAsBase64String(n),recipientClientId:r||void 0,correlationId:o||void 0}))},t.prototype.cleanupWebSocket=function(){null!==this.websocket&&(this.websocket.removeEventListener("open",this.onOpen),this.websocket.removeEventListener("message",this.onMessage),this.websocket.removeEventListener("error",this.onError),this.websocket.removeEventListener("close",this.onClose),this.websocket=null)},t.prototype.onOpen=function(){this.readyState=i.OPEN,this.emit("open")},t.prototype.onMessage=function(e){var n,i;try{n=JSON.parse(e.data)}catch(e){return}try{i=t.parseJSONObjectFromBase64String(n.messagePayload)}catch(e){}var o=n.messageType,s=n.senderClientId,a=n.statusResponse;if(i||a)switch(o){case r.SDP_OFFER:return this.emit("sdpOffer",i,s),void this.emitPendingIceCandidates(s);case r.SDP_ANSWER:return this.emit("sdpAnswer",i,s),void this.emitPendingIceCandidates(s);case r.ICE_CANDIDATE:return void this.emitOrQueueIceCandidate(i,s);case r.STATUS_RESPONSE:return void this.emit("statusResponse",a)}},t.parseJSONObjectFromBase64String=function(e){try{return JSON.parse(atob(e))}catch(t){return JSON.parse(Buffer.from(e,"base64").toString())}},t.serializeJSONObjectAsBase64String=function(e){try{return btoa(JSON.stringify(e))}catch(t){return Buffer.from(JSON.stringify(e)).toString("base64")}},t.prototype.emitOrQueueIceCandidate=function(e,n){var r=n||t.DEFAULT_CLIENT_ID;this.hasReceivedRemoteSDPByClientId[r]?this.emit("iceCandidate",e,n):(this.pendingIceCandidatesByClientId[r]||(this.pendingIceCandidatesByClientId[r]=[]),this.pendingIceCandidatesByClientId[r].push(e))},t.prototype.emitPendingIceCandidates=function(e){var n=this,r=e||t.DEFAULT_CLIENT_ID;this.hasReceivedRemoteSDPByClientId[r]=!0;var i=this.pendingIceCandidatesByClientId[r];i&&(delete this.pendingIceCandidatesByClientId[r],i.forEach((function(t){n.emit("iceCandidate",t,e)})))},t.prototype.validateRecipientClientId=function(e){if(this.config.role===a.Role.VIEWER&&e)throw new Error("Unexpected recipient client id. As the VIEWER, messages must not be sent with a recipient client id.")},t.prototype.validateCorrelationId=function(e){if(e&&!/^[a-zA-Z0-9_.-]{1,256}$/.test(e))throw new Error("Correlation id does not fit the constraint!")},t.prototype.onError=function(e){this.emit("error",e)},t.prototype.onClose=function(){this.readyState=i.CLOSED,this.cleanupWebSocket(),this.emit("close")},t.DEFAULT_CLIENT_ID="MASTER",t}(s.EventEmitter);t.SignalingClient=f},540:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0});var n=function(){function e(e){this.clockOffsetMs=e}return e.prototype.getDate=function(){return new Date(Date.now()+this.clockOffsetMs)},e}();t.default=n},40:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.validateValueNil=t.validateValueNonNil=void 0,t.validateValueNonNil=function(e,t){if(null===e)throw new Error("".concat(t," cannot be null"));if(void 0===e)throw new Error("".concat(t," cannot be undefined"));if(""===e)throw new Error("".concat(t," cannot be empty"))},t.validateValueNil=function(e,t){if(null!=e&&""!==e)throw new Error("".concat(t," should be null"))}},655:(e,t,n)=>{n.r(t),n.d(t,{__assign:()=>o,__asyncDelegator:()=>_,__asyncGenerator:()=>b,__asyncValues:()=>S,__await:()=>m,__awaiter:()=>l,__classPrivateFieldGet:()=>C,__classPrivateFieldSet:()=>I,__createBinding:()=>d,__decorate:()=>a,__exportStar:()=>h,__extends:()=>i,__generator:()=>f,__importDefault:()=>O,__importStar:()=>E,__makeTemplateObject:()=>w,__metadata:()=>u,__param:()=>c,__read:()=>v,__rest:()=>s,__spread:()=>y,__spreadArrays:()=>g,__values:()=>p});var r=function(e,t){return r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])},r(e,t)};function i(e,t){function n(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var o=function(){return o=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=0;a--)(i=e[a])&&(s=(o<3?i(s):o>3?i(t,n,s):i(t,n))||s);return o>3&&s&&Object.defineProperty(t,n,s),s}function c(e,t){return function(n,r){t(n,r,e)}}function u(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function l(e,t,n,r){return new(n||(n=Promise))((function(i,o){function s(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?i(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(s,a)}c((r=r.apply(e,t||[])).next())}))}function f(e,t){var n,r,i,o,s={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return o={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function a(o){return function(a){return function(o){if(n)throw new TypeError("Generator is already executing.");for(;s;)try{if(n=1,r&&(i=2&o[0]?r.return:o[0]?r.throw||((i=r.return)&&i.call(r),0):r.next)&&!(i=i.call(r,o[1])).done)return i;switch(r=0,i&&(o=[2&o[0],i.value]),o[0]){case 0:case 1:i=o;break;case 4:return s.label++,{value:o[1],done:!1};case 5:s.label++,r=o[1],o=[0];continue;case 7:o=s.ops.pop(),s.trys.pop();continue;default:if(!(i=s.trys,(i=i.length>0&&i[i.length-1])||6!==o[0]&&2!==o[0])){s=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function v(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,i,o=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=o.next()).done;)s.push(r.value)}catch(e){i={error:e}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(i)throw i.error}}return s}function y(){for(var e=[],t=0;t1||a(e,t)}))})}function a(e,t){try{(n=i[e](t)).value instanceof m?Promise.resolve(n.value.v).then(c,u):l(o[0][2],n)}catch(e){l(o[0][3],e)}var n}function c(e){a("next",e)}function u(e){a("throw",e)}function l(e,t){e(t),o.shift(),o.length&&a(o[0][0],o[0][1])}}function _(e){var t,n;return t={},r("next"),r("throw",(function(e){throw e})),r("return"),t[Symbol.iterator]=function(){return this},t;function r(r,i){t[r]=e[r]?function(t){return(n=!n)?{value:m(e[r](t)),done:"return"===r}:i?i(t):t}:i}}function S(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t,n=e[Symbol.asyncIterator];return n?n.call(e):(e=p(e),t={},r("next"),r("throw"),r("return"),t[Symbol.asyncIterator]=function(){return this},t);function r(n){t[n]=e[n]&&function(t){return new Promise((function(r,i){(function(e,t,n,r){Promise.resolve(r).then((function(t){e({value:t,done:n})}),t)})(r,i,(t=e[n](t)).done,t.value)}))}}}function w(e,t){return Object.defineProperty?Object.defineProperty(e,"raw",{value:t}):e.raw=t,e}function E(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)Object.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t.default=e,t}function O(e){return e&&e.__esModule?e:{default:e}}function C(e,t){if(!t.has(e))throw new TypeError("attempted to get private field on non-instance");return t.get(e)}function I(e,t,n){if(!t.has(e))throw new TypeError("attempted to set private field on non-instance");return t.set(e,n),n}},26:e=>{e.exports=function(){throw new Error("ws does not work in the browser. Browser clients must use the native WebSocket object")}},595:e=>{e.exports=window.crypto}},t={};function n(r){var i=t[r];if(void 0!==i)return i.exports;var o=t[r]={exports:{}};return e[r](o,o.exports,n),o.exports}n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var r={};(()=>{var e=r;Object.defineProperty(e,"__esModule",{value:!0}),e.VERSION=e.RequestSigner=e.QueryParams=e.SigV4RequestSigner=e.SignalingClient=e.Role=void 0;var t=n(500);Object.defineProperty(e,"Role",{enumerable:!0,get:function(){return t.Role}});var i=n(963);Object.defineProperty(e,"SignalingClient",{enumerable:!0,get:function(){return i.SignalingClient}});var o=n(499);Object.defineProperty(e,"SigV4RequestSigner",{enumerable:!0,get:function(){return o.SigV4RequestSigner}});var s=n(14);Object.defineProperty(e,"QueryParams",{enumerable:!0,get:function(){return s.QueryParams}});var a=n(117);Object.defineProperty(e,"RequestSigner",{enumerable:!0,get:function(){return a.RequestSigner}}),e.VERSION="2.2.0"})(),window.KVSWebRTC=r})(); \ No newline at end of file