Skip to main content

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 inbox triages replies/mentions on your recent posts and drafts responses in your voice (read-only, language-matched); inbox --post walks 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 from llmops-agent in 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.pyMCPServerStdio 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. Set ANTHROPIC_API_KEY (or OPENAI_API_KEY) in ~/.nostr-merchant/.env. Recommended for most setups.
  • ollama:<model> — fully local, no KYC, no phone-home (the sovereignty default). Needs Ollama at localhost: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.

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

nostr_merchant-0.3.0.tar.gz (26.2 kB view details)

Uploaded Source

Built Distribution

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

nostr_merchant-0.3.0-py3-none-any.whl (31.7 kB view details)

Uploaded Python 3

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

Hashes for nostr_merchant-0.3.0.tar.gz
Algorithm Hash digest
SHA256 dc2b5e4d18eae29eb7f08d9b37b38ba3ab6e26cc89e7b1d4f7d6928e7ed57b1e
MD5 c78ea429ff17ad86f9deb15322c50a6d
BLAKE2b-256 0230fb95e8ffa008ed90f9c1c2f6d9f5515e69dd5ebee4073a26ddc638242526

See more details on using hashes here.

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

Hashes for nostr_merchant-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a04157e36e0f4e8633f9647e18276e1d4b0852025c4122775622df3e4aa56007
MD5 c9dfa0f468fb17c2d5defb4781c8a484
BLAKE2b-256 b8bfe95a3391f98c5b5654d738dfb63c2617e541cf3edd759feac07a47b1e250

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