OPEN BETA v0.1 - star, share, and provide feedback :)
Python bindings for the Kinic CLI core, enabling you to build AI agents with verifiable, owned memory on the Internet Computer. Give your agents the memory they can prove, own, and carry anywhere.
For the wizards building trustless agents - no more lobotomized summons that reset on every quest.
Looking for the CLI docs? See docs/cli.md.
Made with ❤️ by ICME Labs.
Traditional AI agents face three critical problems:
- Memory Without Proof: TEEs prove computation, but can't verify the memories your agent retrieved were correct.
- Memory Without Ownership: Your agent's identity is onchain, but its memories live in Pinecone, Weaviate, or other centralized providers.
- Payment Without Verification: With x402, agents can pay for memory retrieval - but can't prove they received the right results.
Kinic solves this with zkTAM (zero-knowledge Trustless Agentic Memory):
- ✅ Verifiable: zkML proofs for embeddings - no black box vectors
- ✅ Owned: Your memory lives on-chain in WASM canisters you control
- ✅ Portable: Move your agent's memory between any infrastructure
By default we use the Internet Computer as the DA layer—with VetKey encryption and cross-chain signing (tECDSA). You can run it locally or on any WASM-based DA layer. In future versions, full zkML support will be enabled, allowing for trustless verification on nearly all blockchains.
- Python 3.9+
- dfx 0.28+ with the
arm64build on Apple Silicon (macOS) - KINIC tokens: At least 1 KINIC to deploy memory canisters
- dfx identity: Create or select one with
dfx identity new <name>ordfx identity use <name>
Note: Do not use the
defaultidentity withkinic-cli—it always fails. Use a named identity instead.
Optional: If you need local launcher/ledger/II canisters, run ./scripts/setup.sh after dfx start --clean --background.
pip install kinic-py
# Or with uv
uv pip install kinic-pyRequires Rust toolchain for the PyO3 extension:
pip install -e .
# Or with uv
uv pip install -e .Create (or switch to) a dfx identity before using the library:
dfx identity new <name>
# or
dfx identity use <name>Make sure you have at least 1 KINIC token:
# Get your principal
dfx --identity <name> identity get-principal
# Check balance (result is in base units: 100000000 = 1 KINIC)
dfx canister --ic call 73mez-iiaaa-aaaaq-aaasq-cai icrc1_balance_of '(record {owner = principal "<your principal>"; subaccount = null; }, )'
# Example: (100000000 : nat) == 1 KINICDM https://x.com/wyatt_benno for KINIC prod tokens with your principal ID.
Or purchase them from MEXC or swap at https://app.icpswap.com/ .
from kinic_py import KinicMemories
km = KinicMemories("<name>") # dfx identity name; use ic=True for mainnet, e.g. KinicMemories("<name>", ic=True)
memory_id = km.create("Python demo", "Created via kinic_py")
km.insert_markdown(memory_id, "notes", "# Hello Kinic!\n\nInserted from Python.")
for score, payload in km.search(memory_id, "Hello"):
print(f"{score:.4f} -> {payload}") # payload is the JSON stored in insertStateful helper that mirrors the CLI behavior.
KinicMemories(identity: str, ic: bool = False)Parameters:
identity: Your dfx identity nameic: SetTrueto target mainnet (default:Falsefor local)
Deploy a new memory canister.
Returns: Canister principal (memory_id)
List all memory canisters owned by your identity.
Embed and store markdown text with zkML verification.
Returns: Number of chunks inserted
Embed and store markdown from a file.
Returns: Number of chunks inserted
Search memories with semantic similarity.
Returns: List of (score, payload) tuples sorted by relevance
Stateless alternatives available:
create_memory(identity, name, description, ic=False)list_memories(identity, ic=False)insert_markdown(identity, memory_id, tag, text, ic=False)insert_markdown_file(identity, memory_id, tag, path, ic=False)search_memories(identity, memory_id, query, ic=False)
Run the complete example at python/examples/memories_demo.py:
# With existing memory
uv run python python/examples/memories_demo.py \
--identity <name> \
--memory-id
# Deploy new memory
uv run python python/examples/memories_demo.py --identity <name>
# Use mainnet
uv run python python/examples/memories_demo.py --identity <name> --icBuild agents with verifiable memory that works with the ERC-8004 trust model:
km = KinicMemories("agent-identity", ic=True)
memory_id = km.create("Trading Agent Memory", "Market analysis and decisions")
# Store verified context
km.insert_markdown(memory_id, "analysis", market_report)
# Retrieve with proof
results = km.search(memory_id, "BTC trend analysis")Agents can pay for memory operations with verifiable results:
# Agent pays for retrieval via x402
# Memory operations return zkML proofs
# Agent can verify it received correct embeddings for paymentSee docs/python-wheel.md for packaging, testing, and PyPI upload instructions.
Ready to deploy on mainnet? DM https://x.com/wyatt_benno for KINIC prod tokens and start building agents with trustless memory.
- Blog Post: Trustless AI can't work without Trustless AI Memory
- Vectune: WASM-based vector database
- JOLT Atlas: zkML framework for embedding verification
Built by wizards, for wizards. 🧙♂️✨
Stop building lobotomized agents. Start building with memory they can prove.