Fixed:
-> !wants -> !orgs info -> special cmd's -> !assist -> "afk" for players without active account -> !loot add <item_ref> <count> => nolonger breaks !account Changes: -> grouped !tara, !gaunt, .. into !wb -> Display the most recent news entry on logon (default: enabled) -> improved grouping of !items -> Added the option to authentificate WS connections (Datanet module). This is used in special cases, where the Websocket Server requires the clien tto authentificate itself. (Server sends "#auth", client responds with the auth string) -> Add main name to relaying (priv <-> org) [default: disabled] -> Added logon/logoff messages back -> restricted default access to "dangerous" commands to moderator -> Added optional logging (Private Channel, Org Channel, Tells, ... disabled by default) Rewrite of the Tower Module. -> More verbosity, if enabled in config. by default, GAS and Hot timer only. -> !hot displays currently hot (and in penalty) sites, and these which go hot in < 60 minutes -> !attacks filterable by PF and Site -> display current contract QL's grouped by org: !contracts (requires managed cache)
This commit is contained in:
@@ -6,7 +6,7 @@ from core.decorators import instance, timerevent
|
||||
from core.event_service import EventService
|
||||
from core.logger import Logger
|
||||
from core.setting_service import SettingService
|
||||
from core.setting_types import TextSettingType
|
||||
from core.setting_types import TextSettingType, HiddenSettingType
|
||||
from modules.standard.datanet.ws_worker import WebsocketRelayWorker
|
||||
|
||||
|
||||
@@ -37,10 +37,16 @@ class WebsocketRelayController(BaseModule):
|
||||
def pre_start(self):
|
||||
self.event_service.register_event_type(self.WS_RELAY)
|
||||
self.setting_service.register(self.module_name,
|
||||
'relay_address',
|
||||
'ws://localhost:25500',
|
||||
'relay_address',
|
||||
'ws://localhost:25500',
|
||||
TextSettingType([], allow_empty=True),
|
||||
"relay for timers, tower info, ...")
|
||||
"relay for timers, tower info, ...")
|
||||
|
||||
self.setting_service.register(self.module_name,
|
||||
'datanet_auth',
|
||||
'',
|
||||
HiddenSettingType([], allow_empty=True),
|
||||
"Auth Challenge response")
|
||||
|
||||
@timerevent(budatime="1s", description="Relay messages from Data relay to the internal message hub",
|
||||
is_hidden=True)
|
||||
@@ -48,8 +54,6 @@ class WebsocketRelayController(BaseModule):
|
||||
while self.queue:
|
||||
obj = self.queue.pop(0)
|
||||
self.event_service.fire_event(self.WS_RELAY, obj)
|
||||
if obj.type == "connected":
|
||||
self.send_relay_message('join', f"{self.bot.name}")
|
||||
|
||||
@timerevent(budatime="1m", description="Ensure the bot is connected to Data relay", is_hidden=True,
|
||||
run_at_startup=True)
|
||||
@@ -68,7 +72,8 @@ class WebsocketRelayController(BaseModule):
|
||||
|
||||
def connect(self):
|
||||
self.disconnect()
|
||||
self.worker = WebsocketRelayWorker(self.queue, self.setting_service.get_value("relay_address"), False)
|
||||
self.worker = WebsocketRelayWorker(self.queue, self.setting_service.get_value("relay_address"),
|
||||
self.setting_service.get_value("datanet_auth"))
|
||||
self.dthread = threading.Thread(target=self.worker.run, daemon=True)
|
||||
self.dthread.start()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user