"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; } } }