Skip to main content

ECDSA-based signer for Swarmauri

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_signing_ecdsa


Swarmauri Signing ECDSA

An asynchronous ECDSA-based signer that implements the ISigning interface for detached signatures over raw bytes and canonicalized envelopes.

Features

  • JSON canonicalization built in, with optional CBOR canonicalization via cbor2
  • Supports the ECDSA-P256-SHA256, ECDSA-P384-SHA384, and ECDSA-P521-SHA512 curves provided by cryptography
  • Multi-signature aware verification with opt-in algorithm restrictions through the require mapping
  • Detached signature generation for both raw byte payloads and Swarmauri envelopes

Installation

pip

pip install swarmauri_signing_ecdsa
# Optional CBOR support
pip install "swarmauri_signing_ecdsa[cbor]"

Poetry

poetry add swarmauri_signing_ecdsa
# Optional CBOR support
poetry add "swarmauri_signing_ecdsa[cbor]"

uv

# Install uv if it is not already available on your system
curl -LsSf https://astral.sh/uv/install.sh | sh

# Install the signer package
uv pip install swarmauri_signing_ecdsa
# Optional CBOR support
uv pip install "swarmauri_signing_ecdsa[cbor]"

Usage

The signer operates asynchronously and expects private keys to be supplied via the KeyRef mappings defined in swarmauri_core. When verifying, provide the corresponding public keys through the opts={"pubkeys": [...]} option.

import asyncio
from cryptography.hazmat.primitives.asymmetric import ec

from swarmauri_signing_ecdsa import EcdsaEnvelopeSigner


async def main() -> None:
    signer = EcdsaEnvelopeSigner()

    # Provide the private key as a KeyRef understood by swarmauri_core
    private_key = ec.generate_private_key(ec.SECP256R1())
    key_ref = {"kind": "cryptography_obj", "obj": private_key}

    envelope = {
        "headers": {"kid": "example"},
        "payload": {"message": "signed hello"},
    }

    signatures = await signer.sign_envelope(
        key_ref,
        envelope,
        canon="json",
    )

    is_valid = await signer.verify_envelope(
        envelope,
        signatures,
        canon="json",
        opts={"pubkeys": [private_key.public_key()]},
    )

    print(f"Signature valid? {is_valid}")


if __name__ == "__main__":
    asyncio.run(main())

Entry Point

The signer registers under the swarmauri.signings entry point as EcdsaEnvelopeSigner.

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


Download files

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

Source Distribution

swarmauri_signing_ecdsa-0.3.0.dev44.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

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

swarmauri_signing_ecdsa-0.3.0.dev44-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file swarmauri_signing_ecdsa-0.3.0.dev44.tar.gz.

File metadata

  • Download URL: swarmauri_signing_ecdsa-0.3.0.dev44.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

Hashes for swarmauri_signing_ecdsa-0.3.0.dev44.tar.gz
Algorithm Hash digest
SHA256 70118b7253e810e23f9a8b69619b0d01cfce38270939cad1b8441a7eef24eb00
MD5 b2f543a0773317677426f5d97ecdef96
BLAKE2b-256 f0e0e0e60315a9bf007c0207cc0a1a04f6d5ecf71cba8fbfdb2f0089971391e2

See more details on using hashes here.

File details

Details for the file swarmauri_signing_ecdsa-0.3.0.dev44-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_signing_ecdsa-0.3.0.dev44-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

Hashes for swarmauri_signing_ecdsa-0.3.0.dev44-py3-none-any.whl
Algorithm Hash digest
SHA256 393e29b6568266d40dc42e4ba2a055d32c87538e5833219433dd0acb23030f59
MD5 21665ac0fdfb9293ceb120de7494df25
BLAKE2b-256 28359a60f108f4613872ce91a95f2c6f92da1f28add11915b86714ddfa7b79dc

See more details on using hashes here.

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