Skip to main content

ECDH-ES+A128KW based multi-recipient encryption provider for Swarmauri

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_mre_crypto_ecdh_es_kw


Swarmauri MRE Crypto ECDH-ES+A128KW

ECDH-ES+A128KW based multi-recipient encryption provider implementing the IMreCrypto contract.

Capabilities

  • Per-recipient ECDH-ES key agreement over secp256r1
  • AES-128 Key Wrap (KW) of the derived content-encryption key
  • AES-128-GCM payload encryption with optional additional authenticated data (AAD)
  • Supported payload algorithm: A128GCM
  • Supported recipient algorithm: ECDH-ES+A128KW
  • Supported MRE mode: MreMode.ENC_ONCE_HEADERS
  • Re-wrapping existing envelopes is not supported

Installation

pip

pip install swarmauri_mre_crypto_ecdh_es_kw

Poetry

poetry add swarmauri_mre_crypto_ecdh_es_kw

uv

  1. Install uv if it is not already available:

    curl -LsSf https://astral.sh/uv/install.sh | sh
    
  2. Add the package to your environment:

    uv pip install swarmauri_mre_crypto_ecdh_es_kw
    

Usage

The provider operates asynchronously. The example below demonstrates encrypting and decrypting a payload for a single recipient whose key is provided as a cryptography object reference. The same aad (if provided) must be used for both encryption and decryption.

import asyncio

from cryptography.hazmat.primitives.asymmetric import ec

from swarmauri_mre_crypto_ecdh_es_kw import EcdhEsA128KwMreCrypto


async def main() -> None:
    crypto = EcdhEsA128KwMreCrypto()

    sk = ec.generate_private_key(ec.SECP256R1())
    pk = sk.public_key()
    recipient = {"kid": "1", "version": 1, "kind": "cryptography_obj", "obj": pk}

    envelope = await crypto.encrypt_for_many([recipient], b"secret", aad=b"metadata")
    plaintext = await crypto.open_for(
        {"kind": "cryptography_obj", "obj": sk}, envelope, aad=b"metadata"
    )

    assert plaintext == b"secret"


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

Entry point

The provider is registered under the swarmauri.mre_cryptos entry point as EcdhEsA128KwMreCrypto.

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

Built Distribution

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

File details

Details for the file swarmauri_mre_crypto_ecdh_es_kw-0.2.0.dev44.tar.gz.

File metadata

  • Download URL: swarmauri_mre_crypto_ecdh_es_kw-0.2.0.dev44.tar.gz
  • Upload date:
  • Size: 8.4 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_mre_crypto_ecdh_es_kw-0.2.0.dev44.tar.gz
Algorithm Hash digest
SHA256 4c13cbfc5f7894e20d73241450749733b6a4a5e8161500f4dbdc25b613b70cb3
MD5 af4c10794b2f51fd9bf3add98aa760ee
BLAKE2b-256 2a689351edd9d5432fcff622845bd3a24c4b1542f6fb2b0d2255eb4bd7e19877

See more details on using hashes here.

File details

Details for the file swarmauri_mre_crypto_ecdh_es_kw-0.2.0.dev44-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_mre_crypto_ecdh_es_kw-0.2.0.dev44-py3-none-any.whl
  • Upload date:
  • Size: 9.6 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_mre_crypto_ecdh_es_kw-0.2.0.dev44-py3-none-any.whl
Algorithm Hash digest
SHA256 48022c11e066243fd77ecaa8eea4d4601bc771c23cd7a4dbc9e8bdc08488e354
MD5 7c186e0b0e255dfa24f762370e800665
BLAKE2b-256 a366cc138e45b3eec9f2c32b682c86d394efa496aabc7f8277fb4c494bc6c066

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