mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-24 18:13:00 +00:00 
			
		
		
		
	Fix issue with roles being passed in being strings.
Client.add_roles and Client.remove_roles would dispatch to the Client.replace_roles function. However, replace_roles expects Role objects while the dispatching involved string IDs. So as a result this needed another layer of dispatch into a _replace_roles function to do the actual call that all three of them dispatch to.
This commit is contained in:
		| @@ -1967,6 +1967,19 @@ class Client: | |||||||
|         yield from utils._verify_successful_response(response) |         yield from utils._verify_successful_response(response) | ||||||
|         yield from response.release() |         yield from response.release() | ||||||
|  |  | ||||||
|  |     @asyncio.coroutine | ||||||
|  |     def _replace_roles(self, member, *roles): | ||||||
|  |         url = '{0}/{1.server.id}/members/{1.id}'.format(endpoints.SERVERS, member) | ||||||
|  |  | ||||||
|  |         payload = { | ||||||
|  |             'roles': list(roles) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         r = yield from aiohttp.patch(url, headers=self.headers, data=utils.to_json(payload), loop=self.loop) | ||||||
|  |         log.debug(request_logging_format.format(method='PATCH', response=r)) | ||||||
|  |         yield from utils._verify_successful_response(r) | ||||||
|  |         yield from r.release() | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def add_roles(self, member, *roles): |     def add_roles(self, member, *roles): | ||||||
|         """|coro| |         """|coro| | ||||||
| @@ -1994,7 +2007,7 @@ class Client: | |||||||
|         """ |         """ | ||||||
|  |  | ||||||
|         new_roles = [role.id for role in itertools.chain(member.roles, roles)] |         new_roles = [role.id for role in itertools.chain(member.roles, roles)] | ||||||
|         yield from self.replace_roles(member, *new_roles) |         yield from self._replace_roles(member, *new_roles) | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def remove_roles(self, member, *roles): |     def remove_roles(self, member, *roles): | ||||||
| @@ -2022,7 +2035,7 @@ class Client: | |||||||
|         """ |         """ | ||||||
|         new_roles = {role.id for role in member.roles} |         new_roles = {role.id for role in member.roles} | ||||||
|         new_roles = new_roles.difference(roles) |         new_roles = new_roles.difference(roles) | ||||||
|         yield from self.replace_roles(member, *new_roles) |         yield from self._replace_roles(member, *new_roles) | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def replace_roles(self, member, *roles): |     def replace_roles(self, member, *roles): | ||||||
| @@ -2054,16 +2067,8 @@ class Client: | |||||||
|             Removing roles failed. |             Removing roles failed. | ||||||
|         """ |         """ | ||||||
|  |  | ||||||
|         url = '{0}/{1.server.id}/members/{1.id}'.format(endpoints.SERVERS, member) |         new_roles = [role.id for role in roles] | ||||||
|  |         yield from self._replace_roles(member, *new_roles) | ||||||
|         payload = { |  | ||||||
|             'roles': [role.id for role in roles] |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         r = yield from aiohttp.patch(url, headers=self.headers, data=utils.to_json(payload), loop=self.loop) |  | ||||||
|         log.debug(request_logging_format.format(method='PATCH', response=r)) |  | ||||||
|         yield from utils._verify_successful_response(r) |  | ||||||
|         yield from r.release() |  | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def create_role(self, server, **fields): |     def create_role(self, server, **fields): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user