2019-08-23 15:20:22 +02:00
|
|
|
/*
|
2022-03-23 10:15:00 +01:00
|
|
|
* Copyright (C) 2020-2022 CZ.NIC z.s.p.o. (http://www.nic.cz/)
|
2019-08-23 15:20:22 +02:00
|
|
|
*
|
|
|
|
* 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" */
|
|
|
|
|
2019-08-23 15:20:22 +02:00
|
|
|
const PROTOCOL = window.location.protocol === "http:" ? "ws" : "wss";
|
|
|
|
|
|
|
|
const URL = process.env.LIGHTTPD
|
2024-06-06 16:57:08 +02:00
|
|
|
? `${PROTOCOL}://${window.location.host}/${process.env.WSPATH || "foris-ws"}`
|
2022-03-23 10:15:00 +01:00
|
|
|
: `${PROTOCOL}://${window.location.hostname}:9081`;
|
2019-08-23 15:20:22 +02:00
|
|
|
|
|
|
|
const WAITING_FOR_CONNECTION_TIMEOUT = 500;
|
|
|
|
|
2024-06-06 16:57:08 +02:00
|
|
|
class WebSockets {
|
2019-08-23 15:20:22 +02:00
|
|
|
constructor() {
|
|
|
|
this.ws = new WebSocket(URL);
|
|
|
|
this.ws.onerror = (e) => {
|
2021-06-14 17:29:33 +02:00
|
|
|
console.error("WS: Error:", e);
|
2019-08-23 15:20:22 +02:00
|
|
|
};
|
|
|
|
this.ws.onmessage = (e) => {
|
2019-12-17 17:45:55 +01:00
|
|
|
console.debug(`WS: Received Message: ${e.data}`);
|
2019-08-23 15:20:22 +02:00
|
|
|
const data = JSON.parse(e.data);
|
|
|
|
this.dispatch(data);
|
|
|
|
};
|
|
|
|
this.ws.onopen = () => {
|
2019-12-17 17:45:55 +01:00
|
|
|
console.debug("WS: Connection open.");
|
2019-08-23 15:20:22 +02:00
|
|
|
};
|
|
|
|
this.ws.onclose = () => {
|
2019-12-17 17:45:55 +01:00
|
|
|
console.debug("WS: Connection closed.");
|
2019-08-23 15:20:22 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
// 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;
|
|
|
|
}
|
|
|
|
|
2019-12-04 17:05:56 +01:00
|
|
|
subscribe(module) {
|
2019-08-23 15:20:22 +02:00
|
|
|
this.waitForConnection(() => {
|
2019-12-04 17:05:56 +01:00
|
|
|
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];
|
2019-12-04 17:05:56 +01:00
|
|
|
} catch (error) {
|
|
|
|
if (error instanceof TypeError) {
|
2020-08-18 15:39:00 +02:00
|
|
|
console.warn(
|
|
|
|
`Callback for this message wasn't found:${error.data}`
|
|
|
|
);
|
2019-12-04 17:05:56 +01:00
|
|
|
} else throw error;
|
2019-08-23 15:20:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof chain === "undefined") return;
|
|
|
|
|
2019-12-04 17:05:56 +01:00
|
|
|
chain.forEach((callback) => callback(json));
|
2019-08-23 15:20:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
close() {
|
|
|
|
this.ws.close();
|
|
|
|
}
|
|
|
|
}
|
2024-06-06 16:57:08 +02:00
|
|
|
|
|
|
|
export default WebSockets;
|