FreeTaxUSA MCP Server
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., "@FreeTaxUSA MCP ServerHelp me file my W-2"
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.
FreeTaxUSA MCP Server
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.
How It Works
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]Features
15 tax filing tools across personal info, income, deductions, review, and filing
Session persistence -- login once, cookies survive between invocations
PII protection -- SSNs, account numbers, and EINs are automatically redacted from all tool outputs
Dynamic navigation -- discovers FreeTaxUSA's section structure at runtime
Anti-bot mitigations -- realistic viewport, disabled automation flags
State paywall detection -- warns before triggering the $15.99 state filing purchase
Prior year support -- configurable tax year for filing back taxes
Tools
Session Management
Tool | Description |
| Log in with email and password. Credentials used once, never stored. |
| Check if session is active, which tax year and section is loaded. |
Page Interaction
Tool | Description |
| Read all form fields and their current values on the active page. |
| Submit the current page and advance to the next. |
| Jump to a section by name ("income", "deductions") or SID number. |
Personal Information
Tool | Description |
| Fill name, SSN, DOB, occupation, and address. |
| Set filing status (single, married joint, head of household, etc.). |
Tax Overview
Tool | Description |
| Get return overview: refund/owed, AGI, filing status, completed sections. |
| Get current federal and state refund or amount owed. |
Income (Phase 2)
Tool | Description |
| Enter W-2 wage and withholding data. |
| Enter 1099 income (INT, DIV, MISC, NEC, R, G, SSA). |
Deductions, Review & Filing (Phase 3)
Tool | Description |
| Enter standard or itemized deductions. |
| Run error check and get review results before filing. |
| File Form 4868 for an automatic 6-month extension. |
| Get which sections are complete, incomplete, or have errors. |
Phase 2 and 3 tools are stubbed and will be implemented in upcoming releases.
Quick Start
Prerequisites
Node.js 20+
A FreeTaxUSA account (free to create)
Install
git clone https://github.com/schwarztim/freetaxusa-mcp.git
cd freetaxusa-mcp
npm install
npm run buildPlaywright will automatically install Chromium during npm install.
Configure
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"]
}
}
}Environment Variables
Variable | Default | Description |
|
| Set to |
|
| Browser profile directory |
|
| Tax year to file (change for prior years) |
Use
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 me@example.com, 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?Architecture
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 aliasesKey Design Decisions
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.
Security
This MCP handles sensitive financial data. The security model:
PII redaction: All tool outputs are filtered. SSNs, EINs, and account numbers are automatically masked.
No credential storage: Login credentials are provided per-call and never written to disk.
Restricted browser profile: The session directory (
~/.freetaxusa-mcp/browser-profile/) is created with 0700 permissions.State paywall guard: Navigation that would trigger a $15.99 purchase throws an error instead of proceeding.
Session expiry detection: Every tool checks for redirect to the login page before acting.
Development
# 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 startPrior Year Filing
To file back taxes, set the tax year:
FREETAXUSA_TAX_YEAR=2024 node dist/index.jsFreeTaxUSA supports free federal filing for prior years. Note that prior year returns cannot be e-filed -- they must be printed and mailed.
Roadmap
Phase 1: Session, navigation, personal info, tax summary
Phase 2: W-2 and 1099 income entry
Phase 3: Deductions, review, extension filing
Phase 4: W-2/1099 PDF import via Claude vision, section walkthroughs
Phase 5: Multi-year batch filing for back taxes
Disclaimer
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.
License
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/schwarztim/freetaxusa-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server