1
0
Fork 0
mirror of https://github.com/myned/modufur.git synced 2025-01-20 06:35:20 +00:00
modufur/src/main/run.py

188 lines
7.7 KiB
Python
Raw Normal View History

2017-09-24 14:09:02 -04:00
import asyncio
2017-11-19 23:18:05 -05:00
from datetime import datetime as dt
import json
2017-11-19 22:59:37 -05:00
import logging as log
2017-10-02 17:29:39 -04:00
import subprocess
import sys
import traceback as tb
from contextlib import suppress
2017-10-21 16:40:06 -04:00
from pprint import pprint
2017-11-19 23:18:05 -05:00
from hurry.filesize import size, alternative
from urllib.parse import urlparse
import discord as d
from discord import errors as err
2017-09-24 14:09:02 -04:00
from discord import utils
from discord.ext import commands
from discord.ext.commands import errors as errext
2017-09-24 14:09:02 -04:00
from misc import exceptions as exc
from misc import checks
from utils import utils as u
2017-09-24 14:09:02 -04:00
2017-11-19 22:59:37 -05:00
log.basicConfig(level=log.WARNING)
2017-11-06 23:51:07 -05:00
class HelpFormatter(commands.HelpFormatter):
async def format():
pass
2017-10-20 16:16:05 -04:00
def get_prefix(bot, message):
if isinstance(message.guild, d.Guild) and message.guild.id in u.settings['prefixes']:
return u.settings['prefixes'][message.guild.id]
return u.config['prefix']
2017-11-06 23:51:07 -05:00
help_formatter = HelpFormatter(show_check_failure=True)
bot = commands.Bot(command_prefix=get_prefix, formatter=help_formatter, description='Experimental miscellaneous bot')
2017-10-13 23:38:58 -04:00
# Send and print ready message to #testing and console after logon
2017-10-20 16:17:16 -04:00
2017-09-24 11:05:28 -04:00
@bot.event
async def on_ready():
2017-10-20 16:16:05 -04:00
from cogs import booru, info, management, owner, tools
2017-10-13 23:59:14 -04:00
2017-10-20 16:17:16 -04:00
for cog in (tools.Utils(bot), owner.Bot(bot), owner.Tools(bot), management.Administration(bot), info.Info(bot), booru.MsG(bot)):
bot.add_cog(cog)
print(f'COG : {type(cog).__name__}')
2017-10-20 16:16:05 -04:00
# bot.loop.create_task(u.clear(booru.temp_urls, 30*60))
2017-10-20 16:19:58 -04:00
if u.config['playing'] is not 'None':
await bot.change_presence(game=d.Game(name=u.config['playing']))
else:
await bot.change_presence(game=None)
2017-10-16 14:07:10 -04:00
2017-10-31 16:13:54 -04:00
print('\n> > > > > > > > >\nC O N N E C T E D : {}\n> > > > > > > > >\n'.format(bot.user.name))
await bot.get_channel(u.config['info_channel']).send('**Started** \N{BLACK SUN WITH RAYS} .')
2017-10-20 16:19:58 -04:00
# u.notify('C O N N E C T E D')
if u.temp:
channel = bot.get_channel(u.temp['startup_chan'])
message = await channel.get_message(u.temp['startup_msg'])
await message.add_reaction('\N{WHITE HEAVY CHECK MARK}')
2017-10-20 16:19:58 -04:00
u.temp.clear()
2017-09-24 11:05:28 -04:00
@bot.event
async def on_message(message):
2017-10-29 17:54:50 -04:00
if message.author is not bot.user:
await bot.process_commands(message)
@bot.event
async def on_error(error, *args, **kwargs):
print('\n! ! ! ! !\nE R R O R : {}\n! ! ! ! !\n'.format(error), file=sys.stderr)
tb.print_exc()
2017-11-19 23:01:06 -05:00
await bot.get_user(u.config['owner_id']).send('**ERROR** \N{WARNING SIGN}\n```\n{}```'.format(error))
await bot.get_channel(u.config['info_channel']).send('**ERROR** \N{WARNING SIGN}\n```\n{}```'.format(error))
2017-10-20 16:19:58 -04:00
if u.temp:
channel = bot.get_channel(u.temp['startup_chan'])
message = await channel.get_message(u.temp['startup_msg'])
await message.add_reaction('\N{WARNING SIGN}')
2017-10-20 16:19:58 -04:00
u.temp.clear()
# u.notify('E R R O R')
await bot.logout()
u.close(bot.loop)
@bot.event
async def on_command_error(ctx, error):
if isinstance(error, err.NotFound):
pass
elif isinstance(error, errext.CheckFailure):
await ctx.send('**Insufficient permissions**', delete_after=10)
await ctx.message.add_reaction('\N{NO ENTRY}')
2017-10-20 16:19:58 -04:00
elif isinstance(error, errext.CommandNotFound):
print('INVALID COMMAND : {}'.format(error), file=sys.stderr)
await ctx.message.add_reaction('\N{BLACK QUESTION MARK ORNAMENT}')
2017-10-20 16:19:58 -04:00
else:
print('\n! ! ! ! ! ! ! ! ! ! ! !\nC O M M A N D E R R O R : {}\n! ! ! ! ! ! ! ! ! ! ! !\n'.format(
error), file=sys.stderr)
tb.print_exception(type(error), error, error.__traceback__, file=sys.stderr)
2017-11-08 22:32:28 -05:00
await bot.get_user(u.config['owner_id']).send('**COMMAND ERROR** \N{WARNING SIGN} `{}` from {} in {}\n```\n{}```'.format(ctx.message.content, ctx.author.mention, ctx.channel.mention, ''.join(tb.format_exception(type(error), error, error.__traceback__))))
await bot.get_channel(u.config['info_channel']).send('**COMMAND ERROR** \N{WARNING SIGN} `{}` from {} in {}\n```\n{}```'.format(ctx.message.content, ctx.author.mention, ctx.channel.mention, error))
2017-10-20 16:19:58 -04:00
await exc.send_error(ctx, error)
await ctx.message.add_reaction('\N{WARNING SIGN}')
2017-10-20 16:19:58 -04:00
# u.notify('C O M M A N D E R R O R')
2017-11-19 11:40:08 -05:00
@bot.event
async def on_command_completion(ctx):
await ctx.message.add_reaction('\N{WHITE HEAVY CHECK MARK}')
2017-11-19 11:40:08 -05:00
if ctx.command.name != 'lastcommand':
u.last_commands[ctx.author.id] = ctx
2017-10-19 04:39:41 -04:00
# d.opus.load_opus('opus')
async def wait(voice):
2017-10-20 16:19:58 -04:00
asyncio.sleep(5)
await voice.disconnect()
2017-10-19 04:39:41 -04:00
def after(voice, error):
2017-10-20 16:19:58 -04:00
coro = voice.disconnect()
future = asyncio.run_coroutine_threadsafe(coro, voice.loop)
future.result()
2017-10-19 04:39:41 -04:00
2017-11-19 23:18:05 -05:00
# suggested = u.setdefault('cogs/suggested.pkl', {'last_update': 'None', 'tags': {}, 'total': 0})
@bot.command(name=',test', hidden=True)
2017-09-25 15:31:51 -04:00
@commands.is_owner()
2017-09-24 11:05:28 -04:00
@checks.del_ctx()
2017-11-19 23:18:05 -05:00
async def test(ctx):
post = await u.fetch('https://e621.net/post/show.json?id=1145042', json=True)
tags = []
if post['tags']:
temptags = post['tags'].split(' ')
cis = []
for tag in suggested:
pass
for tag in temptags:
tags.append(f'[{tag}](https://e621.net/post?tags={tag})')
# tags = ' '.join(tags)
else:
tags = 'None'
if post['description']:
post_description = post['description'] if len(post['description']) < 200 else f'{post["description"][:200]}...'
else:
post_description = 'None'
title = ', '.join(post['artist'])
description = f'posted by: *[{post["author"]}](https://e621.net/post?tags=user:{post["author"]})*'
url = f'https://e621.net/post?tags={",".join(post["artist"])}'
# timestamp = dt.utcnow()
color = ctx.me.color
footer = {'text': post['score'], 'icon_url': 'https://images-ext-1.discordapp.net/external/W2k0ZzhU7ngvN_-CdqAa3H3FmkfCNYQTxPG_DsvacB4/https/emojipedia-us.s3.amazonaws.com/thumbs/320/twitter/103/sparkles_2728.png'}
# image = 'https://e621.net/post/show/54360'
thumbnail = post['file_url']
author = {'name': post['id'], 'url': f'https://e621.net/post/show/{post["id"]}', 'icon_url': ctx.author.avatar_url}
fields = []
names = ('File', 'Sources', 'Description', 'tags', 'tags (ext.)')
values = (f'[{post["md5"]}]({post["file_url"]}) | [{post["file_ext"]}](https://e621.net/post?tags=type:{post["file_ext"]})\n\n**Size** [{size(post["file_size"], system=alternative)}](https://e621.net/post?tags=filesize:{post["file_size"]})\n**Resolution** [{post["width"]} x {post["height"]}](https://e621.net/post?tags=width:{post["width"]},height:{post["height"]}) | [{u.get_aspectratio(post["width"], post["height"])}](https://e621.net/post?tags=ratio:{post["width"]/post["height"]:.2f})', '\n'.join([f'[{urlparse(source).netloc}]({source})' for source in post['sources']]), post_description, ' '.join(tags[:20]), ' '.join(tags[20:]))
inlines = (False, False, False, True, True)
for name, value, inline in zip(names, values, inlines):
fields.append({'name': name, 'value': value, 'inline': inline})
embed = u.generate_embed(ctx, title=title, description=description, url=url, colour=color, footer=footer, thumbnail=thumbnail, author=author, fields=fields)
await ctx.send(embed=embed)
# print(ctx.args)
# print(ctx.kwargs)
2017-10-30 23:36:28 -04:00
# if '<:N_:368917475531816962>' in message:
# await ctx.send('<:N_:368917475531816962>')
2017-10-27 21:06:41 -04:00
# logs = []
# async for entry in ctx.guild.audit_logs(limit=None, action=d.AuditLogAction.message_delete):
# logs.append(
# f'@{entry.user.name} deleted {entry.extra.count} messages from @{entry.target.name} in #{entry.extra.channel.name}')
# pprint(logs)
2017-10-21 16:40:06 -04:00
# channel = bot.get_channel(int(cid))
# voice = await channel.connect()
# voice.play(d.AudioSource, after=lambda: after(voice))
2017-09-24 11:05:28 -04:00
2017-10-13 23:38:58 -04:00
bot.run(u.config['token'])