summaryrefslogtreecommitdiff
path: root/kvmd/web/js/session.js
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/web/js/session.js')
-rw-r--r--kvmd/web/js/session.js61
1 files changed, 61 insertions, 0 deletions
diff --git a/kvmd/web/js/session.js b/kvmd/web/js/session.js
new file mode 100644
index 00000000..31a76f68
--- /dev/null
+++ b/kvmd/web/js/session.js
@@ -0,0 +1,61 @@
+var session = new function() {
+ var __ws = null;
+ var __ping_timer = null;
+ var __missed_heartbeats = 0;
+
+ this.startPoller = function() {
+ __ws = new WebSocket("ws://" + location.host + "/kvmd/ws");
+ __ws.onopen = __wsOpenHandler;
+ __ws.onmessage = __wsMessageHandler;
+ __ws.onerror = __wsErrorHandler;
+ __ws.onclose = __wsCloseHandler;
+ };
+
+ var __wsOpenHandler = function(event) {
+ tools.debug("WebSocket opened:", event);
+ hid.installCapture(__ws);
+ __missed_heartbeats = 0;
+ __ping_timer = setInterval(__pingServer, 1000);
+ };
+
+ var __wsMessageHandler = function(event) {
+ // tools.debug("WebSocket: received data:", event.data);
+ event = JSON.parse(event.data);
+ if (event.msg_type === "pong") {
+ __missed_heartbeats = 0;
+ } else if (event.msg_type === "event") {
+ if (event.msg.event === "atx_state") {
+ atx.setLedsState(event.msg.event_attrs.leds);
+ }
+ }
+ };
+
+ var __wsErrorHandler = function(event) {
+ tools.error("WebSocket error:", event);
+ __ws.close();
+ };
+
+ var __wsCloseHandler = function(event) {
+ tools.debug("WebSocket closed:", event);
+ if (__ping_timer) {
+ clearInterval(__ping_timer);
+ __ping_timer = null;
+ }
+ hid.clearCapture();
+ atx.clearLeds();
+ setTimeout(session.startPoller, 1000);
+ };
+
+ var __pingServer = function(event) {
+ try {
+ __missed_heartbeats += 1;
+ if (__missed_heartbeats >= 5) {
+ throw new Error("Too many missed heartbeats");
+ }
+ __ws.send(JSON.stringify({"event_type": "ping"}));
+ } catch (err) {
+ tools.error("Ping error:", err.message);
+ __ws.close();
+ }
+ };
+};