Browse Source

Fix memory leak in webhooks not deallocating locks

pull/7494/head
Rapptz 3 years ago
parent
commit
4fa2a6e63e
  1. 3
      discord/webhook/async_.py
  2. 3
      discord/webhook/sync.py

3
discord/webhook/async_.py

@ -32,6 +32,7 @@ import re
from urllib.parse import quote as urlquote
from typing import Any, Dict, List, Literal, NamedTuple, Optional, TYPE_CHECKING, Tuple, Union, overload
from contextvars import ContextVar
import weakref
import aiohttp
@ -95,7 +96,7 @@ class AsyncDeferredLock:
class AsyncWebhookAdapter:
def __init__(self):
self._locks: Dict[Any, asyncio.Lock] = {}
self._locks: weakref.WeakValueDictionary[Any, asyncio.Lock] = weakref.WeakValueDictionary()
async def request(
self,

3
discord/webhook/sync.py

@ -38,6 +38,7 @@ import re
from urllib.parse import quote as urlquote
from typing import Any, Dict, List, Literal, Optional, TYPE_CHECKING, Tuple, Type, TypeVar, Union, overload
import weakref
from .. import utils
from ..errors import InvalidArgument, HTTPException, Forbidden, NotFound, DiscordServerError
@ -91,7 +92,7 @@ class DeferredLock:
class WebhookAdapter:
def __init__(self):
self._locks: Dict[Any, threading.Lock] = {}
self._locks: weakref.WeakValueDictionary[Any, threading.Lock] = weakref.WeakValueDictionary()
def request(
self,

Loading…
Cancel
Save