loading…
Search for a command to run...
loading…
Enables AI agents to file taxes through FreeTaxUSA by automating a browser, allowing form filling, navigation, and refund checks via natural language.
Enables AI agents to file taxes through FreeTaxUSA by automating a browser, allowing form filling, navigation, and refund checks via natural language.
An MCP server that lets AI agents file your taxes through FreeTaxUSA -- the free federal tax filing service.
Instead of paying $120+ for TurboTax's guided interview, this MCP gives any AI assistant (Claude, etc.) the ability to navigate FreeTaxUSA's interface, fill forms, check your refund, and walk you through filing -- conversationally.
Federal filing is free. State is $15.99. That's it.
This is not an API wrapper. FreeTaxUSA has no public API.
This MCP uses Playwright to drive a real Chromium browser session against FreeTaxUSA's web interface. It reads forms via the accessibility tree, fills fields, navigates between sections, and returns structured data to the AI agent -- which then talks to you like a human tax preparer would.
You: "Here's my W-2, help me file"
|
[Claude / AI Agent]
|
[FreeTaxUSA MCP] <-- this project
|
[Playwright + Chromium]
|
[freetaxusa.com]
|
[IRS e-file]
| Tool | Description |
|---|---|
authenticate |
Log in with email and password. Credentials used once, never stored. |
get_session_status |
Check if session is active, which tax year and section is loaded. |
| Tool | Description |
|---|---|
read_current_page |
Read all form fields and their current values on the active page. |
save_and_continue |
Submit the current page and advance to the next. |
navigate_section |
Jump to a section by name ("income", "deductions") or SID number. |
| Tool | Description |
|---|---|
fill_taxpayer_info |
Fill name, SSN, DOB, occupation, and address. |
fill_filing_status |
Set filing status (single, married joint, head of household, etc.). |
| Tool | Description |
|---|---|
get_tax_summary |
Get return overview: refund/owed, AGI, filing status, completed sections. |
get_refund_estimate |
Get current federal and state refund or amount owed. |
| Tool | Description |
|---|---|
fill_w2_income |
Enter W-2 wage and withholding data. |
fill_1099_income |
Enter 1099 income (INT, DIV, MISC, NEC, R, G, SSA). |
| Tool | Description |
|---|---|
fill_deductions |
Enter standard or itemized deductions. |
review_return |
Run error check and get review results before filing. |
file_extension |
File Form 4868 for an automatic 6-month extension. |
get_form_status |
Get which sections are complete, incomplete, or have errors. |
Phase 2 and 3 tools are stubbed and will be implemented in upcoming releases.
git clone https://github.com/schwarztim/freetaxusa-mcp.git
cd freetaxusa-mcp
npm install
npm run build
Playwright will automatically install Chromium during npm install.
Add to your Claude Code MCP configuration (~/.claude/user-mcps.json):
{
"mcpServers": {
"freetaxusa": {
"type": "stdio",
"command": "node",
"args": ["/path/to/freetaxusa-mcp/dist/index.js"]
}
}
}
Or for Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"freetaxusa": {
"command": "node",
"args": ["/path/to/freetaxusa-mcp/dist/index.js"]
}
}
}
| Variable | Default | Description |
|---|---|---|
FREETAXUSA_HEADLESS |
true |
Set to false to see the browser window |
FREETAXUSA_USER_DATA_DIR |
~/.freetaxusa-mcp/browser-profile/ |
Browser profile directory |
FREETAXUSA_TAX_YEAR |
2025 |
Tax year to file (change for prior years) |
Once configured, start a conversation with Claude:
You: I need to file my taxes. Log me in to FreeTaxUSA.
Claude: I'll authenticate you now. What's your FreeTaxUSA email and password?
You: email is [email protected], password is hunter2
Claude: [calls authenticate tool] You're logged in for tax year 2025.
Let's start with your personal information. What's your full name?
You: John Smith, SSN 123-45-6789, born 01/15/1990
Claude: [calls fill_taxpayer_info] Done. Your address?
You: 123 Main St, Anytown PA 19301
Claude: [fills address, calls save_and_continue]
Personal info is saved. Your current refund estimate is $2,847.
Let's move to income. Do you have W-2s to enter?
src/
index.ts # Entry point (stdio transport)
server.ts # MCP server + tool registration
browser/
context.ts # Persistent browser context + async mutex
navigation.ts # SID-based navigation + dynamic discovery
forms.ts # Form reading/filling via accessible labels
tools/
session.ts # authenticate, get_session_status
overview.ts # get_tax_summary, get_refund_estimate
personal.ts # fill_taxpayer_info, fill_filing_status
income.ts # fill_w2_income, fill_1099_income
deductions.ts # fill_deductions
review.ts # review_return
filing.ts # file_extension, get_form_status
page.ts # read_current_page, save_and_continue, navigate_section
security/
pii-filter.ts # SSN/EIN/account number redaction
types/
tax.ts # TypeScript interfaces
sections.ts # SID mapping + section aliases
Accessibility tree over CSS selectors. Form elements are targeted by their accessible label (role + name), not by CSS class or ID. This survives UI redesigns that change styling but preserve semantics.
Dynamic SID discovery. FreeTaxUSA uses ?sid=N URL parameters for navigation. SID values can change between tax years. On first page load, the MCP scrapes navigation links to build a live SID map, with a static fallback.
PII filter on all outputs. Every string returned by every tool passes through filterPII() before reaching the MCP transport. SSNs are masked to ***-**-NNNN, EINs to **-***NNNN, and account numbers to ****NNNN. This protects against accidental PII exposure in AI conversation logs.
Single-page mutex. The browser has one active page. An async mutex serializes all tool calls to prevent race conditions from concurrent invocations.
Credentials never stored. Email and password are accepted as tool inputs, used to fill the login form, and discarded. The persistent browser context retains session cookies only. The profile directory is chmod 0700.
This MCP handles sensitive financial data. The security model:
~/.freetaxusa-mcp/browser-profile/) is created with 0700 permissions.# Build
npm run build
# Run in development (auto-recompile)
npm run dev
# Run tests
npm test
# Watch tests
npm run test:watch
# Run with visible browser for debugging
FREETAXUSA_HEADLESS=false npm run start
To file back taxes, set the tax year:
FREETAXUSA_TAX_YEAR=2024 node dist/index.js
FreeTaxUSA supports free federal filing for prior years. Note that prior year returns cannot be e-filed -- they must be printed and mailed.
This project is not affiliated with, endorsed by, or associated with FreeTaxUSA, TaxHawk Inc., or Intuit. FreeTaxUSA is a registered trademark of TaxHawk, Inc. Use of this tool is subject to FreeTaxUSA's Terms of Use. This tool automates a web browser -- the same actions a human would perform manually. You are responsible for the accuracy of your tax return.
MIT
Выполни в терминале:
claude mcp add freetaxusa-mcp-server -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.