1
0
mirror of https://gitlab.nic.cz/turris/reforis/foris-js.git synced 2024-12-28 00:41:35 +01:00
foris-js/src/webSockets/WebSockets.js

127 lines
3.4 KiB
JavaScript
Raw Normal View History

2019-08-23 15:20:22 +02:00
/*
* Copyright (C) 2019 CZ.NIC z.s.p.o. (http://www.nic.cz/)
*
* This is free software, licensed under the GNU General Public License v3.
* See /LICENSE for more information.
*/
2019-08-27 16:09:18 +02:00
/* eslint no-console: "off" */
import { ForisURLs } from "forisUrls";
2019-08-23 15:20:22 +02:00
const PROTOCOL = window.location.protocol === "http:" ? "ws" : "wss";
const URL = process.env.LIGHTTPD
? `${PROTOCOL}://${window.location.hostname}/foris-ws`
: `${PROTOCOL}://${window.location.hostname}:${9081}`;
const WAITING_FOR_CONNECTION_TIMEOUT = 500;
2019-08-27 17:46:45 +02:00
export class WebSockets {
2019-08-23 15:20:22 +02:00
constructor() {
this.ws = new WebSocket(URL);
this.ws.onerror = (e) => {
2019-08-27 16:09:18 +02:00
if (window.location.pathname !== ForisURLs.login) {
2019-08-23 15:20:22 +02:00
console.error("WS: Error observed, you aren't logged probably.");
2019-08-27 16:09:18 +02:00
window.location.replace(ForisURLs.login);
2019-08-23 15:20:22 +02:00
}
console.log(`WS: Error: ${e}`);
};
this.ws.onmessage = (e) => {
console.log(`WS: Received Message: ${e.data}`);
const data = JSON.parse(e.data);
this.dispatch(data);
};
this.ws.onopen = () => {
console.log("WS: Connection open.");
};
this.ws.onclose = () => {
console.log("WS: Connection closed.");
};
// callbacks[module][action]
this.callbacks = {};
}
waitForConnection(callback) {
if (this.ws.readyState === 1) {
callback();
} else {
const that = this;
setTimeout(() => {
that.waitForConnection(callback);
}, WAITING_FOR_CONNECTION_TIMEOUT);
}
}
bind(module, action, callback) {
this.callbacks[module] = this.callbacks[module] || {};
this.callbacks[module][action] = this.callbacks[module][action] || [];
this.callbacks[module][action].push(callback);
return this;
}
subscribe(module) {
2019-08-23 15:20:22 +02:00
this.waitForConnection(() => {
this.send("subscribe", module);
});
return this;
}
unbind(module, action, callback) {
const callbacks = this.callbacks[module][action];
const index = callbacks.indexOf(callback);
if (index !== -1) {
callbacks.splice(index, 1);
}
if (callbacks.length === 0) {
delete this.callbacks[module][action];
}
if (Object.keys(this.callbacks[module]).length === 0) {
this.unsubscribe(module);
}
return this;
}
unsubscribe(module) {
this.waitForConnection(() => {
this.send("unsubscribe", module);
delete this.callbacks[module];
2019-08-23 15:20:22 +02:00
});
return this;
}
send(action, params) {
const payload = JSON.stringify({ action, params });
this.waitForConnection(() => {
this.ws.send(payload);
});
return this;
}
dispatch(json) {
if (!json.module) return;
let chain;
try {
chain = this.callbacks[json.module][json.action];
} catch (error) {
if (error instanceof TypeError) {
console.log(`Callback for this message wasn't found:${error.data}`);
} else throw error;
2019-08-23 15:20:22 +02:00
}
if (typeof chain === "undefined") return;
chain.forEach((callback) => callback(json));
2019-08-23 15:20:22 +02:00
}
close() {
this.ws.close();
}
}