oneseed-0.5.2 is not a library.
Visit the last successful build:
oneseed-0.7.0
1seed
Deterministic cryptographic keys from a single seed.
What This Does
- Stores seed securely in OS keychain with automatic fallback to ~/.1seed
- Derives age, SSH, and signing keys from one master secret
- Encrypts and decrypts files using age
- Signs and verifies data using Ed25519
- Generates site-specific passwords, deterministic integers, UUIDs, and BIP39 mnemonics
Installation
# Quick Install
|
# From crates.io
Quick Start
|
Seed Storage
Priority: SEED_FILE env → OS keyring → ~/.1seed.
1seed uses OS-native credential stores (Keychain, Secret Service, Credential Manager) where available. If unavailable, it automatically falls back to ~/.1seed (mode 0600).
# Override seed location
SEED_FILE=/path/to/seed
# Set default realm
Commands
Initialization
1seed init [-g | -p]: Store seed (generate random or use passphrase).1seed forget --confirm: Remove seed from all storage.1seed status: Show seed location and public keys.
Age Encryption
1seed age [pub | key]: Show keys.1seed age encrypt [-s] [-a] [-o FILE]: Encrypt (default to self).1seed age decrypt [-k FILE] [-o FILE]: Decrypt using derived key.
SSH & Signing
1seed ssh [pub | key | add]: SSH key management and agent integration.1seed sign [pub | data | verify]: Ed25519 signatures.
Derivation
1seed derive password SITE [-l 16] [-n 1]: Site-specific passwords.1seed derive int PATH [--min 0] [--max 100]: Deterministic integers.1seed derive uuid PATH: Deterministic UUIDs.1seed derive mnemonic [-w 24]: BIP39 word phrases.1seed derive raw PATH [--hex | --base64]: Deterministic raw bytes.
Management
1seed update [--check]: Update to latest release from GitHub.
Realms
Realms namespace all derived keys. Same seed, different realm = different keys.
Security Model
Single Point of Failure: The seed is the "Master Key". If it leaks, everything derived from it is compromised. 1seed trades N secrets for one well-protected secret.
- Storage: Uses hardware-backed keychain where available (Secure Enclave, TPM).
- KDF: HKDF-SHA256 for derivation; scrypt for passphrases (~1GB RAM).
- Memory: Keys are zeroized when dropped.
Version History
- v0.5.2: Code formatting fixes
- v0.5.1: Deterministic Integer and UUID derivation, improved documentation
- v0.5.0: Auto-fallback to ~/.1seed, SEED_NO_KEYRING env var
- v0.4.0: Keyring-only storage, removed config file
- v0.3.0: Self-update command, simplified config
- v0.2.0: Domain-based namespaces (
age,ssh,sign,derive) - v0.1.0: Initial release
License
MIT