TallyPrime MCP Server

TallyPrime MCP Server

Gives AI models native-level control over TallyPrime ERP, covering 169+ tools across all functional modules including masters, vouchers, reports, GST, payroll, and more.

Category
Visit Server

README

TallyPrime MCP Server

A production-grade Model Context Protocol (MCP) server that gives AI models complete, native-level control over TallyPrime ERP — covering every functional module across 169+ tools.

Architecture

                    ┌─ Stdio Transport (Claude Desktop / CLI)
AI Model ──► MCP ──┤
                    └─ StreamableHTTP (port 4000, remote clients)
                          │
                          ▼
                    TallyPrime XML Server (port 9000)
                          │
                    ├─ UTF-16LE encoded communication
                    ├─ Serial request queue (single-threaded safety)
                    ├─ Standard XML Export (Method A)
                    ├─ Inline TDL Queries (Method B)
                    ├─ XML Import (Method C)
                    ├─ TDL Actions (Method D)
                    └─ Object Export (Method E)

Three-Layer System

Layer Purpose Example
Standard XML API CRUD operations, report exports Create ledger, fetch Trial Balance
Inline TDL Queries Complex filtered queries built programmatically "All debtors with balance > 1L in Maharashtra"
Persistent TDL File Pre-built collections loaded on Tally startup MCP Ledgers, MCP StockItems, MCP FinancialSnapshot

Quick Start

Prerequisites

  • TallyPrime running with XML Server enabled (port 9000)
  • Node.js 20+

Setup

# Clone & install
cd tally-mcp-server
npm install

# Configure
cp .env.example .env
# Edit .env with your Tally settings

# Run in development (HTTP mode)
npm run dev

# Run in Stdio mode (for Claude Desktop)
npm run dev:stdio

# Build & run production
npm run build
npm start          # HTTP mode
npm run start:stdio  # Stdio mode

Docker

docker compose up -d

Transport Modes

Stdio (for Claude Desktop / CLI)

Add to your Claude Desktop config (claude_desktop_config.json):

{
  "mcpServers": {
    "tally": {
      "command": "node",
      "args": ["/path/to/tally-mcp-server/dist/index.js", "--stdio"]
    }
  }
}

Or set the environment variable:

MCP_TRANSPORT=stdio node dist/index.js

StreamableHTTP (for remote / web clients)

{
  "mcpServers": {
    "tally": {
      "url": "http://localhost:4000/mcp",
      "transport": "streamable-http"
    }
  }
}

Configuration

Variable Default Description
TALLY_HOST localhost TallyPrime hostname
TALLY_PORT 9000 TallyPrime XML server port
TALLY_TIMEOUT_MS 30000 Request timeout in ms
TALLY_COMPANY (auto) Force a specific company (optional)
MCP_SERVER_PORT 4000 HTTP transport port
MCP_TRANSPORT http Transport mode: stdio or http
MASTER_CACHE_TTL_MS 300000 Master cache TTL (5 min)
LOG_LEVEL info Winston log level

Tool Modules (169+ tools)

# Module Tools Description
1 Masters 28 Ledgers, groups, stock items, units, godowns, cost centres, currencies
2 Vouchers 16 Sales, purchases, receipts, payments, journals, contra, credit/debit notes
3 Orders 10 Sales/purchase orders, delivery/receipt notes, rejections
4 Financial Reports 15 Trial balance, P&L, balance sheet, cash flow, daybook, ratio analysis
5 Inventory Reports 10 Stock summary, movement, batch, expiry, reorder, valuation
6 Outstanding 8 Receivables, payables, ageing analysis, bill-wise, overdue
7 GST 18 GSTR-1/2A/2B/3B, HSN, e-Invoice, e-Way Bill, ITC, reconciliation
8 TDS/TCS 12 Computation, forms 26Q/27Q/16, challans, PAN verification
9 Payroll 20 Employees, pay heads, salary structures, payslips, PF/ESI/gratuity
10 Manufacturing 14 BOM, production, consumption, job costing, yield analysis
11 Banking 10 Bank reconciliation, cheque register, PDC, cash position
12 Budgets 8 Budget CRUD, variance, utilization, scenario reports
13 Security 8 Users, audit trail, altered/deleted voucher logs, exceptions
14 Company 8 Company info, connection test, cache refresh, feature status
15 Bulk Operations 12 Batch create/update/delete masters & vouchers
16 TDL Query Engine 12 Custom queries, inline TDL, functions, raw XML, search, reference

Key Technical Features

  • UTF-16LE encoding — Correct wire encoding for Tally's XML server (supports Indian languages: Hindi, Tamil, etc.)
  • Serial request queue — All requests are serialized to protect Tally's single-threaded XML server from concurrent request crashes
  • EXCEPTION/LINEERROR/STATUS detection — Comprehensive error detection covering all Tally error response formats
  • Master name cache with TTL — Fast ledger/stock/group name lookups without hitting Tally
  • Persistent TDL file — Pre-built optimized collections loaded on Tally startup
  • Tally value parsers — Correct parsing of Tally's date, amount, quantity, rate, and boolean formats
  • Input validation — Zod schemas with GSTIN/PAN/date format validators
  • Structured logging — Winston logger with configurable levels

Persistent TDL File

Install tdl/tally-mcp.tdl in your TallyPrime TDL folder for optimized pre-built collections:

Collection Contents
MCP Ledgers All ledgers with key financial fields
MCP StockItems All stock items with inventory fields
MCP Groups All account groups
MCP Vouchers All vouchers (date-filtered via SV)
MCP Debtors Sundry Debtors with balances
MCP Creditors Sundry Creditors with balances
MCP BankAccounts Bank accounts with balances
MCP CostCentres Cost centres
MCP Employees All employees with details
MCP CashBankSummary Cash + bank position
MCP FinancialSnapshot Quick financial summary function

API Endpoints (HTTP mode only)

Endpoint Method Description
/mcp POST MCP StreamableHTTP transport
/mcp GET SSE stream (session-based)
/mcp DELETE Close session
/health GET Health check + cache stats

Project Structure

tally-mcp-server/
├── src/
│   ├── index.ts              # Entry point (Stdio + HTTP)
│   ├── server.ts             # MCP server factory
│   ├── tally/
│   │   ├── client.ts         # HTTP client (UTF-16LE, serial queue)
│   │   ├── xml-builder.ts    # XML request builders
│   │   ├── xml-parser.ts     # XML response parser + value helpers
│   │   ├── tdl-builder.ts    # Inline TDL builder
│   │   └── state.ts          # Master cache with TTL
│   ├── tools/                # 16 tool modules (169+ tools)
│   └── utils/
│       ├── logger.ts         # Winston logger
│       ├── validators.ts     # GSTIN/PAN/date validators
│       ├── date-utils.ts     # Date utilities
│       └── helpers.ts        # Shared result/error helpers
├── tdl/
│   └── tally-mcp.tdl        # Persistent TDL file
├── package.json
└── tsconfig.json

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured