OpenClaw · Skill
Mercury Payments
Pay invoices via Mercury bank API, notify Zeni (bookkeeper) and the vendor, and always attach the invoice PDF.
Install
Start with the primary install command. Alternate entrypoints are included below for ClawHub and OpenClaw CLI users.
Primary command
clawhub install nathan-deepmm/mercury-paymentsClawHub installer
npx clawhub@latest install nathan-deepmm/mercury-paymentsOpenClaw CLI
openclaw skills install nathan-deepmm/mercury-paymentsDirect OpenClaw install
openclaw install nathan-deepmm/mercury-paymentsWhat this skill does
Pay invoices via Mercury bank API, notify Zeni (bookkeeper) and the vendor, and always attach the invoice PDF.
Why it matters
Combining payment execution, bookkeeper notification, and vendor confirmation in one workflow eliminates the manual back-and-forth that typically spans three separate tools.
Typical use cases
- Pay a vendor invoice via ACH without logging into Mercury
- Send a domestic wire with correct purpose category for compliance
- Notify bookkeeper automatically after each payment
- Forward payment confirmation to vendor in the existing email thread
- Transfer funds between two Mercury accounts instantly
Source instructions
Mercury Payments Skill
Overview
Pay invoices via Mercury bank API, notify Zeni (bookkeeper) and the vendor, and always attach the invoice PDF.
Prerequisites
- Mercury API token (write access):
$MERCURY_API_TOKENorpass show <vault-path> - Auth:
Authorization: Bearer <token>(Basic auth also works:token:base64) - Base URL:
https://api.mercury.com/api/v1
Accounts
Discover account IDs dynamically (do not hardcode organization-specific IDs):
curl -s -H "Authorization: Bearer $TOKEN" "https://api.mercury.com/api/v1/accounts"
Default payment account should be confirmed at payment time.
Known Recipients
Keep recipient IDs in your own secure records or resolve by recipient name at runtime.
Payment Flow
1. Get explicit approval
NEVER send money without explicit approval from the authorized operator. Present: amount, recipient, invoice #, account.
2. Download the invoice PDF
Find the invoice email, download the attachment to /tmp/.
3. Check for existing recipient
curl -s -H "Authorization: Bearer $TOKEN" "https://api.mercury.com/api/v1/recipients" | python3 -c "..."
4. Create recipient if needed
curl -s -X POST "https://api.mercury.com/api/v1/recipients" \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{
"name": "...",
"emails": ["..."],
"defaultPaymentMethod": "ach",
"electronicRoutingInfo": {
"accountNumber": "...",
"routingNumber": "...",
"electronicAccountType": "businessChecking",
"address": { "address1": "...", "city": "...", "region": "...", "postalCode": "...", "country": "US" }
},
"defaultAddress": { ... }
}'
5. Send payment
ACH payment:
curl -s -X POST "https://api.mercury.com/api/v1/account/{accountId}/transactions" \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{
"recipientId": "...",
"amount": 533.13,
"paymentMethod": "ach",
"note": "INV123 - Vendor - Period",
"idempotencyKey": "unique-key-here"
}'
Domestic wire payment:
curl -s -X POST "https://api.mercury.com/api/v1/account/{accountId}/transactions" \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{
"recipientId": "...",
"amount": 1080.00,
"paymentMethod": "domesticWire",
"purpose": {"simple": {"category": "vendor", "additionalInfo": "Invoice TRC37332 TRACE Data"}},
"note": "INV-001 - Vendor - Jan 2026",
"idempotencyKey": "unique-key-here"
}'
Wire purpose is required. Format: {"simple": {"category": "<cat>", "additionalInfo": "<desc>"}}
Categories: employee, landlord, vendor, contractor, subsidiary, transferToMyExternalAccount, familyMemberOrFriend, forGoodsOrServices, angelInvestment, savingsOrInvestments, expenses, travel, other
6. Email bookkeeper (always)
Send to your bookkeeping inbox (e.g., bookkeeping@example.com) with:
- Subject:
<Vendor> Invoice <number> — Paid - Body: amount, method, estimated delivery
- Attach the invoice PDF
7. Email vendor (always)
Reply in the existing email thread if possible. Include:
- Confirmation of payment with amount
- Attach the invoice PDF
- Estimated delivery date
Internal Transfers (Between Mercury Accounts)
curl -s -X POST "https://api.mercury.com/api/v1/transfer" \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{
"sourceAccountId": "YOUR_SOURCE_ACCOUNT_ID",
"destinationAccountId": "YOUR_DESTINATION_ACCOUNT_ID",
"amount": 465.00,
"idempotencyKey": "unique-key-here"
}'
Required fields: sourceAccountId, destinationAccountId, amount, idempotencyKey.
Transfers post instantly. Response contains both creditTransaction and debitTransaction.
Querying Transactions
# Recent (default ~30 days)
curl -s -H "Authorization: Bearer $TOKEN" "https://api.mercury.com/api/v1/account/{id}/transactions?limit=500"
# Date range (goes further back)
curl -s -H "Authorization: Bearer $TOKEN" "https://api.mercury.com/api/v1/account/{id}/transactions?start=2025-12-01&end=2026-01-18&limit=500"
Note: Without date params, API only returns ~30 days. Use start/end to go further back.
Idempotency Keys
Use descriptive keys: {vendor}-{invoice}-{period} (e.g., finra-trc37332-nov2025)
Checklist
- Explicit approval received from authorized operator
- Invoice PDF downloaded
- Recipient exists (or created)
- Payment sent with correct amount, method, and note
- Zeni emailed with invoice attached
- Vendor emailed with invoice attached
- Payment logged in daily memory file