From 7123650198bf0b32614f49a77586e1fa42b7b459 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Fri, 14 Feb 2020 19:55:33 -0800 Subject: [PATCH] Fixes feeration authentication header Co-authored-by: thricedotted Fixes #1 --- fedireads/broadcast.py | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/fedireads/broadcast.py b/fedireads/broadcast.py index c8879bded..f4b219e23 100644 --- a/fedireads/broadcast.py +++ b/fedireads/broadcast.py @@ -3,12 +3,12 @@ from base64 import b64encode from Crypto.PublicKey import RSA from Crypto.Signature import pkcs1_15 from Crypto.Hash import SHA256 -from datetime import datetime +from django.utils.http import http_date import json import requests +from urllib.parse import urlparse from fedireads import incoming -from fedireads.settings import DOMAIN def get_recipients(user, post_privacy, direct_recipients=None): @@ -51,13 +51,12 @@ def broadcast(sender, activity, recipients): def sign_and_send(sender, activity, destination): ''' crpyto whatever and http junk ''' - # TODO: handle http[s] with regex - inbox_fragment = sender.inbox.replace('https://%s' % DOMAIN, '') - now = datetime.utcnow().isoformat() + inbox_parts = urlparse(destination) + now = http_date() signature_headers = [ - '(request-target): post %s' % inbox_fragment, - 'host: https://%s' % DOMAIN, - 'date: %s' % now + '(request-target): post %s' % inbox_parts.path, + 'host: %s' % inbox_parts.netloc, + 'date: %s' % now ] message_to_sign = '\n'.join(signature_headers) @@ -79,7 +78,6 @@ def sign_and_send(sender, activity, destination): headers={ 'Date': now, 'Signature': signature, - 'Host': 'https://%s' % DOMAIN, 'Content-Type': 'application/activity+json; charset=utf-8', }, )