Skip to main content

Hardware-anchored identity SDK for AI agents -- 1id.com

Project description

oneid-sdk

Python SDK for 1id.com -- hardware-anchored identity for AI agents.

RFC: draft-drake-email-hardware-attestation-00

Quick start

import oneid

# Enroll at declared tier (no HSM needed, always works)
identity = oneid.enroll(request_tier="declared", display_name="Sparky")
print(f"Enrolled: {identity.handle}")
print(f"URN: {identity.agent_identity_urn}")

# Get an OAuth2 token for API access
token = oneid.get_token()
headers = {"Authorization": f"Bearer {token.access_token}"}

# Check identity
me = oneid.whoami()
print(f"I am {me.handle}, trust tier: {me.trust_tier.value}")

Hardware-backed enrollment

# TPM enrollment (sovereign tier) - requires Windows/Linux with TPM 2.0
identity = oneid.enroll(request_tier="sovereign")

# YubiKey enrollment (portable tier) - requires YubiKey 5 inserted
identity = oneid.enroll(request_tier="portable")

# Virtual TPM (VMware/Hyper-V/QEMU)
identity = oneid.enroll(request_tier="virtual")

Trust tiers

Tier Hardware Sybil Resistant Trust Level
sovereign TPM (Intel, AMD, Infineon) with valid cert Yes Highest
portable YubiKey / Nitrokey / Feitian with PIV attestation Yes High
virtual VMware / Hyper-V / QEMU vTPM No Verified Hardware
declared None (software keys) No Software

request_tier is a requirement, not a preference. You get exactly what you ask for, or an exception. No silent fallbacks.

Key algorithms

Like SSH, agents can choose their preferred key algorithm for declared-tier enrollment:

identity = oneid.enroll(request_tier="declared", key_algorithm="ed25519")     # default, strongest
identity = oneid.enroll(request_tier="declared", key_algorithm="ecdsa-p384")  # NIST P-384
identity = oneid.enroll(request_tier="declared", key_algorithm="rsa-4096")    # RSA compat

Installation

pip install oneid

Requires Python 3.10+.

License

Apache-2.0

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

oneid-1.3.5.tar.gz (102.1 kB view details)

Uploaded Source

Built Distribution

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

oneid-1.3.5-py3-none-any.whl (83.4 kB view details)

Uploaded Python 3

File details

Details for the file oneid-1.3.5.tar.gz.

File metadata

  • Download URL: oneid-1.3.5.tar.gz
  • Upload date:
  • Size: 102.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for oneid-1.3.5.tar.gz
Algorithm Hash digest
SHA256 2a98985d4a28839346b1e4895627ddfeb4ed220e7a23b6ce55a66df59bb3f859
MD5 c9fb7221f67930a99e6a850b4f4f93b7
BLAKE2b-256 e7630e385b1751eb2904467e5b63af1e44e1c5dbe11c0ca8607cd519dc333ccf

See more details on using hashes here.

File details

Details for the file oneid-1.3.5-py3-none-any.whl.

File metadata

  • Download URL: oneid-1.3.5-py3-none-any.whl
  • Upload date:
  • Size: 83.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for oneid-1.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8087873421d1b896c63d88da1c0ed5cd8951d3eeec2de677a2b8e01235e06f98
MD5 7e3c66544f69652d7756c294b97043ff
BLAKE2b-256 9fc89631ce20ded4e2a1529c97b2015d51a935c2f391da7c48ce4cea3a6d0bba

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