Prepare main branch for v2.0 release

This commit is contained in:
2022-11-09 14:10:46 +01:00
parent d76aac181b
commit fba7cd3d75
11 changed files with 103 additions and 91 deletions

View File

@@ -1,6 +1,6 @@
MIT License
Copyright (c) 2021 Peter van Arkel
Copyright (c) 2022 - Peter van Arkel
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal

View File

@@ -1,33 +1,62 @@
import discord
from discord.ext import commands
from logging import getLogger
import typing
from datetime import timedelta
from discord import User, errors, TextChannel, Forbidden
# setup logging
log = getLogger(__name__)
embed = discord.Embed()
class Admin(commands.Cog):
def __init__(self, bot):
self.bot = bot
@commands.command()
@commands.command(name='purge', hidden=True)
@commands.is_owner()
async def clear(self, ctx, amount=1):
async def purge(self, ctx, amount=1):
""" Purge <n> messages from current channel"""
await ctx.message.delete()
await ctx.channel.purge(limit = amount)
log.warn(f'{ctx.message.author} cleared {amount} messages')
log.warn(f'{ctx.message.author} purged {amount} messages')
@commands.command(name='purge_from', hidden=True)
@commands.is_owner()
async def purge_from(self, ctx, message_id: int):
"""Purge all messages after the given message.id"""
try:
message = await ctx.channel.fetch_message(message_id)
except errors.NotFound:
log.warn(f'{ctx.message.author} tried purging {message_id}, but id was not found.')
return
await ctx.message.delete()
await ctx.channel.purge(after=message)
log.info(f'{ctx.message.author} purged all messages after {message_id}')
return True
@commands.command(name='purge_user', hidden=True)
@commands.is_owner()
async def purge_user(self, ctx, user: User, num_minutes: typing.Optional[int] = 5):
"""Clear all messages of <user.id> in all channels within the last [n=5] minutes"""
after = ctx.message.created_at - timedelta(minutes=num_minutes)
def check(msg):
return msg.author.id == user.id
for channel in await ctx.guild.fetch_channels():
if type(channel) is TextChannel:
try:
await channel.purge(limit=10*num_minutes, check=check, after=after)
log.info(f'{ctx.message.author} purged all messages from {user.id} that were posted within the last {num_minutes}')
except Forbidden:
continue
@commands.Cog.listener()
async def on_ready(self):
log.info(f'module active')
def setup(bot):
bot.add_cog(Admin(bot))
async def setup(bot):
await bot.add_cog(Admin(bot))

View File

@@ -1,52 +0,0 @@
import discord
from discord.ext import commands
from logging import getLogger
import asyncio
# setup logging
log = getLogger(__name__)
e = discord.Embed()
class Flair(commands.Cog):
""" The Flair functionality enables the user to setup flair for their profile.
Currently, the flair-roles available are:
- gender pronouns
- willingness to join mature discussions
- whether or not they are open for DMs
"""
def __init__(self, bot):
self.bot = bot
self.msg1 = ['', '', '']
@commands.command()
async def flair(self, ctx):
msg1 = (
f'Welkom bij de flair-wizard! Gebruik onderstaande opties om verder te gaan. \n\n'
f'Druk op ✅ als je verder wil gaan met de wizard.\n'
f'Als je niet je flair opnieuw wilt instellen, druk dan op ❌.\n'
f'Gebruik ❔ als je wil weten hoe je via een tekstcommando alles kan instellen.\n\n'
)
dm = await ctx.author.send(msg1)
log.info(f'{ctx.author} started the flair wizard')
for emoji in self.msg1:
await dm.add_reaction(emoji)
@commands.Cog.listener()
async def on_ready(self):
log.info(f'module active')
def setup(bot):
bot.add_cog(Flair(bot))
# numbers_reactions = ['1⃣', '2⃣', '3⃣', '4⃣', '5⃣', '6⃣']

View File

@@ -44,5 +44,5 @@ class Games(commands.Cog):
log.info(f'module active')
def setup(bot):
bot.add_cog(Games(bot))
async def setup(bot):
await bot.add_cog(Games(bot))

View File

@@ -63,5 +63,5 @@ class Gif(commands.Cog):
log.info(f'module active')
def setup(bot):
bot.add_cog(Gif(bot))
async def setup(bot):
await bot.add_cog(Gif(bot))

View File

@@ -32,6 +32,6 @@ class Links(commands.Cog):
log.info(f'module active')
def setup(bot):
bot.add_cog(Links(bot))
async def setup(bot):
await bot.add_cog(Links(bot))

View File

@@ -33,5 +33,5 @@ class Misc(commands.Cog):
log.info(f'module active')
def setup(bot):
bot.add_cog(Misc(bot))
async def setup(bot):
await bot.add_cog(Misc(bot))

View File

@@ -22,5 +22,5 @@ class Moderator(commands.Cog):
log.info(f'module active')
def setup(bot):
bot.add_cog(Moderator(bot))
async def setup(bot):
await bot.add_cog(Moderator(bot))

View File

@@ -7,43 +7,44 @@ import os
import log
import logging.config
from logging import getLogger
import asyncio
# setup root logger handlers
logging.config.dictConfig(log.LOGGING)
# setup logging
log = getLogger(__name__)
# setup discord.py bot
intents = discord.Intents().all()
bot = commands.Bot(command_prefix='!', intents=intents)
e = discord.Embed()
@bot.command()
@bot.command(name='load', hidden=True)
@commands.has_permissions(administrator=True)
async def load(ctx, extension):
bot.load_extension(f'cogs.{extension}')
log.info(f'{ctx.message.author} loaded the {extension} module')
@bot.command()
@bot.command(name='unload', hidden=True)
@commands.has_permissions(administrator=True)
async def unload(ctx, extension):
bot.unload_extension(f'cogs.{extension}')
log.info(f'{ctx.message.author} unloaded the {extension} module')
@bot.command()
@bot.command(name='reload', hidden=True)
@commands.has_permissions(administrator=True)
async def reload(ctx, extension):
bot.unload_extension(f'cogs.{extension}')
bot.load_extension(f'cogs.{extension}')
log.info(f'{ctx.message.author} reloaded the {extension} module')
async def load_extensions():
for filename in os.listdir('./cogs'):
if filename.endswith('.py'):
await bot.load_extension(f'cogs.{filename[:-3]}')
@bot.event
async def on_ready():
@@ -51,12 +52,9 @@ async def on_ready():
activity = discord.Activity(name='!help', type=discord.ActivityType.listening)
await bot.change_presence(activity=activity)
async def main():
async with bot:
await load_extensions()
await bot.start(env.TOKEN)
for filename in os.listdir('./cogs'):
if filename.endswith('.py'):
bot.load_extension(f'cogs.{filename[:-3]}')
if __name__ == '__main__':
bot.run(env.TOKEN)
asyncio.run(main())

25
jeevesbot/env.py Normal file
View File

@@ -0,0 +1,25 @@
#!/usr/bin/env python3
### bot settings
# TOKEN = 'ODE5NjMyNDg1MjU5ODA0NzU0.YEpcPA.M-zMGu3BT4QEm9HYKwgiMX3ssEk' #LIVE
TOKEN = 'OTI3NTYyNTIwMTE2NDczODk2.GaZvW-.kmcKCSVrL7Ain4bBufJyZtSSS3Z6rSx7l-cTR0' # TEST
### channels
# GIFCHANNELS = [724331671020765247,729667183126511617,863879394233942016] #LIVE
GIFCHANNELS = [] #TEST
FLAIR_CHANNEL = 873576604419387413
### roles
ADMIN_ROLE = 'administrator'
BINGOROLE = 'babbelbingo'
# 863879394233942016 #overflow-lounge @ LP
# 724331671020765247 #lounge @ LP
# 729667183126511617 #vraag-van-de-dag @ LP
# 749399756752814105 #general @ TEST
# 776789540978556948 #guest @ TEST
# 873576604419387413 #flair @ TEST

12
jeevesbot/secret.json Normal file
View File

@@ -0,0 +1,12 @@
{
"type": "service_account",
"project_id": "drive-pull-300915",
"private_key_id": "7d615dce3c433ae5d3c8553aa823629c2fc4d4f3",
"private_key": "-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDmxvsQLYTZCNIc\nkjRUW+asE/mMeXVIT6UL6JBsOF4Q3D1gRZh/69GOs1H/iJ+ZoqZdduwEQT1xH0TN\no/ERzw7dnZAtMXZXliIxXQV7jkSdQ9Kvyw1SfMVWSB2ZqWC+2nOgT9ztcc+5rNSO\n+A+ZgMejUHS7uKFJ69EJhH6YB4ZXL7w8Ty95EtH2OMaqYFICceSmLT91EftRmP/O\nanNjVgnxnc+P3ppg318pbAiF6DzN5wgbuFw3YgaoH1f23M6wq7/s9tLGAe0l0AnM\nOFDOfNZLA8FyLZaqUh+kTQLEyJsKzhR6wyEC7jrMu2qtfNdYFzXSzza+GUc9pemd\nXRx70LmzAgMBAAECggEAVmG2yjhvmJmPpDgptEXuEw0rBKTV/KorOkjj/k4fD6qQ\nor+KNJ+9ge+nSsIGE4jpQuTntTQCXpx4sYyjCKp7gwKeW/w+ssw0okuSaMw47LDd\nZQXZR74CU6iMw969otK8Iw6hwJMwUOzbZ2R82lV05LGR8E5MuRG23hwlEp0GcQ1s\nIOZBe14rkKoBoDrJy9Kh4GBP8TMPrI8XveMfzpVQogCNUZUODu01p59sKUh4LaIx\npRw7GZx0qvs5Fhf5CBaVMH+vvDsRmNSpVZnEoyTJpA1k7+tTgltSr+nhrPc3iWzB\ntqQ9QvzaCYIjbzVTJrbCptGwKyxw804diyaffa6ykQKBgQD5DcLIKKg/4KEDmMiN\nbBNTg2Tt8lLv9JEqcUm4dkg+vc1bi6T2e2f3Ycu129AVIfGTg3JZxg5jLJDIeZx7\nzf2ctNOYhUS56q6ntxXaCeXNBjKPv/NOqh6cgT+XUk573oeR/vwfbxiICqZ6Jx4G\nfix66rpVjv0YeFRsYGsDGDPvywKBgQDtNrng8m9x4Zsz6IYUOhIoydjLDQUvPtz7\nJDkUfSZYzVftVLu3KTZycmgrleUBIZ5IUrW7ld3zkpmnLNfO5KVruehjYZJyUPhD\ns4capE7FTWJzJWeRa3Y89tyFnydZs1UI7GaXTr+ttBXpIfsRIp0K2Ve7OFmN3+hx\nvC1LbOtQuQKBgBmLgckJ8ofqwFkgGKH4zdqpBXcqfbtC+IjD6e3TpAFbcm7LWfY2\nHinPjBdxHlysiJy6xMXUfLFLZuZJIvXH4RVrrrBcKvpuyc9GBiXBEiL/WbxI0enl\npRIkZ6Nbu9UUtA8TekS3HmsFvKGW1YuQ8XsCDG6uJeOWpAIhuZgtqVYVAoGAOPqS\nP4Q8XMByRU+vFSC1x/JkDrH78tNIxVJ4G4HMOjxoyGs4A9D0cR0mBIIm1dS7bmff\nm0VuYNlv6wYMeHfXfD7VoTmIscjdOXXgF/grq5zg7wOnEvkbF528bqRCEXvQCyqt\nod6akCDXun4dDoqf6kE2n5Pzfu6vqNIolxt8kpECgYEAmlwmccOtFDabchU5rxZJ\ngtqW/w1o86+NQE4o6Oq217YXY68PWoc+UgT2F6R5f6fJ3g8w6/1x2NGHMcte6E9/\n8rJT1L/P7dpdOzYWsN3BWlRhc0ICMslj4Aw7FnA+CL1YWSIp4SML/d6SjHBGkt+l\nVLZ4mr7mDtwPZ883nWw56po=\n-----END PRIVATE KEY-----\n",
"client_email": "drive-pull@drive-pull-300915.iam.gserviceaccount.com",
"client_id": "103799335310944603536",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/drive-pull%40drive-pull-300915.iam.gserviceaccount.com"
}