mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-25 10:32:59 +00:00 
			
		
		
		
	WebSocket gateway now properly uses the auth headers.
This commit is contained in:
		| @@ -102,25 +102,6 @@ class Client(object): | |||||||
|             'on_member_remove': _null_event, |             'on_member_remove': _null_event, | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         gateway = requests.get(endpoints.GATEWAY) |  | ||||||
|         if gateway.status_code != 200: |  | ||||||
|             raise GatewayNotFound() |  | ||||||
|         gateway_js = gateway.json() |  | ||||||
|         url = gateway_js.get('url') |  | ||||||
|         if url is None: |  | ||||||
|             raise GatewayNotFound() |  | ||||||
|  |  | ||||||
|         self.ws = WebSocketClient(url, protocols=['http-only', 'chat']) |  | ||||||
|  |  | ||||||
|         # this is kind of hacky, but it's to avoid deadlocks. |  | ||||||
|         # i.e. python does not allow me to have the current thread running if it's self |  | ||||||
|         # it throws a 'cannot join current thread' RuntimeError |  | ||||||
|         # So instead of doing a basic inheritance scheme, we're overriding the member functions. |  | ||||||
|  |  | ||||||
|         self.ws.opened = self._opened |  | ||||||
|         self.ws.closed = self._closed |  | ||||||
|         self.ws.received_message = self._received_message |  | ||||||
|  |  | ||||||
|         # the actual headers for the request... |         # the actual headers for the request... | ||||||
|         # we only override 'authorization' since the rest could use the defaults. |         # we only override 'authorization' since the rest could use the defaults. | ||||||
|         self.headers = { |         self.headers = { | ||||||
| @@ -450,8 +431,6 @@ class Client(object): | |||||||
|         :param str password: The password used to login. |         :param str password: The password used to login. | ||||||
|         """ |         """ | ||||||
|  |  | ||||||
|         self.ws.connect() |  | ||||||
|  |  | ||||||
|         payload = { |         payload = { | ||||||
|             'email': email, |             'email': email, | ||||||
|             'password': password |             'password': password | ||||||
| @@ -463,6 +442,27 @@ class Client(object): | |||||||
|             body = r.json() |             body = r.json() | ||||||
|             self.token = body['token'] |             self.token = body['token'] | ||||||
|             self.headers['authorization'] = self.token |             self.headers['authorization'] = self.token | ||||||
|  |  | ||||||
|  |             gateway = requests.get(endpoints.GATEWAY, headers=self.headers) | ||||||
|  |             if gateway.status_code != 200: | ||||||
|  |                 raise GatewayNotFound() | ||||||
|  |             gateway_js = gateway.json() | ||||||
|  |             url = gateway_js.get('url') | ||||||
|  |             if url is None: | ||||||
|  |                 raise GatewayNotFound() | ||||||
|  |  | ||||||
|  |             self.ws = WebSocketClient(url, protocols=['http-only', 'chat']) | ||||||
|  |  | ||||||
|  |             # this is kind of hacky, but it's to avoid deadlocks. | ||||||
|  |             # i.e. python does not allow me to have the current thread running if it's self | ||||||
|  |             # it throws a 'cannot join current thread' RuntimeError | ||||||
|  |             # So instead of doing a basic inheritance scheme, we're overriding the member functions. | ||||||
|  |  | ||||||
|  |             self.ws.opened = self._opened | ||||||
|  |             self.ws.closed = self._closed | ||||||
|  |             self.ws.received_message = self._received_message | ||||||
|  |             self.ws.connect() | ||||||
|  |  | ||||||
|             second_payload = { |             second_payload = { | ||||||
|                 'op': 2, |                 'op': 2, | ||||||
|                 'd': { |                 'd': { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user