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