Files
trweb/js/trdom_servermanager.js
Fehér Roland b2f155c0b4 Use EventTarget
Getting torrent info from servers now uses Events
instead of magic callbacks.
2025-10-09 13:08:24 +02:00

92 lines
2.7 KiB
JavaScript

"use strict";
class trdom_servermanager extends EventTarget {
#logcb;
#log(loglevel, msg) {
if (this.#logcb !== null) {
this.#logcb('trdom_servermanager', loglevel, msg);
}
}
#servers = {};
getServers() {
return this.#servers;
}
#registerServer = function(name, initdata) {
let server = new trserver(initdata, function(msg) {this.#logcb(`server:${name}`, 6, msg);}.bind(this));
this.#servers[name] = server;
server.addEventListener('torrent-update', this);
server.refreshTorrentList();
}
#loadcb;
#loadServers() {
let serverjson = this.#loadcb('servers');
this.#servers = {};
if (serverjson == null) {
this.#log(4, 'No saved server data found');
}
else {
let serverdata = JSON.parse(serverjson);
for (const [key, value] of Object.entries(serverdata)) {
this.#registerServer(key, value);
}
this.#log(5, `Loaded ${Object.keys(this.#servers).length} servers`);
}
}
loadServers() {
this.#loadServers();
}
#savecb;
#saveServers() {
let serverdata = {};
for (const [key, value] of Object.entries(this.#servers)) {
serverdata[key] = value.getInstanceData();
}
this.#log(5, `Saving ${Object.keys(serverdata).length} servers`);
this.#savecb('servers', JSON.stringify(serverdata));
}
saveServers() {
this.#saveServers();
}
constructor (loadcb = null, savecb = null, logcb = null, registerServer = null) {
super();
this.#loadcb = loadcb;
this.#savecb = savecb;
this.#logcb = logcb
//this.#registerServer = registerServer;
//this.#servers = this.#loadServers();
}
handleEvent(e) {
this.#log(6, `Handling event of type ${e.type}`);
switch (e.type) {
case 'torrent-update':
for (const [srv, server] of Object.entries(this.#servers)) {
if (e.target == server) {
let newEvent = new CustomEvent('torrent-update', {
'detail': {
'torrentHash': e.detail.torrentHash,
'torrentInfo': e.detail.torrentInfo,
'serverName': srv
}
});
this.dispatchEvent(newEvent);
return;
}
}
this.#log(2, `Got update event for unknown server:\n${JSON.stringify(e.detail)}`);
break;
default:
this.#log(5, `Event type ${e.type} not supported`);
break;
}
}
}