Used as the runtime environment for the MCP server, providing fast JavaScript execution for the wallet implementation
Enables deposits via Lightning invoices and payment of Lightning invoices through the wallet interface
Allows installation and execution of the MCP server through npm commands and package management
Integrates with Square's Goose AI assistant through configuration in Goose's config.yaml file
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MCP Moneywhat's my current balance across all mints?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Money

An MCP (Model Context Protocol) money implementation for Nostr using NDK (Nostr Development Kit) with Cashu ecash functionality.
Features
Cashu Wallet Integration: Full support for Cashu ecash mints and tokens
Lightning Network: Deposit via Lightning invoices and pay Lightning invoices
Nostr Zaps: Send zaps to users using npub or NIP-05 identifiers
Multi-mint Support: Manage multiple Cashu mints simultaneously
Persistent Storage: Wallet state saved to local file with mint info caching
MCP Server: Expose wallet functionality through Model Context Protocol
CLI Interface: Direct command-line usage for all wallet operations
Related MCP server: lunchmoney-mcp
Installation
npm install mcp-moneyUsage
MCP Server Mode (Default)
Run without arguments to start the MCP server:
npx mcp-moneyCLI Mode
Use specific commands for direct wallet operations:
# Get total balance
npx mcp-money get_balance
# Get balance per mint
npx mcp-money get_mint_balances
# Create deposit invoice
npx mcp-money deposit 1000 https://testnut.cashu.space
# Pay lightning invoice
npx mcp-money pay lnbc1...
# Send a zap
npx mcp-money zap npub1... 100 "Great post!"
# Add a new mint
npx mcp-money add_mint https://mint.example.comAuthentication
The wallet supports multiple ways to provide your Nostr private key:
Command line:
--nsec nsec1...Environment variable:
NSEC=nsec1...Config file: Automatically saved to
.wallet.jsonAuto-generate: Creates new key if none provided
MCP Tools
When running as an MCP server, the following tools are available:
get_balance: Get the total wallet balanceget_mint_balances: Get balance breakdown per mintdeposit: Create a deposit invoice for specified amount and mintpay: Pay a Lightning invoicezap: Send a zap to a useradd_mint: Add a mint to the wallet
Integration with AI Assistants
Claude Code Integration
To use this wallet with Claude Code, add it to your project's MCP configuration:
{
"mcpServers": {
"mcp-money": {
"command": "npx",
"args": ["mcp-money"]
}
}
}Or install globally and reference the binary directly:
npm install -g mcp-money{
"mcpServers": {
"mcp-money": {
"command": "mcp-money"
}
}
}Goose Integration
To use this wallet with Goose, add it to your ~/.config/goose/config.yaml:
If you have an nsec you want to use, you can set it by passing it as --nsec nsec1....
extensions:
money:
args:
- -y
- mcp-money
bundled: null
cmd: npx
description: Money for agents
enabled: true
env_keys: []
envs: {}
name: money
timeout: 300
type: stdioAfter adding the configuration, restart your AI assistant to begin using the wallet tools.
Configuration
The wallet automatically creates a .wallet.json file to store:
Private key (nsec)
Public key (npub)
Configured relays
Configured mints
Cached mint information
Architecture
Built on top of:
NDK: Nostr Development Kit for Nostr protocol interactions
NDK Wallet: Cashu wallet implementation
Nostr Tools: Low-level Nostr utilities
Bun: Fast JavaScript runtime and package manager
Security
Private keys are stored locally in
.wallet.jsonMint information is cached for performance
All Nostr communications use standard NIP protocols
Lightning payments require explicit confirmation
License
MIT
Contributing
Fork the repository
Create a feature branch
Make your changes
Add tests if applicable
Submit a pull request
Support
For issues and questions, please open an issue on the GitHub repository.