X-Git-Url: https://reisub.nsupdate.info/git/?a=blobdiff_plain;f=relay%2Factor.py;h=24d39ddc08b881b62ee45bfe397cb9fac5fb92d0;hb=a15d7342181d9a9f2cec641be57a2ba447b7ce54;hp=6974ef51e41e7b0f99c4995e1c55b5d850c34404;hpb=436a57971ce75c56ef98f0762240372a6e765551;p=relay.git%2F.git diff --git a/relay/actor.py b/relay/actor.py index 6974ef5..24d39dd 100644 --- a/relay/actor.py +++ b/relay/actor.py @@ -6,12 +6,17 @@ import uuid import re import simplejson as json import cgi +import datetime + from urllib.parse import urlsplit from Crypto.PublicKey import RSA +from cachetools import LFUCache + +from . import app, CONFIG from .database import DATABASE from .http_debug import http_debug - -from cachetools import LFUCache +from .remote_actor import fetch_actor +from .http_signatures import sign_headers, generate_body_digest # generate actor keys if not present @@ -29,19 +34,12 @@ if "actorKeys" not in DATABASE: PRIVKEY = RSA.importKey(DATABASE["actorKeys"]["privateKey"]) PUBKEY = PRIVKEY.publickey() - -sem = asyncio.Semaphore(500) - -from . import app, CONFIG -from .remote_actor import fetch_actor - - AP_CONFIG = CONFIG['ap'] CACHE_SIZE = CONFIG.get('cache-size', 16384) - - CACHE = LFUCache(CACHE_SIZE) +sem = asyncio.Semaphore(500) + async def actor(request): data = { @@ -68,11 +66,6 @@ async def actor(request): app.router.add_get('/actor', actor) - - -from .http_signatures import sign_headers - - get_actor_inbox = lambda actor: actor.get('endpoints', {}).get('sharedInbox', actor['inbox']) @@ -86,10 +79,14 @@ async def push_message_to_actor(actor, message, our_key_id): '(request-target)': 'post {}'.format(url.path), 'Content-Length': str(len(data)), 'Content-Type': 'application/activity+json', - 'User-Agent': 'ActivityRelay' + 'User-Agent': 'ActivityRelay', + 'Host': url.netloc, + 'Digest': 'SHA-256={}'.format(generate_body_digest(data)), + 'Date': datetime.datetime.utcnow().strftime('%a, %d %b %Y %H:%M:%S GMT') } headers['signature'] = sign_headers(headers, PRIVKEY, our_key_id) headers.pop('(request-target)') + headers.pop('Host') logging.debug('%r >> %r', inbox, message)