@yang__yj/pixelstreaming-core 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cspell.json +48 -0
- package/.eslintignore +8 -0
- package/.eslintrc.js +8 -0
- package/.prettierignore +0 -0
- package/.prettierrc.json +6 -0
- package/coverage/clover.xml +3480 -0
- package/coverage/coverage-final.json +62 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +356 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov-report/src/AFK/AFKController.ts.html +559 -0
- package/coverage/lcov-report/src/AFK/index.html +116 -0
- package/coverage/lcov-report/src/Config/Config.ts.html +2764 -0
- package/coverage/lcov-report/src/Config/SettingBase.ts.html +280 -0
- package/coverage/lcov-report/src/Config/SettingFlag.ts.html +382 -0
- package/coverage/lcov-report/src/Config/SettingNumber.ts.html +418 -0
- package/coverage/lcov-report/src/Config/SettingOption.ts.html +424 -0
- package/coverage/lcov-report/src/Config/SettingText.ts.html +331 -0
- package/coverage/lcov-report/src/Config/index.html +191 -0
- package/coverage/lcov-report/src/DataChannel/DataChannelController.ts.html +499 -0
- package/coverage/lcov-report/src/DataChannel/DataChannelSender.ts.html +262 -0
- package/coverage/lcov-report/src/DataChannel/InitialSettings.ts.html +268 -0
- package/coverage/lcov-report/src/DataChannel/LatencyTestResults.ts.html +313 -0
- package/coverage/lcov-report/src/DataChannel/index.html +161 -0
- package/coverage/lcov-report/src/FreezeFrame/FreezeFrame.ts.html +427 -0
- package/coverage/lcov-report/src/FreezeFrame/FreezeFrameController.ts.html +427 -0
- package/coverage/lcov-report/src/FreezeFrame/index.html +131 -0
- package/coverage/lcov-report/src/Inputs/FakeTouchController.ts.html +682 -0
- package/coverage/lcov-report/src/Inputs/GamepadController.ts.html +985 -0
- package/coverage/lcov-report/src/Inputs/HoveringMouseEvents.ts.html +688 -0
- package/coverage/lcov-report/src/Inputs/InputClassesFactory.ts.html +505 -0
- package/coverage/lcov-report/src/Inputs/KeyboardController.ts.html +1048 -0
- package/coverage/lcov-report/src/Inputs/LockedMouseEvents.ts.html +946 -0
- package/coverage/lcov-report/src/Inputs/MouseButtons.ts.html +160 -0
- package/coverage/lcov-report/src/Inputs/MouseController.ts.html +1171 -0
- package/coverage/lcov-report/src/Inputs/SpecialKeyCodes.ts.html +133 -0
- package/coverage/lcov-report/src/Inputs/TouchController.ts.html +712 -0
- package/coverage/lcov-report/src/Inputs/XRGamepadController.ts.html +463 -0
- package/coverage/lcov-report/src/Inputs/index.html +266 -0
- package/coverage/lcov-report/src/Logger/Logger.ts.html +325 -0
- package/coverage/lcov-report/src/Logger/index.html +116 -0
- package/coverage/lcov-report/src/PeerConnectionController/AggregatedStats.ts.html +1018 -0
- package/coverage/lcov-report/src/PeerConnectionController/CandidatePairStats.ts.html +136 -0
- package/coverage/lcov-report/src/PeerConnectionController/CandidateStat.ts.html +124 -0
- package/coverage/lcov-report/src/PeerConnectionController/DataChannelStats.ts.html +136 -0
- package/coverage/lcov-report/src/PeerConnectionController/InboundRTPStats.ts.html +547 -0
- package/coverage/lcov-report/src/PeerConnectionController/OutBoundRTPStats.ts.html +163 -0
- package/coverage/lcov-report/src/PeerConnectionController/PeerConnectionController.ts.html +1795 -0
- package/coverage/lcov-report/src/PeerConnectionController/SessionStats.ts.html +115 -0
- package/coverage/lcov-report/src/PeerConnectionController/StreamStats.ts.html +118 -0
- package/coverage/lcov-report/src/PeerConnectionController/index.html +236 -0
- package/coverage/lcov-report/src/PixelStreaming/PixelStreaming.ts.html +2269 -0
- package/coverage/lcov-report/src/PixelStreaming/index.html +116 -0
- package/coverage/lcov-report/src/UI/OnScreenKeyboard.ts.html +376 -0
- package/coverage/lcov-report/src/UI/index.html +116 -0
- package/coverage/lcov-report/src/UeInstanceMessage/ResponseController.ts.html +226 -0
- package/coverage/lcov-report/src/UeInstanceMessage/SendDescriptorController.ts.html +346 -0
- package/coverage/lcov-report/src/UeInstanceMessage/SendMessageController.ts.html +364 -0
- package/coverage/lcov-report/src/UeInstanceMessage/StreamMessageController.ts.html +862 -0
- package/coverage/lcov-report/src/UeInstanceMessage/ToStreamerMessagesController.ts.html +271 -0
- package/coverage/lcov-report/src/UeInstanceMessage/TwoWayMap.ts.html +241 -0
- package/coverage/lcov-report/src/UeInstanceMessage/index.html +191 -0
- package/coverage/lcov-report/src/Util/CoordinateConverter.ts.html +952 -0
- package/coverage/lcov-report/src/Util/EventEmitter.ts.html +1705 -0
- package/coverage/lcov-report/src/Util/EventListenerTracker.ts.html +172 -0
- package/coverage/lcov-report/src/Util/FileUtil.ts.html +505 -0
- package/coverage/lcov-report/src/Util/WebGLUtils.ts.html +232 -0
- package/coverage/lcov-report/src/Util/WebXRUtils.ts.html +160 -0
- package/coverage/lcov-report/src/Util/index.html +191 -0
- package/coverage/lcov-report/src/VideoPlayer/StreamController.ts.html +349 -0
- package/coverage/lcov-report/src/VideoPlayer/VideoPlayer.ts.html +799 -0
- package/coverage/lcov-report/src/VideoPlayer/index.html +131 -0
- package/coverage/lcov-report/src/WebRtcPlayer/WebRtcPlayerController.ts.html +6199 -0
- package/coverage/lcov-report/src/WebRtcPlayer/index.html +116 -0
- package/coverage/lcov-report/src/WebSockets/MessageReceive.ts.html +352 -0
- package/coverage/lcov-report/src/WebSockets/MessageSend.ts.html +604 -0
- package/coverage/lcov-report/src/WebSockets/SignallingProtocol.ts.html +622 -0
- package/coverage/lcov-report/src/WebSockets/WebSocketController.ts.html +844 -0
- package/coverage/lcov-report/src/WebSockets/index.html +161 -0
- package/coverage/lcov-report/src/WebXR/WebXRController.ts.html +1042 -0
- package/coverage/lcov-report/src/WebXR/index.html +116 -0
- package/coverage/lcov-report/src/__test__/index.html +161 -0
- package/coverage/lcov-report/src/__test__/mockMediaStream.ts.html +457 -0
- package/coverage/lcov-report/src/__test__/mockRTCPeerConnection.ts.html +1126 -0
- package/coverage/lcov-report/src/__test__/mockRTCRtpReceiver.ts.html +151 -0
- package/coverage/lcov-report/src/__test__/mockWebSocket.ts.html +475 -0
- package/coverage/lcov-report/src/index.html +116 -0
- package/coverage/lcov-report/src/pixelstreamingfrontend.ts.html +232 -0
- package/coverage/lcov.info +6458 -0
- package/dist/lib-pixelstreamingfrontend.esm.js +1 -0
- package/dist/lib-pixelstreamingfrontend.js +1 -0
- package/jest.config.js +18 -0
- package/package.json +47 -18
- package/readme.md +15 -0
- package/src/AFK/AFKController.test.ts +162 -0
- package/src/AFK/AFKController.ts +158 -0
- package/src/Config/Config.test.ts +222 -0
- package/src/Config/Config.ts +909 -0
- package/src/Config/SettingBase.ts +65 -0
- package/src/Config/SettingFlag.ts +99 -0
- package/src/Config/SettingNumber.ts +111 -0
- package/src/Config/SettingOption.ts +124 -0
- package/src/Config/SettingText.ts +82 -0
- package/src/DataChannel/DataChannelController.ts +138 -0
- package/src/DataChannel/DataChannelLatencyTestController.ts +129 -0
- package/src/DataChannel/DataChannelLatencyTestResults.ts +67 -0
- package/src/DataChannel/DataChannelSender.ts +59 -0
- package/src/DataChannel/InitialSettings.ts +61 -0
- package/src/DataChannel/LatencyTestResults.ts +76 -0
- package/src/FreezeFrame/FreezeFrame.ts +114 -0
- package/src/FreezeFrame/FreezeFrameController.ts +114 -0
- package/src/Inputs/FakeTouchController.ts +199 -0
- package/src/Inputs/GamepadController.ts +300 -0
- package/src/Inputs/GamepadTypes.ts +10 -0
- package/src/Inputs/HoveringMouseEvents.ts +192 -0
- package/src/Inputs/IMouseEvents.ts +64 -0
- package/src/Inputs/ITouchController.ts +29 -0
- package/src/Inputs/InputClassesFactory.ts +140 -0
- package/src/Inputs/KeyboardController.ts +318 -0
- package/src/Inputs/LockedMouseEvents.ts +287 -0
- package/src/Inputs/MouseButtons.ts +25 -0
- package/src/Inputs/MouseController.ts +362 -0
- package/src/Inputs/SpecialKeyCodes.ts +16 -0
- package/src/Inputs/TouchController.ts +253 -0
- package/src/Inputs/XRGamepadController.ts +126 -0
- package/src/Logger/Logger.ts +80 -0
- package/src/PeerConnectionController/AggregatedStats.ts +311 -0
- package/src/PeerConnectionController/CandidatePairStats.ts +17 -0
- package/src/PeerConnectionController/CandidateStat.ts +13 -0
- package/src/PeerConnectionController/CodecStats.ts +19 -0
- package/src/PeerConnectionController/DataChannelStats.ts +17 -0
- package/src/PeerConnectionController/InboundRTPStats.ts +154 -0
- package/src/PeerConnectionController/InboundTrackStats.ts +34 -0
- package/src/PeerConnectionController/OutBoundRTPStats.ts +26 -0
- package/src/PeerConnectionController/PeerConnectionController.ts +563 -0
- package/src/PeerConnectionController/SessionStats.ts +10 -0
- package/src/PeerConnectionController/StreamStats.ts +11 -0
- package/src/PixelStreaming/PixelStreaming.test.ts +624 -0
- package/src/PixelStreaming/PixelStreaming.ts +847 -0
- package/src/UI/OnScreenKeyboard.ts +97 -0
- package/src/UeInstanceMessage/ResponseController.ts +47 -0
- package/src/UeInstanceMessage/SendMessageController.ts +154 -0
- package/src/UeInstanceMessage/StreamMessageController.ts +233 -0
- package/src/UeInstanceMessage/ToStreamerMessagesController.ts +62 -0
- package/src/Util/CoordinateConverter.ts +289 -0
- package/src/Util/EventEmitter.ts +595 -0
- package/src/Util/EventListenerTracker.ts +29 -0
- package/src/Util/FileUtil.ts +140 -0
- package/src/Util/RTCUtils.ts +41 -0
- package/src/Util/WebGLUtils.ts +49 -0
- package/src/Util/WebXRUtils.ts +25 -0
- package/src/VideoPlayer/StreamController.ts +89 -0
- package/src/VideoPlayer/VideoPlayer.ts +246 -0
- package/src/WebRtcPlayer/WebRtcPlayerController.ts +2221 -0
- package/src/WebSockets/MessageReceive.ts +89 -0
- package/src/WebSockets/MessageSend.ts +185 -0
- package/src/WebSockets/SignallingProtocol.ts +180 -0
- package/src/WebSockets/WebSocketController.ts +267 -0
- package/src/WebXR/WebXRController.ts +319 -0
- package/src/__test__/mockMediaStream.ts +124 -0
- package/src/__test__/mockRTCPeerConnection.ts +347 -0
- package/src/__test__/mockRTCRtpReceiver.ts +22 -0
- package/src/__test__/mockWebSocket.ts +130 -0
- package/src/pixelstreamingfrontend.ts +50 -0
- package/tsconfig.jest.json +8 -0
- package/tsconfig.json +24 -0
- package/{library/types → types}/Config/Config.d.ts +5 -4
- package/types/DataChannel/DataChannelLatencyTestController.d.ts +26 -0
- package/types/DataChannel/DataChannelLatencyTestResults.d.ts +46 -0
- package/{library/types → types}/Inputs/HoveringMouseEvents.d.ts +1 -1
- package/{library/types → types}/PeerConnectionController/PeerConnectionController.d.ts +1 -1
- package/{library/types → types}/PixelStreaming/PixelStreaming.d.ts +31 -6
- package/{library/types → types}/UeInstanceMessage/SendMessageController.d.ts +1 -1
- package/{library/types → types}/UeInstanceMessage/StreamMessageController.d.ts +3 -5
- package/{library/types → types}/Util/EventEmitter.d.ts +40 -3
- package/types/Util/RTCUtils.d.ts +8 -0
- package/{library/types → types}/VideoPlayer/StreamController.d.ts +3 -3
- package/{library/types → types}/VideoPlayer/VideoPlayer.d.ts +2 -0
- package/{library/types → types}/WebRtcPlayer/WebRtcPlayerController.d.ts +30 -27
- package/{library/types → types}/WebSockets/MessageReceive.d.ts +9 -9
- package/{library/types → types}/WebSockets/MessageSend.d.ts +13 -9
- package/{library/types → types}/WebSockets/SignallingProtocol.d.ts +3 -3
- package/{library/types → types}/WebSockets/WebSocketController.d.ts +16 -12
- package/{library/types → types}/pixelstreamingfrontend.d.ts +2 -1
- package/webpack.common.js +35 -0
- package/webpack.dev.js +35 -0
- package/webpack.prod.js +36 -0
- package/yang__yj-pixelstreaming-core-1.0.1.tgz +0 -0
- package/yang__yj-pixelstreaming-core-1.0.2.tgz +0 -0
- package/library/dist/lib-pixelstreamingfrontend.esm.js +0 -1
- package/library/dist/lib-pixelstreamingfrontend.js +0 -1
- /package/{library/types → types}/AFK/AFKController.d.ts +0 -0
- /package/{library/types → types}/Config/SettingBase.d.ts +0 -0
- /package/{library/types → types}/Config/SettingFlag.d.ts +0 -0
- /package/{library/types → types}/Config/SettingNumber.d.ts +0 -0
- /package/{library/types → types}/Config/SettingOption.d.ts +0 -0
- /package/{library/types → types}/Config/SettingText.d.ts +0 -0
- /package/{library/types → types}/DataChannel/DataChannelController.d.ts +0 -0
- /package/{library/types → types}/DataChannel/DataChannelSender.d.ts +0 -0
- /package/{library/types → types}/DataChannel/InitialSettings.d.ts +0 -0
- /package/{library/types → types}/DataChannel/LatencyTestResults.d.ts +0 -0
- /package/{library/types → types}/FreezeFrame/FreezeFrame.d.ts +0 -0
- /package/{library/types → types}/FreezeFrame/FreezeFrameController.d.ts +0 -0
- /package/{library/types → types}/Inputs/FakeTouchController.d.ts +0 -0
- /package/{library/types → types}/Inputs/GamepadController.d.ts +0 -0
- /package/{library/types → types}/Inputs/GamepadTypes.d.ts +0 -0
- /package/{library/types → types}/Inputs/IMouseEvents.d.ts +0 -0
- /package/{library/types → types}/Inputs/ITouchController.d.ts +0 -0
- /package/{library/types → types}/Inputs/InputClassesFactory.d.ts +0 -0
- /package/{library/types → types}/Inputs/KeyboardController.d.ts +0 -0
- /package/{library/types → types}/Inputs/LockedMouseEvents.d.ts +0 -0
- /package/{library/types → types}/Inputs/MouseButtons.d.ts +0 -0
- /package/{library/types → types}/Inputs/MouseController.d.ts +0 -0
- /package/{library/types → types}/Inputs/SpecialKeyCodes.d.ts +0 -0
- /package/{library/types → types}/Inputs/TouchController.d.ts +0 -0
- /package/{library/types → types}/Inputs/XRGamepadController.d.ts +0 -0
- /package/{library/types → types}/Logger/Logger.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/AggregatedStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/CandidatePairStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/CandidateStat.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/CodecStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/DataChannelStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/InboundRTPStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/InboundTrackStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/OutBoundRTPStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/SessionStats.d.ts +0 -0
- /package/{library/types → types}/PeerConnectionController/StreamStats.d.ts +0 -0
- /package/{library/types → types}/UI/OnScreenKeyboard.d.ts +0 -0
- /package/{library/types → types}/UeInstanceMessage/ResponseController.d.ts +0 -0
- /package/{library/types → types}/UeInstanceMessage/SendDescriptorController.d.ts +0 -0
- /package/{library/types → types}/UeInstanceMessage/ToStreamerMessagesController.d.ts +0 -0
- /package/{library/types → types}/UeInstanceMessage/TwoWayMap.d.ts +0 -0
- /package/{library/types → types}/Util/CoordinateConverter.d.ts +0 -0
- /package/{library/types → types}/Util/EventListenerTracker.d.ts +0 -0
- /package/{library/types → types}/Util/FileUtil.d.ts +0 -0
- /package/{library/types → types}/Util/WebGLUtils.d.ts +0 -0
- /package/{library/types → types}/Util/WebXRUtils.d.ts +0 -0
- /package/{library/types → types}/WebXR/WebXRController.d.ts +0 -0
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
// Copyright Epic Games, Inc. All Rights Reserved.
|
|
2
|
+
|
|
3
|
+
import { Config, Flags, NumericParameters } from '../Config/Config';
|
|
4
|
+
import { Logger } from '../Logger/Logger';
|
|
5
|
+
import { PixelStreaming } from '../PixelStreaming/PixelStreaming';
|
|
6
|
+
import {
|
|
7
|
+
AfkTimedOutEvent,
|
|
8
|
+
AfkWarningActivateEvent,
|
|
9
|
+
AfkWarningDeactivateEvent,
|
|
10
|
+
AfkWarningUpdateEvent
|
|
11
|
+
} from '../Util/EventEmitter';
|
|
12
|
+
|
|
13
|
+
export class AFKController {
|
|
14
|
+
// time out logic details
|
|
15
|
+
closeTimeout = 10;
|
|
16
|
+
active = false;
|
|
17
|
+
countdownActive = false;
|
|
18
|
+
warnTimer: ReturnType<typeof setTimeout> = undefined;
|
|
19
|
+
countDown = 0;
|
|
20
|
+
countDownTimer: ReturnType<typeof setInterval> = undefined;
|
|
21
|
+
config: Config;
|
|
22
|
+
pixelStreaming: PixelStreaming;
|
|
23
|
+
onDismissAfk: () => void;
|
|
24
|
+
|
|
25
|
+
onAFKTimedOutCallback: () => void;
|
|
26
|
+
|
|
27
|
+
constructor(
|
|
28
|
+
config: Config,
|
|
29
|
+
pixelStreaming: PixelStreaming,
|
|
30
|
+
onDismissAfk: () => void
|
|
31
|
+
) {
|
|
32
|
+
this.config = config;
|
|
33
|
+
this.pixelStreaming = pixelStreaming;
|
|
34
|
+
this.onDismissAfk = onDismissAfk;
|
|
35
|
+
this.onAFKTimedOutCallback = () => {
|
|
36
|
+
console.log(
|
|
37
|
+
'AFK timed out, did you want to override this callback?'
|
|
38
|
+
);
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* The methods that occur when an afk event listener is clicked
|
|
44
|
+
*/
|
|
45
|
+
onAfkClick() {
|
|
46
|
+
clearInterval(this.countDownTimer);
|
|
47
|
+
|
|
48
|
+
if (this.active || this.countdownActive) {
|
|
49
|
+
this.startAfkWarningTimer();
|
|
50
|
+
this.pixelStreaming.dispatchEvent(
|
|
51
|
+
new AfkWarningDeactivateEvent()
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Start the warning timer if a timeout is set greater that 0 seconds
|
|
58
|
+
*/
|
|
59
|
+
startAfkWarningTimer() {
|
|
60
|
+
if (
|
|
61
|
+
this.config.getNumericSettingValue(
|
|
62
|
+
NumericParameters.AFKTimeoutSecs
|
|
63
|
+
) > 0 &&
|
|
64
|
+
this.config.isFlagEnabled(Flags.AFKDetection)
|
|
65
|
+
) {
|
|
66
|
+
this.active = true;
|
|
67
|
+
} else {
|
|
68
|
+
this.active = false;
|
|
69
|
+
}
|
|
70
|
+
this.resetAfkWarningTimer();
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* Stop the afk warning timer
|
|
75
|
+
*/
|
|
76
|
+
stopAfkWarningTimer() {
|
|
77
|
+
this.active = false;
|
|
78
|
+
this.countdownActive = false;
|
|
79
|
+
clearTimeout(this.warnTimer);
|
|
80
|
+
clearInterval(this.countDownTimer);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* Pause the timer which when elapsed will warn the user they are inactive.
|
|
85
|
+
*/
|
|
86
|
+
pauseAfkWarningTimer() {
|
|
87
|
+
this.active = false;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* If the user interacts then reset the warning timer.
|
|
92
|
+
*/
|
|
93
|
+
resetAfkWarningTimer() {
|
|
94
|
+
if (this.active && this.config.isFlagEnabled(Flags.AFKDetection)) {
|
|
95
|
+
clearTimeout(this.warnTimer);
|
|
96
|
+
this.warnTimer = setTimeout(
|
|
97
|
+
() => this.activateAfkEvent(),
|
|
98
|
+
this.config.getNumericSettingValue(
|
|
99
|
+
NumericParameters.AFKTimeoutSecs
|
|
100
|
+
) * 1000
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Show the AFK overlay and begin the countDown
|
|
107
|
+
*/
|
|
108
|
+
activateAfkEvent() {
|
|
109
|
+
// Pause the timer while the user is looking at the inactivity warning overlay
|
|
110
|
+
this.pauseAfkWarningTimer();
|
|
111
|
+
|
|
112
|
+
// instantiate a new overlay
|
|
113
|
+
this.pixelStreaming.dispatchEvent(
|
|
114
|
+
new AfkWarningActivateEvent({
|
|
115
|
+
countDown: this.countDown,
|
|
116
|
+
dismissAfk: this.onDismissAfk
|
|
117
|
+
})
|
|
118
|
+
);
|
|
119
|
+
|
|
120
|
+
// update our countDown timer and overlay contents
|
|
121
|
+
this.countDown = this.closeTimeout;
|
|
122
|
+
this.countdownActive = true;
|
|
123
|
+
this.pixelStreaming.dispatchEvent(
|
|
124
|
+
new AfkWarningUpdateEvent({ countDown: this.countDown })
|
|
125
|
+
);
|
|
126
|
+
|
|
127
|
+
// if we are in locked mouse exit pointerlock
|
|
128
|
+
if (!this.config.isFlagEnabled(Flags.HoveringMouseMode)) {
|
|
129
|
+
// minor hack to alleviate ios not supporting pointerlock
|
|
130
|
+
if (document.exitPointerLock) {
|
|
131
|
+
document.exitPointerLock();
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// reset our countDown interval accordingly
|
|
136
|
+
this.countDownTimer = setInterval(() => {
|
|
137
|
+
this.countDown--;
|
|
138
|
+
if (this.countDown == 0) {
|
|
139
|
+
// The user failed to click so hide the overlay and disconnect them.
|
|
140
|
+
this.pixelStreaming.dispatchEvent(
|
|
141
|
+
new AfkTimedOutEvent()
|
|
142
|
+
);
|
|
143
|
+
this.onAFKTimedOutCallback();
|
|
144
|
+
Logger.Log(
|
|
145
|
+
Logger.GetStackTrace(),
|
|
146
|
+
'You have been disconnected due to inactivity'
|
|
147
|
+
);
|
|
148
|
+
|
|
149
|
+
// switch off the afk feature as stream has closed
|
|
150
|
+
this.stopAfkWarningTimer();
|
|
151
|
+
} else {
|
|
152
|
+
this.pixelStreaming.dispatchEvent(
|
|
153
|
+
new AfkWarningUpdateEvent({ countDown: this.countDown })
|
|
154
|
+
);
|
|
155
|
+
}
|
|
156
|
+
}, 1000);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
import { mockRTCRtpReceiver, unmockRTCRtpReceiver } from '../__test__/mockRTCRtpReceiver';
|
|
2
|
+
import {
|
|
3
|
+
Config,
|
|
4
|
+
Flags,
|
|
5
|
+
FlagsKeys,
|
|
6
|
+
NumericParameters,
|
|
7
|
+
NumericParametersKeys,
|
|
8
|
+
OptionParameters,
|
|
9
|
+
OptionParametersKeys,
|
|
10
|
+
TextParameters,
|
|
11
|
+
TextParametersKeys
|
|
12
|
+
} from './Config';
|
|
13
|
+
|
|
14
|
+
const allFlags = Object.keys(Flags).map((key) => Flags[key as FlagsKeys]);
|
|
15
|
+
const allNumericParameters = Object.keys(NumericParameters).map(
|
|
16
|
+
(key) => NumericParameters[key as NumericParametersKeys]
|
|
17
|
+
);
|
|
18
|
+
const allTextParameters = Object.keys(TextParameters).map(
|
|
19
|
+
(key) => TextParameters[key as TextParametersKeys]
|
|
20
|
+
);
|
|
21
|
+
const allOptionParameters = Object.keys(OptionParameters).map(
|
|
22
|
+
(key) => OptionParameters[key as OptionParametersKeys]
|
|
23
|
+
);
|
|
24
|
+
|
|
25
|
+
const allParameters = [
|
|
26
|
+
...allFlags,
|
|
27
|
+
...allNumericParameters,
|
|
28
|
+
...allTextParameters,
|
|
29
|
+
...allOptionParameters
|
|
30
|
+
];
|
|
31
|
+
|
|
32
|
+
describe('Config', () => {
|
|
33
|
+
beforeEach(() => {
|
|
34
|
+
mockRTCRtpReceiver();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
afterEach(() => {
|
|
38
|
+
unmockRTCRtpReceiver();
|
|
39
|
+
jest.resetAllMocks();
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it('should populate initial values for all settings when initialized without parameters', () => {
|
|
43
|
+
const config = new Config();
|
|
44
|
+
|
|
45
|
+
const settings = config.getSettings();
|
|
46
|
+
expect(Object.keys(settings)).toEqual(
|
|
47
|
+
expect.arrayContaining(allParameters)
|
|
48
|
+
);
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it('should populate given initial setting values', () => {
|
|
52
|
+
const initialSettings = {
|
|
53
|
+
[Flags.AutoPlayVideo]: false,
|
|
54
|
+
[NumericParameters.WebRTCMaxBitrate]: 12345,
|
|
55
|
+
[TextParameters.SignallingServerUrl]: 'url'
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
const config = new Config({ initialSettings });
|
|
59
|
+
|
|
60
|
+
expect(config.isFlagEnabled(Flags.AutoPlayVideo)).toEqual(
|
|
61
|
+
initialSettings[Flags.AutoPlayVideo]
|
|
62
|
+
);
|
|
63
|
+
expect(
|
|
64
|
+
config.getNumericSettingValue(NumericParameters.WebRTCMaxBitrate)
|
|
65
|
+
).toEqual(initialSettings[NumericParameters.WebRTCMaxBitrate]);
|
|
66
|
+
expect(
|
|
67
|
+
config.getTextSettingValue(TextParameters.SignallingServerUrl)
|
|
68
|
+
).toEqual(initialSettings[TextParameters.SignallingServerUrl]);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('should replace setting values when new settings are set with setSettings', () => {
|
|
72
|
+
const config = new Config();
|
|
73
|
+
|
|
74
|
+
const preferredCodecs = ['c1', 'c2', 'c3'];
|
|
75
|
+
config.setOptionSettingOptions(
|
|
76
|
+
OptionParameters.PreferredCodec,
|
|
77
|
+
preferredCodecs
|
|
78
|
+
);
|
|
79
|
+
|
|
80
|
+
const changedSettings = {
|
|
81
|
+
[Flags.AutoPlayVideo]: false,
|
|
82
|
+
[NumericParameters.WebRTCMaxBitrate]: 54321,
|
|
83
|
+
[TextParameters.SignallingServerUrl]: 'signalling-url',
|
|
84
|
+
[OptionParameters.PreferredCodec]: 'c2'
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
config.setSettings(changedSettings);
|
|
88
|
+
|
|
89
|
+
expect(config.isFlagEnabled(Flags.AutoPlayVideo)).toEqual(
|
|
90
|
+
changedSettings[Flags.AutoPlayVideo]
|
|
91
|
+
);
|
|
92
|
+
expect(
|
|
93
|
+
config.getNumericSettingValue(NumericParameters.WebRTCMaxBitrate)
|
|
94
|
+
).toEqual(changedSettings[NumericParameters.WebRTCMaxBitrate]);
|
|
95
|
+
expect(
|
|
96
|
+
config.getTextSettingValue(TextParameters.SignallingServerUrl)
|
|
97
|
+
).toEqual(changedSettings[TextParameters.SignallingServerUrl]);
|
|
98
|
+
expect(
|
|
99
|
+
config.getSettingOption(OptionParameters.PreferredCodec).selected
|
|
100
|
+
).toEqual(changedSettings[OptionParameters.PreferredCodec]);
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('should replace setting values when new settings are set with set* setters', () => {
|
|
104
|
+
const config = new Config();
|
|
105
|
+
|
|
106
|
+
const preferredCodecs = ['c1', 'c2', 'c3'];
|
|
107
|
+
config.setOptionSettingOptions(
|
|
108
|
+
OptionParameters.PreferredCodec,
|
|
109
|
+
preferredCodecs
|
|
110
|
+
);
|
|
111
|
+
|
|
112
|
+
const changedSettings = {
|
|
113
|
+
[Flags.AutoPlayVideo]: false,
|
|
114
|
+
[NumericParameters.WebRTCMaxBitrate]: 54321,
|
|
115
|
+
[TextParameters.SignallingServerUrl]: 'signalling-url',
|
|
116
|
+
[OptionParameters.PreferredCodec]: 'c2'
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
config.setFlagEnabled(
|
|
120
|
+
Flags.AutoPlayVideo,
|
|
121
|
+
changedSettings[Flags.AutoPlayVideo]
|
|
122
|
+
);
|
|
123
|
+
config.setNumericSetting(
|
|
124
|
+
NumericParameters.WebRTCMaxBitrate,
|
|
125
|
+
changedSettings[NumericParameters.WebRTCMaxBitrate]
|
|
126
|
+
);
|
|
127
|
+
config.setTextSetting(
|
|
128
|
+
TextParameters.SignallingServerUrl,
|
|
129
|
+
changedSettings[TextParameters.SignallingServerUrl]
|
|
130
|
+
);
|
|
131
|
+
config.setOptionSettingValue(
|
|
132
|
+
OptionParameters.PreferredCodec,
|
|
133
|
+
changedSettings[OptionParameters.PreferredCodec]
|
|
134
|
+
);
|
|
135
|
+
|
|
136
|
+
expect(config.isFlagEnabled(Flags.AutoPlayVideo)).toEqual(
|
|
137
|
+
changedSettings[Flags.AutoPlayVideo]
|
|
138
|
+
);
|
|
139
|
+
expect(
|
|
140
|
+
config.getNumericSettingValue(NumericParameters.WebRTCMaxBitrate)
|
|
141
|
+
).toEqual(changedSettings[NumericParameters.WebRTCMaxBitrate]);
|
|
142
|
+
expect(
|
|
143
|
+
config.getTextSettingValue(TextParameters.SignallingServerUrl)
|
|
144
|
+
).toEqual(changedSettings[TextParameters.SignallingServerUrl]);
|
|
145
|
+
expect(
|
|
146
|
+
config.getSettingOption(OptionParameters.PreferredCodec).selected
|
|
147
|
+
).toEqual(changedSettings[OptionParameters.PreferredCodec]);
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
it('should persist config changes to window.location URL when updateURLParams() is called', () => {
|
|
151
|
+
const config = new Config({ useUrlParams: true });
|
|
152
|
+
|
|
153
|
+
const preferredCodecs = ['c1', 'c2', 'c3'];
|
|
154
|
+
config.setOptionSettingOptions(
|
|
155
|
+
OptionParameters.PreferredCodec,
|
|
156
|
+
preferredCodecs
|
|
157
|
+
);
|
|
158
|
+
|
|
159
|
+
const changedSettings = {
|
|
160
|
+
[Flags.AutoPlayVideo]: false,
|
|
161
|
+
[NumericParameters.WebRTCMaxBitrate]: 54321,
|
|
162
|
+
[TextParameters.SignallingServerUrl]: 'signalling-url',
|
|
163
|
+
[OptionParameters.PreferredCodec]: 'c2'
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
config.setSettings(changedSettings);
|
|
167
|
+
|
|
168
|
+
config
|
|
169
|
+
.getFlags()
|
|
170
|
+
.find((setting) => setting.id === Flags.AutoPlayVideo)
|
|
171
|
+
?.updateURLParams();
|
|
172
|
+
config
|
|
173
|
+
.getNumericSettings()
|
|
174
|
+
.find(
|
|
175
|
+
(setting) => setting.id === NumericParameters.WebRTCMaxBitrate
|
|
176
|
+
)
|
|
177
|
+
?.updateURLParams();
|
|
178
|
+
config
|
|
179
|
+
.getTextSettings()
|
|
180
|
+
.find(
|
|
181
|
+
(setting) => setting.id === TextParameters.SignallingServerUrl
|
|
182
|
+
)
|
|
183
|
+
?.updateURLParams();
|
|
184
|
+
config
|
|
185
|
+
.getOptionSettings()
|
|
186
|
+
.find((setting) => setting.id === OptionParameters.PreferredCodec)
|
|
187
|
+
?.updateURLParams();
|
|
188
|
+
|
|
189
|
+
const urlParams = new URLSearchParams(window.location.search);
|
|
190
|
+
|
|
191
|
+
expect(urlParams.get(Flags.AutoPlayVideo)).toEqual(
|
|
192
|
+
changedSettings[Flags.AutoPlayVideo].toString()
|
|
193
|
+
);
|
|
194
|
+
expect(urlParams.get(NumericParameters.WebRTCMaxBitrate)).toEqual(
|
|
195
|
+
changedSettings[NumericParameters.WebRTCMaxBitrate].toString()
|
|
196
|
+
);
|
|
197
|
+
expect(urlParams.get(TextParameters.SignallingServerUrl)).toEqual(
|
|
198
|
+
changedSettings[TextParameters.SignallingServerUrl].toString()
|
|
199
|
+
);
|
|
200
|
+
expect(urlParams.get(OptionParameters.PreferredCodec)).toEqual(
|
|
201
|
+
changedSettings[OptionParameters.PreferredCodec].toString()
|
|
202
|
+
);
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
it('should read initial config from window.location URL if initialized with useUrlParams: true', () => {
|
|
206
|
+
window.history.replaceState(
|
|
207
|
+
{},
|
|
208
|
+
'',
|
|
209
|
+
'http://localhost/?AutoPlayVideo=false&WebRTCMaxBitrate=43210&ss=signalling-url-from-url-param'
|
|
210
|
+
);
|
|
211
|
+
|
|
212
|
+
const config = new Config({ useUrlParams: true });
|
|
213
|
+
|
|
214
|
+
expect(config.isFlagEnabled(Flags.AutoPlayVideo)).toEqual(false);
|
|
215
|
+
expect(
|
|
216
|
+
config.getNumericSettingValue(NumericParameters.WebRTCMaxBitrate)
|
|
217
|
+
).toEqual(43210);
|
|
218
|
+
expect(
|
|
219
|
+
config.getTextSettingValue(TextParameters.SignallingServerUrl)
|
|
220
|
+
).toEqual('signalling-url-from-url-param');
|
|
221
|
+
});
|
|
222
|
+
});
|