update admin.py to use command spec (and not docstrings)

This commit is contained in:
jesopo 2020-02-07 10:36:25 +00:00
parent 29fdc3ce53
commit a19f6304c5

View file

@ -4,27 +4,22 @@
from src import IRCLine, ModuleManager, utils from src import IRCLine, ModuleManager, utils
class Module(ModuleManager.BaseModule): class Module(ModuleManager.BaseModule):
@utils.hook("received.command.nick", min_args=1) @utils.hook("received.command.nick")
@utils.kwarg("help", "Change my nickname")
@utils.kwarg("permission", "changenickname")
@utils.spec("!<nickname>word")
def change_nickname(self, event): def change_nickname(self, event):
""" event["server"].send_nick(event["spec"][0])
:help: Change my nickname
:usage: <nickname>
:permission: changenickname
"""
nickname = event["args_split"][0]
event["server"].send_nick(nickname)
@utils.hook("received.command.raw", min_args=1) @utils.hook("received.command.raw")
@utils.kwarg("help", "Send a line of raw IRC data")
@utils.kwarg("permission", "raw")
@utils.spec("!<line>string")
def raw(self, event): def raw(self, event):
""" if IRCLine.is_human(event["spec"][0]):
:help: Send a line of raw IRC data line = IRCLine.parse_human(event["spec"][0])
:usage: <raw line>
:permission: raw
"""
if IRCLine.is_human(event["args"]):
line = IRCLine.parse_human(event["args"])
else: else:
line = IRCLine.parse_line(event["args"]) line = IRCLine.parse_line(event["spec"][0])
line = event["server"].send(line) line = event["server"].send(line)
if not line == None: if not line == None:
@ -34,22 +29,12 @@ class Module(ModuleManager.BaseModule):
@utils.hook("received.command.part") @utils.hook("received.command.part")
@utils.kwarg("help", "Part from the current or given channel") @utils.kwarg("help", "Part from the current or given channel")
@utils.kwarg("usage", "[channel]") @utils.kwarg("permission", "part")
@utils.kwarg("require_mode", "high")
@utils.kwarg("require_access", "high,part")
@utils.spec("!r~channel")
def part(self, event): def part(self, event):
check = utils.Check("permission", "part") event["server"].send_part(event["spec"][0].name)
if event["args"]:
target = event["args_split"][0]
elif event["is_channel"]:
target = event["target"].name
check |= utils.Check("channel-mode", "high")
check |= utils.Check("channel-access", "high,part")
else:
event["stderr"].write("No channel provided")
event["check_assert"](check)
event["server"].send_part(target)
def _id_from_alias(self, alias): def _id_from_alias(self, alias):
return self.bot.database.servers.get_by_alias(alias) return self.bot.database.servers.get_by_alias(alias)
@ -63,15 +48,11 @@ class Module(ModuleManager.BaseModule):
return id, self.bot.get_server_by_id(id) return id, self.bot.get_server_by_id(id)
@utils.hook("received.command.reconnect") @utils.hook("received.command.reconnect")
@utils.kwarg("help", "Reconnect to the current, or provided, server")
@utils.kwarg("permission", "reconnect")
@utils.spec("?<server>word")
def reconnect(self, event): def reconnect(self, event):
""" alias = event["spec"][0] or str(event["server"])
:help: Reconnect to the current network
:permission: reconnect
"""
server = event["server"]
alias = str(event["server"])
if event["args"]:
alias = event["args_split"][0]
server = self._server_from_alias(alias) server = self._server_from_alias(alias)
if server: if server:
@ -84,13 +65,11 @@ class Module(ModuleManager.BaseModule):
event["stdout"].write("Not connected to %s" % alias) event["stdout"].write("Not connected to %s" % alias)
@utils.hook("received.command.connect", min_args=1) @utils.hook("received.command.connect", min_args=1)
@utils.kwarg("help", "Connect to a given server")
@utils.kwarg("permission", "connect")
@utils.spec("!<server>word")
def connect(self, event): def connect(self, event):
""" alias = event["spec"][0]
:help: Connect to a network
:usage: <server id>
:permission: connect
"""
alias = event["args_split"][0]
server = self._server_from_alias(alias) server = self._server_from_alias(alias)
if server: if server:
raise utils.EventError("Already connected to %s" % str(server)) raise utils.EventError("Already connected to %s" % str(server))
@ -99,21 +78,14 @@ class Module(ModuleManager.BaseModule):
event["stdout"].write("Connecting to %s" % str(server)) event["stdout"].write("Connecting to %s" % str(server))
@utils.hook("received.command.disconnect") @utils.hook("received.command.disconnect")
@utils.kwarg("help", "Disconnect from the current or provided server")
@utils.kwarg("permission", "disconnect")
@utils.spec("?<server>word")
def disconnect(self, event): def disconnect(self, event):
""" alias = event["spec"][0] or str(event["server"])
:help: Disconnect from a server
:usage: [server id]
:permission: disconnect
"""
server = event["server"]
id = -1
alias = str(event["server"])
if event["args"]:
alias = event["args_split"][0]
id, server = self._both_from_alias(alias) id, server = self._both_from_alias(alias)
if not server == None: if not server == None:
alias = str(server)
server.disconnect() server.disconnect()
self.bot.disconnect(server) self.bot.disconnect(server)
elif id in self.bot.reconnections: elif id in self.bot.reconnections:
@ -122,16 +94,15 @@ class Module(ModuleManager.BaseModule):
else: else:
raise utils.EventError("Server not connected") raise utils.EventError("Server not connected")
if not server == event["server"]:
event["stdout"].write("Disconnected from %s" % alias) event["stdout"].write("Disconnected from %s" % alias)
@utils.hook("received.command.shutdown") @utils.hook("received.command.shutdown")
@utils.kwarg("help", "Shutdown the bot")
@utils.kwarg("permission", "shutdown")
@utils.spec("?<reason>string")
def shutdown(self, event): def shutdown(self, event):
""" reason = event["spec"][0] or "Shutting down"
:help: Shutdown bot
:usage: [reason]
:permission: shutdown
"""
reason = event["args"] or ""
for server in self.bot.servers.values(): for server in self.bot.servers.values():
line = server.send_quit(reason) line = server.send_quit(reason)
line.events.on("send").hook(self._shutdown_hook(server)) line.events.on("send").hook(self._shutdown_hook(server))
@ -141,15 +112,14 @@ class Module(ModuleManager.BaseModule):
self.bot.disconnect(server) self.bot.disconnect(server)
return shutdown return shutdown
@utils.hook("received.command.addserver", min_args=3) @utils.hook("received.command.addserver")
@utils.kwarg("help", "Add a new server")
@utils.kwarg("pemission", "addserver")
@utils.spec(
"!<alias>word !<hostname:port>word !<nickname!username@bindhost>word")
def add_server(self, event): def add_server(self, event):
""" alias = event["spec"][0]
:help: Add a new server hostname, sep, port = event["spec"][1].partition(":")
:usage: <alias> <hostname>:[+]<port> <nickname>!<username>[@<bindhost>]
:permission: addserver
"""
alias = event["args_split"][0]
hostname, sep, port = event["args_split"][1].partition(":")
tls = port.startswith("+") tls = port.startswith("+")
port = port.lstrip("+") port = port.lstrip("+")
@ -157,7 +127,7 @@ class Module(ModuleManager.BaseModule):
raise utils.EventError("Please provide <hostname>:[+]<port>") raise utils.EventError("Please provide <hostname>:[+]<port>")
port = int(port) port = int(port)
hostmask = IRCLine.parse_hostmask(event["args_split"][2]) hostmask = IRCLine.parse_hostmask(event["spec"][2])
nickname = hostmask.nickname nickname = hostmask.nickname
username = hostmask.username or nickname username = hostmask.username or nickname
realname = nickname realname = nickname
@ -174,18 +144,17 @@ class Module(ModuleManager.BaseModule):
event["stdout"].write("Added server '%s'" % alias) event["stdout"].write("Added server '%s'" % alias)
@utils.hook("received.command.editserver") @utils.hook("received.command.editserver")
@utils.kwarg("min_args", 3)
@utils.kwarg("help", "Edit server details") @utils.kwarg("help", "Edit server details")
@utils.kwarg("usage", "<alias> <option> <value>")
@utils.kwarg("permission", "editserver") @utils.kwarg("permission", "editserver")
@utils.spec("!<alias>word !<option>word !<value>string")
def edit_server(self, event): def edit_server(self, event):
alias = event["args_split"][0] alias = event["spec"][0]
server_id = self._id_from_alias(alias) server_id = self._id_from_alias(alias)
if server_id == None: if server_id == None:
raise utils.EventError("Unknown server '%s'" % alias) raise utils.EventError("Unknown server '%s'" % alias)
option = event["args_split"][1].lower() option = event["spec"][1].lower()
value = " ".join(event["args_split"][2:]) value = " ".join(event["spec"][2])
value_parsed = None value_parsed = None
if option == "hostname": if option == "hostname":