mirror of
https://git.pleroma.social/pleroma/relay.git
synced 2024-11-22 14:38:00 +00:00
Merge branch 'feature/semaphore_in_push_to_actor' into 'master'
use global semaphore in push_to_actor to prevent overloading system with outbound connections See merge request pleroma/relay!16
This commit is contained in:
commit
b3b33c9796
|
@ -30,6 +30,7 @@ if "actorKeys" not in DATABASE:
|
||||||
PRIVKEY = RSA.importKey(DATABASE["actorKeys"]["privateKey"])
|
PRIVKEY = RSA.importKey(DATABASE["actorKeys"]["privateKey"])
|
||||||
PUBKEY = PRIVKEY.publickey()
|
PUBKEY = PRIVKEY.publickey()
|
||||||
|
|
||||||
|
sem = asyncio.Semaphore(500)
|
||||||
|
|
||||||
from . import app, CONFIG
|
from . import app, CONFIG
|
||||||
from .remote_actor import fetch_actor
|
from .remote_actor import fetch_actor
|
||||||
|
@ -77,7 +78,6 @@ get_actor_inbox = lambda actor: actor.get('endpoints', {}).get('sharedInbox', ac
|
||||||
|
|
||||||
async def push_message_to_actor(actor, message, our_key_id):
|
async def push_message_to_actor(actor, message, our_key_id):
|
||||||
inbox = get_actor_inbox(actor)
|
inbox = get_actor_inbox(actor)
|
||||||
|
|
||||||
url = urlsplit(inbox)
|
url = urlsplit(inbox)
|
||||||
|
|
||||||
# XXX: Digest
|
# XXX: Digest
|
||||||
|
@ -93,6 +93,8 @@ async def push_message_to_actor(actor, message, our_key_id):
|
||||||
|
|
||||||
logging.debug('%r >> %r', inbox, message)
|
logging.debug('%r >> %r', inbox, message)
|
||||||
|
|
||||||
|
global sem
|
||||||
|
async with sem:
|
||||||
try:
|
try:
|
||||||
async with aiohttp.ClientSession(trace_configs=[http_debug()]) as session:
|
async with aiohttp.ClientSession(trace_configs=[http_debug()]) as session:
|
||||||
async with session.post(inbox, data=data, headers=headers) as resp:
|
async with session.post(inbox, data=data, headers=headers) as resp:
|
||||||
|
@ -317,5 +319,4 @@ async def inbox(request):
|
||||||
|
|
||||||
return aiohttp.web.Response(body=b'{}', content_type='application/activity+json')
|
return aiohttp.web.Response(body=b'{}', content_type='application/activity+json')
|
||||||
|
|
||||||
|
|
||||||
app.router.add_post('/inbox', inbox)
|
app.router.add_post('/inbox', inbox)
|
||||||
|
|
Loading…
Reference in a new issue