AWS Signature Version 4 signer for Swarmauri
Project description
Swarmauri Signing SigV4
AWS Signature Version 4 (SigV4) signer and verifier that implements the ISigning interface for HTTP requests and raw byte payloads.
Features
- Canonicalizes HTTP request envelopes according to AWS SigV4 rules
- Derives SigV4 signing keys from AWS credentials and scope information
- Supports both request signing and raw payload HMAC generation/verification
- Returns structured signature metadata (scope, signed headers, canonical hash) for downstream Authorization headers
Security Notes
- Requires valid AWS-style credentials (
access_key,secret_key, optionalsession_token) - Verification requires access to the shared secret material; compare signatures externally when AWS performs verification
- Payload canonicalization expects callers to supply the appropriate SHA-256 hash or the
UNSIGNED-PAYLOADmarker
Installation
Install the package with your preferred Python packaging tool:
pip install swarmauri_signing_sigv4
uv pip install swarmauri_signing_sigv4
poetry add swarmauri_signing_sigv4
Usage
import asyncio
from swarmauri_signing_sigv4 import SigV4Signing
envelope = {
"method": "GET",
"uri": "/",
"query": {"Action": ["ListUsers"], "Version": ["2010-05-08"]},
"headers": {
"host": "iam.amazonaws.com",
"x-amz-date": "20150830T123600Z",
"content-type": "application/x-www-form-urlencoded; charset=utf-8",
},
"payload_hash": "UNSIGNED-PAYLOAD",
"amz_date": "20150830T123600Z",
"scope": {"date": "20150830", "region": "us-east-1", "service": "iam"},
}
key = {"access_key": "AKIDEXAMPLE", "secret_key": "wJalrXUtnFEMI/K7MDENG+bPxRfiCYEXAMPLEKEY"}
async def main() -> None:
signer = SigV4Signing()
signatures = await signer.sign_envelope(key, envelope)
print(signatures[0]["signature"])
asyncio.run(main())
When verifying signatures you must provide the shared secret via opts["secret_key"] or require["secret_key"].
Byte payload signing
Use sign_bytes / verify_bytes when you only need a SigV4-derived HMAC:
payload = b"example"
opts = {"date": "20150830", "region": "us-east-1", "service": "iam"}
signatures = await signer.sign_bytes(key, payload, opts=opts)
assert await signer.verify_bytes(payload, signatures, opts={**opts, "secret_key": key["secret_key"]})
Entry Point
The signer registers under the swarmauri.signings entry point as SigV4Signing.
Want to help?
If you want to contribute to swarmauri-sdk, read up on our guidelines for contributing that will help you get started.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri_signing_sigv4-0.1.1.dev39.tar.gz.
File metadata
- Download URL: swarmauri_signing_sigv4-0.1.1.dev39.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e3911e9bcbf0b3a0f52d2b0ebec252ac57648a28a217ce837971c1c81e24b96a
|
|
| MD5 |
db646ca2cb54c3cdf0e7a6a0501752de
|
|
| BLAKE2b-256 |
9009bdc29de4cb72375f8057029b2d199d21da8d48dd77b0eb2fcb28fccbb61a
|
File details
Details for the file swarmauri_signing_sigv4-0.1.1.dev39-py3-none-any.whl.
File metadata
- Download URL: swarmauri_signing_sigv4-0.1.1.dev39-py3-none-any.whl
- Upload date:
- Size: 10.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dfee40520de1f9b8a62d1cad03da787bd069ba34c425d9f24da2c2addb4e1021
|
|
| MD5 |
348495e5ff97c92022b457da55738a60
|
|
| BLAKE2b-256 |
4e90f5f6f96502576afcbe82d327c543b9474a27c9e3819741af533aba098584
|