aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Manuel Ignacio Pérez Alcolea <[email protected]>2019-12-20 03:09:25 -0300
committerGravatar Manuel Ignacio Pérez Alcolea <[email protected]>2019-12-20 03:09:25 -0300
commit8e9d19c7b73f44dac9482302bc34bc737a2fe3ed (patch)
tree8f54f82480aefa8825600d81fd04776a7dcde52d
parentMake `FetchedUser` return a `discord.Object` if user *may* exist (diff)
Make post_user take default values for payload from `getattr`
-rw-r--r--bot/cogs/moderation/utils.py32
1 files changed, 12 insertions, 20 deletions
diff --git a/bot/cogs/moderation/utils.py b/bot/cogs/moderation/utils.py
index 0674e8d45..604ce5ce4 100644
--- a/bot/cogs/moderation/utils.py
+++ b/bot/cogs/moderation/utils.py
@@ -39,26 +39,18 @@ async def post_user(ctx: Context, user: t.Union[discord.User, discord.Object]) -
"""
log.trace("Attempting to add user to the database.")
- try:
- payload = {
- 'avatar_hash': user.avatar,
- 'discriminator': int(user.discriminator),
- 'id': user.id,
- 'in_guild': False,
- 'name': user.name,
- 'roles': []
- }
- except AttributeError:
- log.trace("Couldn't take all the attributes for the user payload, taking just its ID.")
- # XXX: Not sure if these default values are ideal.
- payload = {
- 'avatar_hash': 0,
- 'discriminator': 0,
- 'id': user.id,
- 'in_guild': False,
- 'name': 'Some name',
- 'roles': []
- }
+ if not isinstance(user, discord.User):
+ log.warn("The given user is not a discord.User object.")
+
+ # XXX: Not sure if these default values are ideal.
+ payload = {
+ 'avatar_hash': getattr(user, 'avatar', 0),
+ 'discriminator': int(getattr(user, 'discriminator', 0)),
+ 'id': user.id,
+ 'in_guild': False,
+ 'name': getattr(user, 'name', 'No name'),
+ 'roles': []
+ }
try:
response = await ctx.bot.api_client.post('bot/users', json=payload)