1
0
Fork 0
mirror of synced 2024-05-29 16:59:42 +12:00
Bonfire/cogs/events.py

118 lines
3.5 KiB
Python
Raw Normal View History

from utils import config
import aiohttp
import logging
import json
2017-05-09 09:54:24 +12:00
import discord
log = logging.getLogger()
2018-05-24 17:09:42 +12:00
discord_bots_url = 'https://bots.discord.pw/api/bots/{}/stats'
discordbots_url = "https://discordbots.org/api/bots/{}/stats"
2016-08-19 13:56:41 +12:00
carbonitex_url = 'https://www.carbonitex.net/discord/data/botdata.php'
2016-08-07 10:20:23 +12:00
class StatsUpdate:
2018-05-24 17:09:42 +12:00
"""This is used purely to update stats information for the bot sites"""
2016-08-07 10:20:23 +12:00
def __init__(self, bot):
self.bot = bot
self.session = aiohttp.ClientSession()
2016-08-07 10:20:23 +12:00
def __unload(self):
self.bot.loop.create_task(self.session.close())
async def update(self):
2017-03-08 12:56:24 +13:00
server_count = len(self.bot.guilds)
2018-05-24 17:09:42 +12:00
# Carbonitex request
2016-08-19 13:56:41 +12:00
carbon_payload = {
'key': config.carbon_key,
'servercount': server_count
2016-08-19 13:56:41 +12:00
}
async with self.session.post(carbonitex_url, data=carbon_payload) as resp:
log.info('Carbonitex statistics returned {} for {}'.format(resp.status, carbon_payload))
2016-10-31 17:32:33 +13:00
2018-05-24 17:09:42 +12:00
# Discord.bots.pw request
payload = json.dumps({
'server_count': server_count
})
headers = {
'authorization': config.discord_bots_key,
'content-type': 'application/json'
}
2018-05-24 17:09:42 +12:00
url = discord_bots_url.format(self.bot.user.id)
async with self.session.post(url, data=payload, headers=headers) as resp:
2016-08-19 13:56:41 +12:00
log.info('bots.discord.pw statistics returned {} for {}'.format(resp.status, payload))
2016-08-07 10:20:23 +12:00
2018-05-24 17:09:42 +12:00
# discordbots.com request
url = discordbots_url.format(self.bot.user.id)
payload = {
"server_count": server_count
}
headers = {
"Authorization": config.discordbots_key
}
async with self.session.post(url, data=payload, headers=headers) as resp:
log.info('discordbots.com statistics retruned {} for {}'.format(resp.status, payload))
2017-06-07 20:30:19 +12:00
async def on_guild_join(self, _):
await self.update()
2017-06-07 20:30:19 +12:00
async def on_guild_leave(self, _):
await self.update()
async def on_ready(self):
await self.update()
2016-10-31 17:32:33 +13:00
async def on_member_join(self, member):
2019-01-28 15:58:39 +13:00
query = """
SELECT
COALESCE(welcome_alerts, default_alerts) AS channel,
welcome_msg AS msg
FROM
guilds
WHERE
welcome_notifications = True
AND
id = $1
AND
COALESCE(welcome_alerts, default_alerts) IS NOT NULL
"""
settings = await self.bot.db.fetchrow(query, member.guild.id)
message = settings['msg'] or "Welcome to the '{server}' server {member}!"
channel = member.guild.get_channel(settings['channel'])
2017-04-09 14:51:39 +12:00
try:
2019-01-28 15:58:39 +13:00
await channel.send(message.format(server=member.guild.name, member=member.mention))
2017-08-01 13:39:10 +12:00
except (discord.Forbidden, discord.HTTPException, AttributeError):
2017-04-09 14:51:39 +12:00
pass
2016-10-31 17:32:33 +13:00
async def on_member_remove(self, member):
2019-01-28 15:58:39 +13:00
query = """
SELECT
COALESCE(goodbye_alerts, default_alerts) AS channel,
goodbye_msg AS msg
FROM
guilds
WHERE
welcome_notifications = True
AND
id = $1
AND
COALESCE(goodbye_alerts, default_alerts) IS NOT NULL
"""
settings = await self.bot.db.fetchrow(query, member.guild.id)
message = settings['msg'] or "{member} has left the server, I hope it wasn't because of something I said :c"
channel = member.guild.get_channel(settings['channel'])
2017-04-09 14:51:39 +12:00
try:
2019-01-28 15:58:39 +13:00
await channel.send(message.format(server=member.guild.name, member=member.mention))
2017-08-01 13:39:10 +12:00
except (discord.Forbidden, discord.HTTPException, AttributeError):
2017-04-09 14:51:39 +12:00
pass
2016-10-31 17:32:33 +13:00
2016-08-07 10:20:23 +12:00
def setup(bot):
bot.add_cog(StatsUpdate(bot))