You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.7KB

  1. #!/usr/env python
  2. import logging
  3. import discord
  4. from discord.ext import commands
  5. import load_config
  6. from config.server_config import ServerConfig
  7. # Sets up Logging that discord.py does on its own
  8. logger = logging.getLogger('discord')
  9. logger.setLevel(logging.DEBUG)
  10. handler = logging.FileHandler(filename='discord.log', encoding='utf-8', mode='w')
  11. handler.setFormatter(logging.Formatter('%(asctime)s:%(levelname)s:%(name)s: %(message)s'))
  12. logger.addHandler(handler)
  13. server_config = ServerConfig()
  14. bot = commands.Bot(command_prefix=load_config.command_prefix, description=load_config.description)
  15. @bot.event
  16. async def on_ready():
  17. server_config.error_check(bot.servers)
  18. print("Discord.py version: " + discord.__version__)
  19. print("Client logged in\n")
  20. bot.owner = load_config.owner
  21. print("Cogs Loaded:")
  22. for cog in load_config.cogslist:
  23. bot.load_extension(cog)
  24. print(cog)
  25. print("")
  26. print("Servers I am currently in:")
  27. for server in bot.servers:
  28. print(server)
  29. print("")
  30. # Testing Code
  31. game = discord.Game(name="Rewriting Moi for v{}".format(load_config.version), type=0)
  32. await bot.change_presence(game=game)
  33. print("Game Changed")
  34. @bot.event
  35. async def on_server_join(server):
  36. server_config.servers = server_config.load_config()
  37. server_config.servers[server.id] = server_config.servers_template["example"]
  38. server_config.update_config(server_config.servers)
  39. @bot.event
  40. async def on_server_remove(server):
  41. server_config.servers = server_config.load_config()
  42. server_config.servers.pop(server.id)
  43. server_config.update_config(server_config.servers)
  44. @bot.event
  45. async def on_message(message):
  46. # TODO: Check for words for reactions and check blacklist
  47. return await bot.process_commands(message)
  48. #@bot.event
  49. #async def on_error(error, ctx, *args, **kwargs):
  50. # pass
  51. @bot.event
  52. async def on_command_error(error, ctx):
  53. if isinstance(error, commands.NoPrivateMessage):
  54. await bot.send_message(ctx.message.author, 'This command cannot be used in private messages.')
  55. elif isinstance(error, commands.DisabledCommand):
  56. await bot.say(':x: This command is disabled')
  57. elif isinstance(error, commands.CommandInvokeError):
  58. raise error
  59. #if bot.dev:
  60. # raise error
  61. #else:
  62. # embed = discord.Embed(title=':x: Command Error', colour=0x992d22) #Dark Red
  63. # embed.add_field(name='Error', value=str(error))
  64. # embed.add_field(name='Server', value=ctx.message.server)
  65. # embed.add_field(name='Channel', value=ctx.message.channel)
  66. # embed.add_field(name='User', value=ctx.message.author)
  67. # embed.add_field(name='Message', value=ctx.message.clean_content)
  68. # embed.timestamp = datetime.datetime.utcnow()
  69. # try:
  70. # await bot.send_message(bot.owner, embed=embed)
  71. # except:
  72. # pass
  73. bot.run(load_config.token)