MarginFront MCP Tools Reference
This is a complete list of every tool the MarginFront MCP server provides. There are 13 tools total, organized into four groups: read-only, write, diagnostic, and destructive. Your AI assistant calls these tools automatically when you ask it questions about your MarginFront data. You don’t need to memorize tool names — just ask in plain English and the AI picks the right tool.Read-Only Tools (8)
These tools look things up without changing anything.1. verify
What it does: Checks that your API key is valid and shows which organization it belongs to. This is the “hello world” of MCP — call it first to make sure everything is wired up. Parameters: None. What it returns: Your organization name and a verified status. Example prompt: “Verify my MarginFront connection”2. list_customers
What it does: Lists your customers with optional search and pagination. Good for browsing your customer list or finding a specific customer by name. Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| page | number | No | 1 | Which page of results to show |
| limit | number | No | 20 | How many results per page (1-100) |
| search | string | No | — | Search by customer name or external ID |
3. get_customer
What it does: Gets detailed information about one specific customer, including their subscriptions. Parameters:| Name | Type | Required | Description |
|---|---|---|---|
| customerId | string | Yes | The customer’s MarginFront UUID (not their external ID) |
Note: This tool needs the MarginFront UUID, not the external ID you use in your own system. Use list_customers first to find the UUID.
4. list_invoices
What it does: Lists invoices with optional filters by status or customer. Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| status | string | No | — | Filter by status: "draft", "pending", "paid", "overdue", or "void" |
| customerId | string | No | — | Filter by customer UUID |
| page | number | No | 1 | Which page of results |
| limit | number | No | 20 | Results per page (1-100) |
5. get_invoice
What it does: Gets full details about one invoice, including every line item and payment history. Parameters:| Name | Type | Required | Description |
|---|---|---|---|
| invoiceId | string | Yes | The invoice’s UUID |
6. list_events
What it does: Lists usage events (the raw records of what your customers actually used) with optional filters. Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| page | number | No | 1 | Which page of results |
| limit | number | No | 20 | Results per page (1-100) |
| customerId | string | No | — | Filter by customer UUID |
| agentId | string | No | — | Filter by agent UUID |
| signalId | string | No | — | Filter by signal UUID |
| startDate | string | No | — | Only show events after this date (ISO 8601 format, e.g. "2026-04-01") |
| endDate | string | No | — | Only show events before this date (ISO 8601 format) |
7. get_usage_analytics
What it does: Gets aggregated usage analytics (totals and trends) for a date range. Unlikelist_events which shows individual events, this gives you the big picture — totals, breakdowns, and time-series data.
Parameters:
| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| startDate | string | Yes | — | Start of the date range (ISO 8601, e.g. "2026-04-01") |
| endDate | string | Yes | — | End of the date range (ISO 8601, e.g. "2026-04-12") |
| groupBy | string | No | — | How to break down the data: "agent", "customer", "signal", "model", or "day" |
8. list_subscriptions
What it does: Lists customer subscriptions (which customer is on which pricing plan). Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| status | string | No | — | Filter by status: "active", "canceled", "past_due", "trialing" |
| customerId | string | No | — | Filter by customer UUID |
| page | number | No | 1 | Which page of results |
| limit | number | No | 20 | Results per page (1-100) |
Write Tools (3)
These tools create or modify data. They change things in MarginFront, so the AI will usually confirm before calling them.9. record_usage
What it does: Records a single usage event — one measurement of a customer using your AI agent. This is how MarginFront learns what to bill for. There are two kinds of events:- LLM events (chatbots, summarizers, etc.): pass
inputTokensandoutputTokens. - Non-LLM events (SMS, web scraping, API calls, etc.): pass
quantityinstead.
| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| customerExternalId | string | Yes | — | Your customer’s ID in your system, e.g. "acme-001" |
| agentCode | string | Yes | — | The agent/product code from your dashboard, e.g. "cs-bot-v2" |
| signalName | string | Yes | — | The metric being tracked, e.g. "messages" or "pages_processed" |
| model | string | Yes | — | The model identifier, e.g. "gpt-4o", "claude-sonnet-4-6", "twilio-sms" |
| modelProvider | string | Yes | — | The provider name in lowercase, e.g. "openai", "anthropic", "twilio" |
| inputTokens | number | No | — | Number of input/prompt tokens (for LLM events) |
| outputTokens | number | No | — | Number of output/completion tokens (for LLM events) |
| quantity | number | No | 1 | Number of billing units (for non-LLM events) |
| usageDate | string | No | now | ISO 8601 date for backdating, e.g. "2026-04-01T00:00:00Z" |
| metadata | object | No | — | Custom key-value pairs stored with the event (not used for billing) |
get_needs_attention and map_model to fix it.
Example prompt: “Record a usage event: customer acme-001 used cs-bot, signal messages, gpt-4o from openai, 500 input tokens, 120 output tokens”
Important: If you get a “NEEDS_COST_BACKFILL” response, do NOT re-send the event. The event was saved. The model just isn’t in the pricing table yet. Useget_needs_attentionto see which models need mapping, thenmap_modelto fix them.
10. record_usage_batch
What it does: Records multiple usage events at once (1 to 100 per request). Each record has the same fields asrecord_usage. You can mix LLM events and non-LLM events in the same batch.
Parameters:
| Name | Type | Required | Description |
|---|---|---|---|
| records | array | Yes | An array of 1-100 usage records. Each record has the same fields as record_usage (see above). |
11. create_customer
What it does: Creates a new customer in MarginFront. Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| name | string | Yes | — | Customer’s display name, e.g. "Acme Corp" |
| externalId | string | No | — | Your system’s ID for this customer, e.g. "acme-001" |
| string | No | — | Customer’s email address | |
| phone | string | No | — | Customer’s phone number |
Tip: Always set externalId when creating a customer. That’s the ID you’ll use when recording usage events later, so it should match whatever ID you use for this customer in your own system.
Diagnostic Tool (1)
This tool helps you find and fix data issues.12. get_needs_attention
What it does: Finds usage events where the model+provider combination isn’t in the pricing table. These events were saved (the data isn’t lost), but their cost is null because MarginFront doesn’t know how much that model costs. Parameters:| Name | Type | Required | Default | Description |
|---|---|---|---|---|
| startDate | string | No | 30 days ago | Only look at events after this date (ISO 8601) |
| endDate | string | No | now | Only look at events before this date (ISO 8601) |
Important: These events ARE saved — they just have cost=null. Do NOT re-send them. Use map_model (below) to tell MarginFront what pricing to use, and it will backfill the costs automatically.
Destructive Tool (1)
This tool modifies existing data. “Destructive” sounds scary, but it’s actually a fix-it tool — and it’s safe to run more than once (it’s idempotent, meaning running it twice produces the same result as running it once).13. map_model
What it does: Maps an unknown model to a known one in the pricing table, then backfills costs for all affected events. This creates a permanent, organization-scoped mapping — once you map it, future events with the same model+provider will have their costs calculated automatically. You tell it the “source” (the unknown model) and the “target” (the known model to price it as). You can identify the target two ways:- By name: pass
targetModel+targetProvider(e.g., map “gpt-4o-2024-08-06” to “gpt-4o” from “openai”). - By ID: pass
targetPricingId(the UUID of the specific pricing table row).
| Name | Type | Required | Description |
|---|---|---|---|
| sourceModel | string | Yes | The unknown model name to map FROM, e.g. "gpt-4o-2024-08-06" |
| sourceProvider | string | Yes | The unknown provider to map FROM, e.g. "openai" |
| targetPricingId | string | No* | UUID of the target pricing row to map TO |
| targetModel | string | No* | Known model name to map TO, e.g. "gpt-4o" |
| targetProvider | string | No* | Known provider to map TO, e.g. "openai" |
*You must provide eitherWhat it returns: Confirmation of the mapping, how many events had their costs backfilled, and the mapping ID. Example prompt: “Map model gpt-4o-2024-08-06 from openai to gpt-4o from openai”targetPricingIdOR bothtargetModel+targetProvider. One or the other, not both.
Safe to run again: If you accidentally run this twice with the same inputs, nothing bad happens. It’s idempotent.

