Rewrite webhooks to play better with typings and rate limits

This unfortunately required splitting the types into two. This led to
a lot of unfortunate code duplication that I didn't really enjoy
writing.

The new design allows users to pass an authentication token to make
webhook requests without the webhook token and allows to finally
edit the webhook channel.

The new design also uses a contextvar to store rate limiting
information so multiple instances or recreating instances no longer
clears the ratelimiting state since it's now essentially a "global"
object.

Closes #6525, closes #6662, closes #2509, closes #1761
This commit is contained in:
Rapptz
2021-04-15 07:20:28 -04:00
parent 5ea5f32479
commit a6f7213c89
7 changed files with 2377 additions and 1229 deletions

View File

@@ -2495,7 +2495,7 @@ Webhook
.. attributetable:: Webhook
.. autoclass:: Webhook
.. autoclass:: Webhook()
:members:
WebhookMessage
@@ -2503,22 +2503,23 @@ WebhookMessage
.. attributetable:: WebhookMessage
.. autoclass:: WebhookMessage
.. autoclass:: WebhookMessage()
:members:
Adapters
~~~~~~~~~
SyncWebhook
~~~~~~~~~~~~
Adapters allow you to change how the request should be handled. They all build on a single
interface, :meth:`WebhookAdapter.request`.
.. attributetable:: SyncWebhook
.. autoclass:: WebhookAdapter
.. autoclass:: SyncWebhook()
:members:
.. autoclass:: AsyncWebhookAdapter
:members:
SyncWebhookMessage
~~~~~~~~~~~~~~~~~~~
.. autoclass:: RequestsWebhookAdapter
.. attributetable:: SyncWebhookMessage
.. autoclass:: SyncWebhookMessage()
:members:
.. _discord_api_abcs: