Files
discord-jeeves/jeeves.py

92 lines
3.8 KiB
Python
Raw Normal View History

2021-06-06 22:08:18 +02:00
#!/usr/bin/env python3
import discord
from discord.ext import commands
import logging
from jeevesbot import bothelp, functions, env
2021-06-08 21:06:15 +02:00
import gspread
from oauth2client.service_account import ServiceAccountCredentials
import asyncio
2021-06-06 22:08:18 +02:00
# setup logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger('jeeves')
logger.setLevel(logging.INFO)
handler = logging.FileHandler(filename='jeeves.log', encoding='utf-8', mode='a')
handler.setFormatter(logging.Formatter('%(asctime)s:%(levelname)s:%(name)s: %(message)s'))
logger.addHandler(handler)
# setup discord.py
client = discord.Client()
e = discord.Embed()
2021-06-08 21:06:15 +02:00
# setup gspread
scope = ['https://www.googleapis.com/auth/spreadsheets', 'https://www.googleapis.com/auth/drive']
2021-06-13 14:01:23 +02:00
# creds = ServiceAccountCredentials.from_json_keyfile_name('jeevesbot/secret.json', scope)
# gclient = gspread.authorize(creds)
2021-06-06 22:08:18 +02:00
@client.event
async def on_message(message):
# we do not want the bot to reply to itself
if message.author == client.user:
return
if message.content.startswith('!help'):
parameters = message.content.split(' ', 1)
if len(parameters) == 2:
2021-06-15 00:43:38 +02:00
msg = bothelp.help(parameters[1])
2021-06-06 22:08:18 +02:00
else:
2021-06-15 00:43:38 +02:00
msg = bothelp.help()
2021-06-06 22:08:18 +02:00
await message.author.send(msg)
logline = (str(message.author) + ' requested help')
logger.info(logline)
2021-06-06 22:08:18 +02:00
# giphy and tenor both have different structures to their links
if message.content.startswith('https://tenor.com/'):
roles = functions.checkrole(message.author.roles)
channel = functions.checkchannel(message.channel.id)
embed_url = message.content
follow_url = embed_url + '.gif'
2021-06-13 14:01:23 +02:00
full_url = await functions.resolve(follow_url)
2021-06-06 22:08:18 +02:00
gif_url = full_url.split('?')[0]
embed = e.set_image(url=gif_url)
if channel is True:
if roles is not True:
await message.channel.send(embed=embed)
logline = (str(message.author) + ' requested a gif: ' + str(gif_url))
logger.info(logline)
2021-06-12 16:55:13 +02:00
if message.content.startswith('https://c.tenor.com/'):
roles = functions.checkrole(message.author.roles)
channel = functions.checkchannel(message.channel.id)
embed_url = message.content
embed = e.set_image(url=embed_url)
if channel is True:
if roles is not True:
await message.channel.send(embed=embed)
logline = (str(message.author) + ' requested a gif: ' + str(embed_url))
logger.info(logline)
2021-06-06 22:08:18 +02:00
if message.content.startswith('https://giphy.com/'):
roles = functions.checkrole(message.author.roles)
channel = functions.checkchannel(message.channel.id)
embed_url = message.content
image_code = embed_url.split('-')[-1]
gif_url = 'https://media.giphy.com/media/' + image_code + '/giphy.gif'
embed = e.set_image(url=gif_url)
if channel is True:
if roles is not True:
await message.channel.send(embed=embed)
logline = (str(message.author) + ' requested a gif: ' + str(gif_url))
logger.info(logline)
2021-06-06 22:08:18 +02:00
if message.content.startswith('!roll'):
parameters = message.content.split(' ', 1)
if len(parameters) == 2:
param = parameters[1]
roll,result = functions.roll(param)
msg = 'Rolling %s for {0.author.mention}: `%s`'.format(message) % (param,roll)
await message.channel.send(msg)
@client.event
async def on_ready():
print('### Active with id %s as %s ###' % (client.user.id,client.user.name) )
2021-06-15 00:46:44 +02:00
activity = discord.Activity(name='!help', type=discord.ActivityType.listening)
2021-06-15 00:43:38 +02:00
await client.change_presence(activity=activity)
2021-06-06 22:08:18 +02:00
if __name__ == '__main__':
client.run(env.TOKEN)