Browse Source

Actually use v4 gateway and fixes thanks to Jake.

pull/236/merge
Rapptz 9 years ago
parent
commit
f6fa1e837a
  1. 2
      discord/endpoints.py
  2. 10
      discord/gateway.py

2
discord/endpoints.py

@ -26,7 +26,7 @@ DEALINGS IN THE SOFTWARE.
BASE = 'https://discordapp.com'
API_BASE = BASE + '/api'
GATEWAY = API_BASE + '/gateway?encoding=json&v=4'
GATEWAY = API_BASE + '/gateway'
USERS = API_BASE + '/users'
ME = USERS + '/@me'
REGISTER = API_BASE + '/auth/register'

10
discord/gateway.py

@ -125,7 +125,7 @@ def get_gateway(token, *, loop=None):
yield from resp.release()
raise GatewayNotFound()
data = yield from resp.json(encoding='utf-8')
return data.get('url')
return data.get('url') + '?encoding=json&v=4'
class DiscordWebSocket(websockets.client.WebSocketClientProtocol):
"""Implements a WebSocket for Discord's gateway v4.
@ -310,6 +310,9 @@ class DiscordWebSocket(websockets.client.WebSocketClientProtocol):
if op == self.INVALIDATE_SESSION:
state.sequence = None
state.session_id = None
if data == True:
raise ResumeWebSocket()
yield from self.identify()
return
@ -381,10 +384,7 @@ class DiscordWebSocket(websockets.client.WebSocketClientProtocol):
except websockets.exceptions.ConnectionClosed as e:
if self._can_handle_close(e.code):
log.info('Websocket closed with {0.code} ({0.reason}), attempting a reconnect.'.format(e))
if e.code == 4006:
raise ReconnectWebSocket() from e
else:
raise ResumeWebSocket() from e
raise ResumeWebSocket() from e
else:
raise ConnectionClosed(e) from e

Loading…
Cancel
Save