Browse Source

Fix overwrites order in get_permissions

pull/66/head
Anis B 8 years ago
committed by GitHub
parent
commit
bc23eb84fd
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 18
      disco/types/channel.py

18
disco/types/channel.py

@ -159,12 +159,18 @@ class Channel(SlottedModel, Permissible):
member = self.guild.get_member(user)
base = self.guild.get_permissions(member)
for ow in six.itervalues(self.overwrites):
if ow.id != user.id and ow.id not in member.roles:
continue
base -= ow.deny
base += ow.allow
ow_everyone = self.overwrites.get(self.guild_id)
if ow_everyone:
base += ow_everyone.compiled
for role_id in member.roles:
ow_role = self.overwrites.get(role_id)
if ow_role:
base += ow_role.compiled
ow_member = self.overwrites.get(member.user.id)
if ow_member:
base += ow_member.compiled
return base

Loading…
Cancel
Save