aboutsummaryrefslogtreecommitdiff
path: root/modules/fediverse/ap_security.py
diff options
context:
space:
mode:
authorGravatar jesopo2019-09-15 11:06:00 +0100
committerGravatar jesopo2019-09-15 11:06:00 +0100
commit71896f808163d3d2b0c460b84dde3bd17dcfbafb (patch)
treec9e105047d58e920ea08f774904d12193bdc306c /modules/fediverse/ap_security.py
parentactivities.py -> ap_activities.py (diff)
move AP server event/exports to __init__.py
Diffstat (limited to 'modules/fediverse/ap_security.py')
-rw-r--r--modules/fediverse/ap_security.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/modules/fediverse/ap_security.py b/modules/fediverse/ap_security.py
new file mode 100644
index 00000000..00fe8264
--- /dev/null
+++ b/modules/fediverse/ap_security.py
@@ -0,0 +1,36 @@
+import base64, typing
+from cryptography.hazmat.primitives import hashes, serialization
+from cryptography.hazmat.primitives.asymmetric import padding, rsa
+from cryptography.hazmat.backends import default_backend
+
+SIGNATURE_FORMAT = (
+ "keyId=\"%s\",headers=\"%s\",signature=\"%s\",algorithm=\"rsa-sha256\"")
+
+
+def _private_key(key_filename: str) -> rsa.RSAPrivateKey:
+ with open(key_filename) as key_file:
+ return serialization.load_pem_private_key(
+ key_file.read(), password=None, backend=default_backend())
+
+class PrivateKey(object):
+ def __init__(self, filename, id):
+ self.key = _private_key(filename)
+ self.id = id
+
+def signature(key: PrivateKey, headers: typing.List[typing.Tuple[str, str]]
+ ) -> str:
+ sign_header_keys = " ".join(h[0] for h in headers)
+
+ sign_string_parts = ["%s: %s" % (k, v) for k, v in headers]
+ sign_string = "\n".join(sign_string_parts)
+
+ signature = key.key.sign(
+ sign_string.encode("utf8"),
+ padding.PSS(
+ mgf=padding.MGF1(hashes.SHA256()),
+ salt_length=padding.PSS.MAX_LENGTH),
+ hashes.SHA256()
+ )
+
+ signature = base64.b64encode(signature).decode("ascii")
+ return SIGNATURE_FORMAT % (key_id, sign_header_keys, signature)