A local-first AI agent that runs a business on NOSTR: checks its Lightning wallet, publishes notes and listings, answers encrypted DMs, and pays for paywalled MCP tools over NWC — all under sats budget caps it can't exceed. Drives five MCP servers (nwc-mcp, nostr-ops-mcp, marketplace-mcp, albyhub-admin-mcp, paywall-mcp). Ollama-first, API-pluggable. Built on pydantic-ai — no LangChain. MIT.
Project description
nostr-merchant
The AI that runs your NOSTR business. A local-first Python agent that holds the whole merchant toolkit — it checks its Lightning wallet, publishes notes and listings, runs a Shopstr storefront, answers encrypted DMs, triages its NOSTR inbox to draft and post replies, and pays for paywalled MCP tools over NWC — all under sats budget caps it can't exceed. Built on five MCP servers (nwc-mcp, nostr-ops-mcp, marketplace-mcp, albyhub-admin-mcp, paywall-mcp) — 37 tools the agent picks from.
Ollama-first, API-pluggable. Built on pydantic-ai — no LangChain. MIT.
v0.3 — engagement inbox. Seven CLI commands.
nostr-merchant inboxtriages replies/mentions on your recent posts and drafts responses in your voice (read-only, language-matched);inbox --postwalks each draft (approve / edit / skip), confirms, and publishes the approved ones as NIP-10 replies. The agent layer enforces a budget-and-audit safety pipeline on top of every MCP server's own safety stack; the self-paying-for-tools loop holds end to end given a working LLM backend (Ollama / Anthropic / OpenAI). (Renamed fromllmops-agentin v0.2.)
Install
pipx install nostr-merchant # recommended: isolated CLI
# or: uvx --from nostr-merchant nostr-merchant --help
# or: pip install nostr-merchant
The five MCP servers it drives are launched on demand via npx -y — no separate install. You need Python 3.11+, an NWC-compatible wallet (e.g. Alby Hub), and an LLM backend (see Usage).
Status
| Layer | State |
|---|---|
| Design doc | ✅ Done — ../03-python-reference-agent-design.md |
Package scaffold (uv init, pyproject.toml, ruff/mypy/pytest config) |
✅ Done |
config.py — env-driven Pydantic Settings |
✅ Done |
budget.py — persistent rolling-window tracker |
✅ Done |
audit.py — NDJSON writer |
✅ Done |
mcp_servers.py — MCPServerStdio launch + doctor probe |
✅ Done |
agent.py — Pydantic AI agent + process_tool_call middleware |
✅ Done |
workflows/research.py — self-paying research workflow |
✅ Done |
cli.py — typer entry-point with ask / doctor / budget / audit / config-print / version |
✅ Done |
| Live LLM smoke test (Anthropic Haiku) | ✅ Done — end-to-end ask returns a real nwc_get_balance receipt with all 37 substrate tools loaded |
Usage
# from this directory, with uv-installed venv
uv run nostr-merchant --help
uv run nostr-merchant version
uv run nostr-merchant budget # snapshot, no LLM needed
uv run nostr-merchant config-print # effective config, secrets masked
uv run nostr-merchant doctor # ping each configured MCP server
uv run nostr-merchant ask "What's my Lightning wallet balance?" # the main demo loop
uv run nostr-merchant audit --tail 20 # recent audit entries
Or run the whole sequence with the bundled script: ./smoke.sh (full run — the ask is read-only, so it can never move sats) or ./smoke.sh --no-ask (skip the LLM call entirely).
ask requires a working LLM backend, set via NOSTR_MERCHANT_MODEL:
anthropic:claude-haiku-4-5-20251001(or any Anthropic/OpenAI model) — fast, reliable tool-calling. SetANTHROPIC_API_KEY(orOPENAI_API_KEY) in~/.nostr-merchant/.env. Recommended for most setups.ollama:<model>— fully local, no KYC, no phone-home (the sovereignty default). Needs Ollama atlocalhost:11434. Reality check: a 37-tool agent loop wants real hardware — a small model on a CPU-only box is too slow to be practical. Run Ollama on a GPU, or use a hosted model and keep your wallet + keys local (the trust boundary that actually matters).
Provider creds in ~/.nostr-merchant/.env are loaded automatically — no need to export them.
Dev loop
uv sync # install deps + dev deps into .venv
uv run ruff check # lint
uv run mypy # type check
uv run pytest # tests
Build wheel for distribution:
uv build
License
MIT — see LICENSE.
Contact
Built by LLMOps.Pro.
- NOSTR:
npub1hdg932jvwc3jdvkqywgqv0ue4nn60exrf92asy8mtazt3hjg7d2s2yw0nw - Lightning Address:
sovereigncitizens@getalby.com - Shopstr: shopstr.store/marketplace/SOVEREIGN_CITIZENS
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nostr_merchant-0.3.0.tar.gz.
File metadata
- Download URL: nostr_merchant-0.3.0.tar.gz
- Upload date:
- Size: 26.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc2b5e4d18eae29eb7f08d9b37b38ba3ab6e26cc89e7b1d4f7d6928e7ed57b1e
|
|
| MD5 |
c78ea429ff17ad86f9deb15322c50a6d
|
|
| BLAKE2b-256 |
0230fb95e8ffa008ed90f9c1c2f6d9f5515e69dd5ebee4073a26ddc638242526
|
File details
Details for the file nostr_merchant-0.3.0-py3-none-any.whl.
File metadata
- Download URL: nostr_merchant-0.3.0-py3-none-any.whl
- Upload date:
- Size: 31.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a04157e36e0f4e8633f9647e18276e1d4b0852025c4122775622df3e4aa56007
|
|
| MD5 |
c9dfa0f468fb17c2d5defb4781c8a484
|
|
| BLAKE2b-256 |
b8bfe95a3391f98c5b5654d738dfb63c2617e541cf3edd759feac07a47b1e250
|