Files
igncore/core/private_channel_service.py
Minidodo 17c776faec 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)
2021-11-25 14:09:43 +01:00

86 lines
4.2 KiB
Python

from core.aochat import server_packets, client_packets
from core.conn import Conn
from core.decorators import instance
from core.logger import Logger
from core.setting_service import SettingService
@instance()
class PrivateChannelService:
PRIVATE_CHANNEL_MESSAGE_EVENT = "private_channel_message"
JOINED_PRIVATE_CHANNEL_EVENT = "private_channel_joined"
LEFT_PRIVATE_CHANNEL_EVENT = "private_channel_left"
def __init__(self):
self.logger = Logger(__name__)
self.private_channel_chars = {}
def inject(self, registry):
self.bot = registry.get_instance("bot")
self.event_service = registry.get_instance("event_service")
self.character_service = registry.get_instance("character_service")
self.access_service = registry.get_instance("access_service")
self.setting_service: SettingService = registry.get_instance("setting_service")
def pre_start(self):
self.event_service.register_event_type(self.JOINED_PRIVATE_CHANNEL_EVENT)
self.event_service.register_event_type(self.LEFT_PRIVATE_CHANNEL_EVENT)
self.event_service.register_event_type(self.PRIVATE_CHANNEL_MESSAGE_EVENT)
self.bot.register_packet_handler(server_packets.PrivateChannelClientJoined.id,
self.handle_private_channel_client_joined)
self.bot.register_packet_handler(server_packets.PrivateChannelClientLeft.id,
self.handle_private_channel_client_left)
# priority must be above that of CommandService in order for relaying of commands to work correctly
self.bot.register_packet_handler(server_packets.PrivateChannelMessage.id,
self.handle_private_channel_message, priority=30)
self.access_service.register_access_level("guest", 94, self.in_private_channel)
def handle_private_channel_message(self, conn: Conn, packet: server_packets.PrivateChannelMessage):
if conn.id != "main":
return
if self.setting_service.get_value("log_priv") == "1":
char_name = self.character_service.get_char_name(packet.char_id)
self.logger.log_chat(conn, "Private Channel", char_name, packet.message)
if packet.private_channel_id == self.bot.get_char_id():
self.event_service.fire_event(self.PRIVATE_CHANNEL_MESSAGE_EVENT, packet)
def handle_private_channel_client_joined(self, conn: Conn, packet: server_packets.PrivateChannelClientJoined):
if conn.id != "main":
return
if packet.private_channel_id == self.bot.get_char_id():
if self.setting_service.get_value("log_priv") == "1":
char_name = self.character_service.get_char_name(packet.char_id)
self.logger.log_chat(conn, "Private Channel", None, f"{char_name} joined the channel.")
self.private_channel_chars[packet.char_id] = packet
self.event_service.fire_event(self.JOINED_PRIVATE_CHANNEL_EVENT, packet)
def handle_private_channel_client_left(self, conn: Conn, packet: server_packets.PrivateChannelClientLeft):
if conn.id != "main":
return
if packet.private_channel_id == self.bot.get_char_id():
if self.setting_service.get_value("log_priv") == "1":
char_name = self.character_service.get_char_name(packet.char_id)
self.logger.log_chat(conn, "Private Channel", None, f"{char_name} left the channel.")
del self.private_channel_chars[packet.char_id]
self.event_service.fire_event(self.LEFT_PRIVATE_CHANNEL_EVENT, packet)
def invite(self, char_id):
if char_id != self.bot.get_char_id():
self.bot.send_packet(client_packets.PrivateChannelInvite(char_id))
def kick(self, char_id):
if char_id != self.bot.get_char_id() and char_id in self.private_channel_chars:
self.bot.send_packet(client_packets.PrivateChannelKick(char_id))
def kickall(self):
self.bot.send_packet(client_packets.PrivateChannelKickAll())
def in_private_channel(self, char_id):
return char_id in self.private_channel_chars
def get_all_in_private_channel(self):
return self.private_channel_chars