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.

85 lines
3.3KB

  1. # -*- coding: utf-8 -*-
  2. # MIT License
  3. #
  4. # Copyright (c) 2017-2018 Roxanne Gibson
  5. #
  6. # Permission is hereby granted, free of charge, to any person obtaining a copy
  7. # of this software and associated documentation files (the "Software"), to deal
  8. # in the Software without restriction, including without limitation the rights
  9. # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  10. # copies of the Software, and to permit persons to whom the Software is
  11. # furnished to do so, subject to the following conditions:
  12. #
  13. # The above copyright notice and this permission notice shall be included in all
  14. # copies or substantial portions of the Software.
  15. #
  16. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  19. # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  21. # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  22. # SOFTWARE.
  23. from discord.ext import commands
  24. class User(commands.UserConverter):
  25. """Overriding the discord version to add a slower global look up for when it is a requirement to return a user who has left the guild.
  26. Converts to a :class:`User`.
  27. All lookups are via the global user cache. (Excluding the last one which makes an api call to discord.
  28. The lookup strategy is as follows (in order):
  29. 1. Lookup by ID.
  30. 2. Lookup by mention.
  31. 3. Lookup by name#discrim
  32. 4. Lookup by name
  33. 5. Lookup by fetch_user
  34. """
  35. async def convert(self, ctx, argument):
  36. try:
  37. result = await super().convert(ctx, argument)
  38. except commands.BadArgument as e:
  39. try:
  40. result = await ctx.bot.fetch_user(argument)
  41. except: # Bare except or otherwise it will raise its own BadArgument and have a pretty shitty error message that isn't useful.
  42. raise e
  43. return result
  44. class Emoji():
  45. """discord.Emoji converter for Roxbot. Is a combo of the EmojiConverter and PartialEmojiConverter converter classes."""
  46. async def convert(self, ctx, argument):
  47. try:
  48. return await commands.EmojiConverter().convert(ctx, argument)
  49. except commands.errors.BadArgument:
  50. return await commands.PartialEmojiConverter().convert(ctx, argument)
  51. class AvatarURL(commands.UserConverter):
  52. """
  53. Overriding the discord version to make it a converter appropriate for the image cog.
  54. Converts the input into a avatar url or url to an image provided. Either through URL or Attachments.
  55. 1. Look up if argument is a URL
  56. 3. Look up if argument is user
  57. Will do a user lookup, if that fails, then tries to parse the argument for a link
  58. """
  59. async def convert(self, ctx, argument):
  60. if any(x in argument.split(".")[-1].lower() for x in ("png", "jpg", "jpeg")):
  61. return argument.strip("<>")
  62. else:
  63. try:
  64. user = await super().convert(ctx, argument)
  65. return user.avatar_url_as(format="png")
  66. except: # Same as above
  67. raise commands.BadArgument("No valid image/user given.")