Browse Source

Add a more concrete exception for 500 status codes.

Fixes #5797
pull/5810/head
Rapptz 5 years ago
parent
commit
450e71f086
  1. 8
      discord/errors.py
  2. 7
      discord/http.py
  3. 8
      discord/webhook.py
  4. 5
      docs/api.rst

8
discord/errors.py

@ -122,6 +122,14 @@ class NotFound(HTTPException):
""" """
pass pass
class DiscordServerError(HTTPException):
"""Exception that's thrown for when a 500 range status code occurs.
Subclass of :exc:`HTTPException`.
.. versionadded:: 1.5
"""
pass
class InvalidData(ClientException): class InvalidData(ClientException):
"""Exception that's raised when the library encounters unknown """Exception that's raised when the library encounters unknown

7
discord/http.py

@ -33,7 +33,7 @@ import weakref
import aiohttp import aiohttp
from .errors import HTTPException, Forbidden, NotFound, LoginFailure, GatewayNotFound from .errors import HTTPException, Forbidden, NotFound, LoginFailure, DiscordServerError, GatewayNotFound
from .gateway import DiscordClientWebSocketResponse from .gateway import DiscordClientWebSocketResponse
from . import __version__, utils from . import __version__, utils
@ -252,6 +252,9 @@ class HTTPClient:
raise raise
# We've run out of retries, raise. # We've run out of retries, raise.
if r.status >= 500:
raise DiscordServerError(r, data)
raise HTTPException(r, data) raise HTTPException(r, data)
async def get_from_cdn(self, url): async def get_from_cdn(self, url):
@ -659,7 +662,7 @@ class HTTPClient:
def get_template(self, code): def get_template(self, code):
return self.request(Route('GET', '/guilds/templates/{code}', code=code)) return self.request(Route('GET', '/guilds/templates/{code}', code=code))
def create_from_template(self, code, name, region, icon): def create_from_template(self, code, name, region, icon):
payload = { payload = {
'name': name, 'name': name,

8
discord/webhook.py

@ -34,7 +34,7 @@ from urllib.parse import quote as _uriquote
import aiohttp import aiohttp
from . import utils from . import utils
from .errors import InvalidArgument, HTTPException, Forbidden, NotFound from .errors import InvalidArgument, HTTPException, Forbidden, NotFound, DiscordServerError
from .enums import try_enum, WebhookType from .enums import try_enum, WebhookType
from .user import BaseUser, User from .user import BaseUser, User
from .asset import Asset from .asset import Asset
@ -241,7 +241,10 @@ class AsyncWebhookAdapter(WebhookAdapter):
raise NotFound(r, response) raise NotFound(r, response)
else: else:
raise HTTPException(r, response) raise HTTPException(r, response)
# no more retries # no more retries
if r.status >= 500:
raise DiscordServerError(r, response)
raise HTTPException(r, response) raise HTTPException(r, response)
async def handle_execution_response(self, response, *, wait): async def handle_execution_response(self, response, *, wait):
@ -342,7 +345,10 @@ class RequestsWebhookAdapter(WebhookAdapter):
raise NotFound(r, response) raise NotFound(r, response)
else: else:
raise HTTPException(r, response) raise HTTPException(r, response)
# no more retries # no more retries
if r.status >= 500:
raise DiscordServerError(r, response)
raise HTTPException(r, response) raise HTTPException(r, response)
def handle_execution_response(self, response, *, wait): def handle_execution_response(self, response, *, wait):

5
docs/api.rst

@ -904,7 +904,7 @@ of :class:`enum.Enum`.
is to be interpreted as a system message or a regular message. is to be interpreted as a system message or a regular message.
.. container:: operations .. container:: operations
.. describe:: x == y .. describe:: x == y
Checks if two messages are equal. Checks if two messages are equal.
@ -2902,6 +2902,8 @@ The following exceptions are thrown by the library.
.. autoexception:: NotFound .. autoexception:: NotFound
.. autoexception:: DiscordServerError
.. autoexception:: InvalidData .. autoexception:: InvalidData
.. autoexception:: InvalidArgument .. autoexception:: InvalidArgument
@ -2931,3 +2933,4 @@ Exception Hierarchy
- :exc:`HTTPException` - :exc:`HTTPException`
- :exc:`Forbidden` - :exc:`Forbidden`
- :exc:`NotFound` - :exc:`NotFound`
- :exc:`DiscordServerError`

Loading…
Cancel
Save