mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-05-17 03:09:05 +00:00
Add ability to edit or delete roles from a sever.
This commit is contained in:
parent
f59ab28741
commit
a5cf6d275d
@ -760,3 +760,47 @@ class Client(object):
|
|||||||
url = '{0}/invite/{1.id}'.format(endpoints.API_BASE, invite)
|
url = '{0}/invite/{1.id}'.format(endpoints.API_BASE, invite)
|
||||||
response = requests.post(url, headers=self.headers)
|
response = requests.post(url, headers=self.headers)
|
||||||
return response.status_code in (200, 201)
|
return response.status_code in (200, 201)
|
||||||
|
|
||||||
|
def edit_role(self, server, role):
|
||||||
|
"""Edits the specified :class:`Role` for the entire :class:`Server`.
|
||||||
|
|
||||||
|
To use this you have to edit the role yourself and then pass it
|
||||||
|
to this member function. For example: ::
|
||||||
|
|
||||||
|
server = message.channel.server
|
||||||
|
role = find(lambda r: r.name == 'My Cool Role', server.roles)
|
||||||
|
role.name = 'My Not So Cool Role'
|
||||||
|
role.permissions.can_kick_members = False
|
||||||
|
role.permissions.can_ban_members = False
|
||||||
|
client.edit_role(server, role)
|
||||||
|
|
||||||
|
Note that you cannot edit the name of the @everyone role as that role is special.
|
||||||
|
|
||||||
|
:param server: The :class:`Server` the role belongs to.
|
||||||
|
:param role: The :class:`Role` to edit.
|
||||||
|
:return: ``True`` if editing was successful, ``False`` otherwise.
|
||||||
|
"""
|
||||||
|
|
||||||
|
url = '{0}/{1.id}/roles/{2.id}'.format(endpoints.SERVERS, server, role)
|
||||||
|
|
||||||
|
payload = {
|
||||||
|
'name': role.name,
|
||||||
|
'permissions': role.permissions.value
|
||||||
|
}
|
||||||
|
|
||||||
|
response = requests.patch(url, json=payload, headers=self.headers)
|
||||||
|
return response.status_code == 204
|
||||||
|
|
||||||
|
def delete_role(self, server, role):
|
||||||
|
"""Deletes the specified :class:`Role` for the entire :class:`Server`.
|
||||||
|
|
||||||
|
Works in a similar matter to :func:`edit_role`.
|
||||||
|
|
||||||
|
:param server: The :class:`Server` the role belongs to.
|
||||||
|
:param role: The :class:`Role` to delete.
|
||||||
|
:return: ``True`` if deleting was successful, ``False`` otherwise.
|
||||||
|
"""
|
||||||
|
|
||||||
|
url = '{0}/{1.id}/roles/{2.id}'.format(endpoints.SERVERS, server, role)
|
||||||
|
response = requests.delete(url, headers=self.headers)
|
||||||
|
return response.status_code == 204
|
||||||
|
Loading…
x
Reference in New Issue
Block a user