HMAC-based signer for Swarmauri
Project description
Swarmauri Signing HMAC
An HMAC-based signer implementing the ISigning interface for detached
signatures over raw bytes and canonicalized envelopes.
Features
- JSON canonicalization (always available)
- Optional CBOR canonicalization via
cbor2 - Detached signatures using standard library
hmac - Supports raw, hex, environment, and HKDF-derived
KeyRefsecrets.
Security Notes
- Supports HMAC-SHA-256/384/512 only.
- Keys must be at least 32 bytes (256 bits).
- Tags default to the hash digest size and may be truncated via
opts["tag_size"]but not below 16 bytes (128 bits). - Secrets shorter than 32 bytes are rejected even when using a longer digest.
Installation
Install the package with your preferred Python packaging tool:
pip install swarmauri_signing_hmac
poetry add swarmauri_signing_hmac
uv pip install swarmauri_signing_hmac
Install cbor2 to enable CBOR canonicalization:
pip install cbor2
Usage
import asyncio
from swarmauri_signing_hmac import HmacEnvelopeSigner
from swarmauri_core.crypto.types import JWAAlg
async def main() -> None:
signer = HmacEnvelopeSigner()
# KeyRef with a raw 32-byte secret; see swarmauri_core for more options
key = {"kind": "raw", "key": "a" * 32}
# Sign and verify raw bytes
payload = b"hello"
sigs = await signer.sign_bytes(key, payload, alg=JWAAlg.HS256, opts={"tag_size": 16})
assert await signer.verify_bytes(payload, sigs, opts={"keys": [key]})
# Sign and verify a JSON envelope
env = {"msg": "hello"}
sigs_env = await signer.sign_envelope(
key, env, alg=JWAAlg.HS256, canon="json", opts={"tag_size": 16}
)
assert await signer.verify_envelope(env, sigs_env, canon="json", opts={"keys": [key]})
asyncio.run(main())
Verification requires providing one or more keys via opts["keys"].
Key references
HmacEnvelopeSigner accepts multiple KeyRef forms:
{"kind": "raw", "key": <bytes-or-str>}– direct secret material.{"kind": "hex", "key": <hex str>}– hex encoded secret.{"kind": "env", "name": <ENV_NAME>}– loads the secret from an environment variable.{"kind": "derived", "key": <bytes-or-str>, "hkdf": {"salt": ..., "info": ...}}– derives the signing secret with HKDF.
Provide an optional "kid" to control the key identifier or specify
"alg" when verifying to override the default HS256 digest for a key entry.
Entry Point
The signer registers under the swarmauri.signings entry point as HmacEnvelopeSigner.
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_hmac-0.3.0.dev31.tar.gz.
File metadata
- Download URL: swarmauri_signing_hmac-0.3.0.dev31.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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 |
e91ca7d53d1d6e6b4f4d6b13603dd9ba96da72455e2407ff5a4b83bc3281e323
|
|
| MD5 |
c0e9009caf2d507493b8c40f71274351
|
|
| BLAKE2b-256 |
85dc866dfa7472a184712270ddeb8d25bd5fc8a9dfbc3e835de402f224e01fef
|
File details
Details for the file swarmauri_signing_hmac-0.3.0.dev31-py3-none-any.whl.
File metadata
- Download URL: swarmauri_signing_hmac-0.3.0.dev31-py3-none-any.whl
- Upload date:
- Size: 10.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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 |
f913dbcc23812fdd9bdbf47632369ca73ba041b83e64125014c313d8e6e1d25e
|
|
| MD5 |
93f9d2e6f0a97b320219dda19cda7a0d
|
|
| BLAKE2b-256 |
c384edacd3b3ae76909eada8ea32814f71faabec7747de93ca7b5c5972ddcba9
|