Skip to main content

An implementation of the IETF HTTP Message Signatures draft standard

Project description

http-message-signatures is an implementation of the IETF RFC 9421 HTTP Message Signatures standard in Python.

Installation

pip3 install http-message-signatures

Synopsis

from http_message_signatures import HTTPMessageSigner, HTTPMessageVerifier, HTTPSignatureKeyResolver, algorithms
import requests, base64, hashlib, http_sfv

class MyHTTPSignatureKeyResolver(HTTPSignatureKeyResolver):
    keys = {"my-key": b"top-secret-key"}

    def resolve_public_key(self, key_id: str):
        return self.keys[key_id]

    def resolve_private_key(self, key_id: str):
        return self.keys[key_id]

request = requests.Request('POST', 'https://example.com/foo?param=Value&Pet=dog', json={"hello": "world"})
request = request.prepare()
request.headers["Content-Digest"] = str(http_sfv.Dictionary({"sha-256": hashlib.sha256(request.body).digest()}))

signer = HTTPMessageSigner(signature_algorithm=algorithms.HMAC_SHA256, key_resolver=MyHTTPSignatureKeyResolver())
signer.sign(request, key_id="my-key", covered_component_ids=("@method", "@authority", "@target-uri", "content-digest"))

verifier = HTTPMessageVerifier(signature_algorithm=algorithms.HMAC_SHA256, key_resolver=MyHTTPSignatureKeyResolver())
verifier.verify(request)

Note that verifying the body content-digest is outside the scope of this package’s functionality, so it remains the caller’s responsibility. The requests-http-signature library builds upon this package to provide integrated signing and validation of the request body.

Given an HTTP request can potentially have multiple signatures the verify() method returns a list of VerifyResult s. However, the implementation currently supports just one signature, so the returned list currently contains just one element. If more signatures are found in the request then InvalidSignature is raised.

Additionally, the verify() method raises HTTPMessageSignaturesException or an exception derived from this class in case an error occurs (unable to load PEM key, unsupported algorithm specified in signature input, signature doesn’t match digest etc.)

Authors

  • Andrey Kislyuk <https://kislyuk.com>

License

Copyright 2017-2024, Andrey Kislyuk and http-message-signatures contributors. Licensed under the terms of the Apache License, Version 2.0. Distribution of attribution information, LICENSE and NOTICE files with source copies of this package and derivative works is REQUIRED as specified by the Apache License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

http_message_signatures-0.6.1.tar.gz (21.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

http_message_signatures-0.6.1-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file http_message_signatures-0.6.1.tar.gz.

File metadata

  • Download URL: http_message_signatures-0.6.1.tar.gz
  • Upload date:
  • Size: 21.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for http_message_signatures-0.6.1.tar.gz
Algorithm Hash digest
SHA256 e0c409b1529826e90a75563d892db82eba1d1afae95b14e242f9221e8b9382e4
MD5 a12c03e839d2865beb32f59b96b261c9
BLAKE2b-256 59acbce2a2210fbea7c4349f3f53d927093c2eeb9d05c5efc285c5bdb518e660

See more details on using hashes here.

Provenance

The following attestation bundles were made for http_message_signatures-0.6.1.tar.gz:

Publisher: release.yml on pyauth/http-message-signatures

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file http_message_signatures-0.6.1-py3-none-any.whl.

File metadata

File hashes

Hashes for http_message_signatures-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 210346bfcf1e90c5877b90b4f0f7fd0e20128087d488b4b300e01daf1e002d75
MD5 a5780423fb40676b66573e8082d66809
BLAKE2b-256 3ed2a02ddec9b8f5d7aa6fe6119110d7c9a490fab3b78c90645083303dbfd097

See more details on using hashes here.

Provenance

The following attestation bundles were made for http_message_signatures-0.6.1-py3-none-any.whl:

Publisher: release.yml on pyauth/http-message-signatures

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page