💰 Freshbooks Cli OpenClaw Skill - ClawHub
Do you want your AI agent to automate Freshbooks Cli workflows? This free skill from ClawHub helps with speech & transcription tasks without building custom tools from scratch.
What this skill does
FreshBooks CLI for managing invoices, clients, and billing. Use when the user mentions freshbooks, invoicing, billing, clients, or accounting.
Install
npx clawhub@latest install freshbooks-cliFull SKILL.md
Open original| name | description |
|---|---|
| freshbooks-cli | FreshBooks CLI for managing invoices, clients, and billing. Use when the user mentions freshbooks, invoicing, billing, clients, or accounting. |
freshbooks-cli
CLI tool for managing FreshBooks invoices, clients, and billing. Uses the official @freshbooks/api SDK.
Install
npm install -g @haseebuchiha/freshbooks-cli
Requires .npmrc with @haseebuchiha:registry=https://npm.pkg.github.com for GitHub Package Registry.
Setup (once)
Authenticate with FreshBooks OAuth2. You must use the --manual flag (localhost redirect does not work with FreshBooks).
freshbooks auth login \
--client-id "<FRESHBOOKS_CLIENT_ID>" \
--client-secret "<FRESHBOOKS_CLIENT_SECRET>" \
--manual
This opens the browser. Authorize, then copy the code from the page and paste it into the CLI. Tokens are stored at ~/.config/freshbooks-cli/config.json (0600 permissions) and auto-refresh before expiry.
Verify: freshbooks auth status
Auth commands
freshbooks auth login --client-id <id> --client-secret <secret> --manual-- authenticate via OAuth2 OOB flowfreshbooks auth logout-- clear stored tokens and credentialsfreshbooks auth status-- show account ID, token expiry, and auth statefreshbooks auth refresh-- manually refresh the access token
Clients commands
freshbooks clients list [-p <page>] [--per-page <n>] [-s <search>]-- list clients, search by org namefreshbooks clients get <id>-- get a single client by IDfreshbooks clients create [--fname <name>] [--lname <name>] [--email <email>] [--organization <org>]-- create a clientfreshbooks clients create --data '<json>'-- create with full JSON payloadfreshbooks clients update <id> --data '<json>'-- update a client
Example: freshbooks clients create --fname "Taha" --organization "abcg.io"
Invoices commands
freshbooks invoices list [-p <page>] [--per-page <n>]-- list invoicesfreshbooks invoices get <id>-- get a single invoice by IDfreshbooks invoices create --client-id <id> [--lines '<json>']-- create an invoice with line itemsfreshbooks invoices create --client-id <id> --data '<json>'-- create with full JSON payloadfreshbooks invoices update <id> --data '<json>'-- update an invoicefreshbooks invoices archive <id>-- archive an invoice (no permanent delete in FreshBooks)freshbooks invoices share-link <id>-- get a shareable link for an invoice
Line items format
Lines are a JSON array. Each line has name, qty, and unitCost (money object):
[
{"name": "Web Services", "qty": 1, "unitCost": {"amount": "15000.00", "code": "USD"}},
{"name": "App Services", "qty": 1, "unitCost": {"amount": "15000.00", "code": "USD"}}
]
Example (full invoice create):
freshbooks invoices create --client-id 818183 \
--lines '[{"name":"Web Services","qty":1,"unitCost":{"amount":"15000.00","code":"USD"}},{"name":"App Services","qty":1,"unitCost":{"amount":"15000.00","code":"USD"}}]'
Workflows
Onboard a new client and invoice them
freshbooks clients create --fname "Name" --organization "Company"-- note the returnedidfreshbooks invoices create --client-id <id> --lines '[...]'-- create the invoicefreshbooks invoices share-link <invoice-id>-- get shareable link
Look up billing for a client
freshbooks clients list -s "company name"-- find the client IDfreshbooks invoices list-- list all invoices (filter by client in output)freshbooks invoices get <id>-- get full invoice details
Notes
- All output is JSON to stdout. Pipe to
jqfor filtering:freshbooks clients list | jq '.clients[].organization' - Money values are
{"amount": "string", "code": "USD"}. The amount is always a string like"30000.00", never a number. Do not use parseFloat on money. archivesets vis_state=1. FreshBooks does not support permanent deletion.- Tokens auto-refresh. If refresh fails, re-run
freshbooks auth login --client-id <id> --client-secret <secret> --manual. - Client credentials can also be read from env vars
FRESHBOOKS_CLIENT_IDandFRESHBOOKS_CLIENT_SECRET(takes priority over stored config). - Always use
--manualfor auth login. The localhost callback redirect URI does not work with FreshBooks. - Confirm with the user before creating invoices or modifying billing data.