2019-05-25 20:40:06 +00:00
|
|
|
#--depends-on commands
|
|
|
|
|
2016-05-09 15:14:12 +00:00
|
|
|
import time
|
2018-10-03 12:22:37 +00:00
|
|
|
from src import ModuleManager, utils
|
2016-05-09 15:14:12 +00:00
|
|
|
|
2018-09-27 10:46:10 +00:00
|
|
|
class Module(ModuleManager.BaseModule):
|
2018-10-04 15:01:13 +00:00
|
|
|
def _uptime(self):
|
|
|
|
return utils.to_pretty_time(int(time.time()-self.bot.start_time))
|
|
|
|
|
2018-10-03 12:22:37 +00:00
|
|
|
@utils.hook("received.command.uptime")
|
2016-05-09 15:14:12 +00:00
|
|
|
def uptime(self, event):
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2018-09-30 16:29:09 +00:00
|
|
|
:help: Show my uptime
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2018-10-04 15:01:13 +00:00
|
|
|
event["stdout"].write("Uptime: %s" % self._uptime())
|
2018-10-05 21:49:06 +00:00
|
|
|
@utils.hook("api.get.uptime")
|
2018-10-04 15:01:13 +00:00
|
|
|
def uptime_api(self, event):
|
|
|
|
return self._uptime()
|
2016-05-09 15:14:12 +00:00
|
|
|
|
2018-10-04 15:01:13 +00:00
|
|
|
def _stats(self):
|
2016-05-09 15:14:12 +00:00
|
|
|
networks = len(self.bot.servers)
|
|
|
|
channels = 0
|
|
|
|
users = 0
|
|
|
|
for server in self.bot.servers.values():
|
|
|
|
channels += len(server.channels)
|
|
|
|
users += len(server.users)
|
2018-10-04 15:01:13 +00:00
|
|
|
return [networks, channels, users]
|
2016-05-09 15:14:12 +00:00
|
|
|
|
2018-10-04 15:01:13 +00:00
|
|
|
@utils.hook("received.command.stats")
|
|
|
|
def stats(self, event):
|
|
|
|
"""
|
|
|
|
:help: Show my network/channel/user stats
|
|
|
|
"""
|
|
|
|
networks, channels, users = self._stats()
|
2016-05-09 15:14:12 +00:00
|
|
|
|
|
|
|
response = "I currently have %d network" % networks
|
|
|
|
if networks > 1:
|
|
|
|
response += "s"
|
|
|
|
response += ", %d channel" % channels
|
|
|
|
if channels > 1:
|
|
|
|
response += "s"
|
|
|
|
response += " and %d visible user" % users
|
|
|
|
if users > 1:
|
|
|
|
response += "s"
|
|
|
|
|
|
|
|
event["stdout"].write(response)
|
2018-10-04 15:01:13 +00:00
|
|
|
|
2018-10-05 21:49:06 +00:00
|
|
|
@utils.hook("api.get.stats")
|
2018-10-04 15:01:13 +00:00
|
|
|
def stats_api(self, event):
|
|
|
|
networks, channels, users = self._stats()
|
|
|
|
return {"networks": networks, "channels": channels, "users": users}
|
2018-10-04 16:10:15 +00:00
|
|
|
|
2018-10-05 08:51:17 +00:00
|
|
|
def _server_stats(self, server):
|
2019-05-24 16:36:20 +00:00
|
|
|
connected_seconds = time.time()-server.socket.connect_time
|
2018-10-05 08:51:17 +00:00
|
|
|
return {
|
2018-11-11 08:47:21 +00:00
|
|
|
"hostname": server.connection_params.hostname,
|
|
|
|
"port": server.connection_params.port,
|
|
|
|
"tls": server.connection_params.tls,
|
|
|
|
"alias": server.connection_params.alias,
|
2018-10-05 08:51:17 +00:00
|
|
|
"hostmask": "%s!%s@%s" % (
|
|
|
|
server.nickname, server.username, server.hostname),
|
2018-11-11 08:44:46 +00:00
|
|
|
"users": len(server.users),
|
2019-02-11 18:26:16 +00:00
|
|
|
"bytes-written": server.socket.bytes_written,
|
2019-05-24 16:32:59 +00:00
|
|
|
"bytes-written-per-second":
|
|
|
|
server.socket.bytes_written/connected_seconds,
|
2019-02-11 18:26:16 +00:00
|
|
|
"bytes-read": server.socket.bytes_read,
|
2019-05-24 16:32:59 +00:00
|
|
|
"bytes-read-per-second": server.socket.bytes_read/connected_seconds,
|
2018-11-27 13:24:38 +00:00
|
|
|
"channels": {
|
2019-02-08 17:56:13 +00:00
|
|
|
c.name: self._channel_stats(c) for c in server.channels
|
|
|
|
},
|
2019-05-15 16:13:05 +00:00
|
|
|
"capabilities": list(server.agreed_capabilities),
|
|
|
|
"version": server.version
|
2018-10-05 08:51:17 +00:00
|
|
|
}
|
|
|
|
|
2018-10-05 21:49:06 +00:00
|
|
|
@utils.hook("api.get.servers")
|
2018-10-04 16:18:40 +00:00
|
|
|
def servers_api(self, event):
|
2018-10-05 08:51:17 +00:00
|
|
|
if event["path"]:
|
|
|
|
server_id = event["path"][0]
|
|
|
|
if not server_id.isdigit():
|
|
|
|
return None
|
|
|
|
server_id = int(server_id)
|
|
|
|
|
2019-04-24 11:07:30 +00:00
|
|
|
server = self.bot.get_server_by_id(server_id)
|
2018-10-05 08:51:17 +00:00
|
|
|
if not server:
|
|
|
|
return None
|
|
|
|
return self._server_stats(server)
|
|
|
|
else:
|
|
|
|
servers = {}
|
|
|
|
for server in self.bot.servers.values():
|
|
|
|
servers[server.id] = self._server_stats(server)
|
|
|
|
return servers
|
2018-10-04 16:18:40 +00:00
|
|
|
|
2018-10-04 16:37:34 +00:00
|
|
|
def _channel_stats(self, channel):
|
|
|
|
return {
|
2018-12-26 23:24:43 +00:00
|
|
|
"users": sorted([user.nickname for user in channel.users],
|
|
|
|
key=lambda nickname: nickname.lower()),
|
2018-10-05 08:46:03 +00:00
|
|
|
"topic": channel.topic,
|
|
|
|
"topic-set-at": channel.topic_time,
|
2019-06-13 10:54:13 +00:00
|
|
|
"topic-set-by": channel.topic_setter_nickname,
|
|
|
|
"modes": channel.mode_str()
|
2018-10-04 16:37:34 +00:00
|
|
|
}
|
2018-10-05 21:49:06 +00:00
|
|
|
@utils.hook("api.get.channels")
|
2018-10-04 16:10:15 +00:00
|
|
|
def channels_api(self, event):
|
2018-10-04 16:21:40 +00:00
|
|
|
if event["path"]:
|
|
|
|
server_id = event["path"][0]
|
2018-10-04 16:10:15 +00:00
|
|
|
if not server_id.isdigit():
|
|
|
|
return None
|
|
|
|
server_id = int(server_id)
|
|
|
|
|
2019-04-24 11:07:30 +00:00
|
|
|
server = self.bot.get_server_by_id(server_id)
|
2018-10-04 16:10:15 +00:00
|
|
|
if not server:
|
|
|
|
return None
|
|
|
|
channels = {}
|
|
|
|
for channel in server.channels.values():
|
2018-10-04 16:37:34 +00:00
|
|
|
channels[channel.name] = self._channel_stats(channel)
|
2018-10-04 16:10:15 +00:00
|
|
|
return channels
|
|
|
|
else:
|
|
|
|
channels = {}
|
|
|
|
for server in self.bot.servers.values():
|
|
|
|
channels[server.id] = {}
|
|
|
|
for channel in server.channels.values():
|
2018-10-04 16:37:34 +00:00
|
|
|
channels[server.id][str(channel)] = self._channel_stats(
|
|
|
|
channel)
|
2018-10-04 16:10:15 +00:00
|
|
|
return channels
|
2018-10-04 16:37:47 +00:00
|
|
|
|
2018-10-05 21:49:06 +00:00
|
|
|
@utils.hook("api.get.modules")
|
2018-10-04 16:37:47 +00:00
|
|
|
def modules_api(self, event):
|
|
|
|
return list(self.bot.modules.modules.keys())
|
2018-11-08 22:28:32 +00:00
|
|
|
|
2018-11-08 22:30:06 +00:00
|
|
|
@utils.hook("received.command.caps")
|
2018-11-08 22:28:32 +00:00
|
|
|
def capabilities(self, event):
|
|
|
|
"""
|
|
|
|
:help: List negotiated IRCv3 capabilities
|
|
|
|
"""
|
|
|
|
event["stdout"].write("IRCv3 capabilities: %s" %
|
2019-02-16 09:12:43 +00:00
|
|
|
", ".join(event["server"].agreed_capabilities))
|