Tally Prime MCP Server
Connects Tally Prime ERP data to AI assistants via MCP, enabling natural language queries for financial reports, stock summaries, and ledger balances.
README
Tally Prime MCP Server
Tally Prime MCP (Model Context Protocol) Server implementation to feed Tally Prime ERP data to popular LLM like Claude, ChatGPT supporting MCP client. This MCP Server helps expose functionalities of Tally to LLM directly.
Prerequisites
- Tally Prime (Silver / Gold)
- Node JS
Ensure below things are pre-installed and setup:
- Ensure to download & install Node JS from official website
- XML Port of Tally Prime must be enabled (F1 > Settings > Connectivity > Client/Server configuration) with below settings
TallyPrime acts as = Server
Port = 9000
Note: Kindly avoid using Educational version of Tally Prime, which has limitations of date range. It will result in invalid / partial data being fed to LLM, leading to highly degraded & incorrect responses.
Download
Download the latest release from GitHub: <br> https://github.com/QalaLabs/tally-mcp-server/releases
Last updated: version 7.3 [31-May-2026]
Refer docs/CHANGELOG.md for details
Supported Platform
Implementation was tested on below AI platform
| Platform | Local | Remote |
|---|---|---|
| Claude AI | :heavy_check_mark: | :heavy_check_mark: |
| ChatGPT | :heavy_check_mark: |
Setup (Local)
This mode of setup is to be used when MCP Client (like Claude Desktop, Perplexity etc.) and Tally Prime both exists in local PC. MCP Client software itself runs the MCP Server internally in such scenario.
Simply download & extract zip file somewhere on the disk. Assuming that we downloaded & extracted zip file on below path (folder)
D:\Software\Tally MCP Server
<image src="https://excelkida.com/image/github/explorer-tally-mcp-server.png" height="265" width="766" />
A sample setup for few popular tools is demonstrated.
Claude Desktop
Desktop version of Claude AI supports loading of local MCP server. Ensure you have Pro / Team / Max / Enterprise subscription of Claude, which supports higher limit compared to Free. MCP makes multiple calls to Tally for validation and inference, which might exhaust free limits quickly. Download Claude Desktop from following link claude.ai/download
One-click installation (via Extension)
Go to menu > File > Settings
<image src="https://excelkida.com/image/github/claude-desktop-settings-menu.png" height="185" width="335">
Extensions > Advance Settings
<image src="https://excelkida.com/image/github/claude-desktop-settings-extension.png" height="553" width="928">
Click on install extension button
<image src="https://excelkida.com/image/github/claude-desktop-extension-page.png" height="619" width="868">
Browse the extension file (with file extension mcpb) download at the start
<image src="https://excelkida.com/image/github/claude-desktop-extension-install.png" height="843" width="696">
A dialog window will appear asking Do you want to install Tally Prime? click Install button, which would install the Tally MCP Server
Installation via Config file (via Developer menu)
Go to menu > File > Settings > Developer
<image src="https://excelkida.com/image/github/claude-desktop-developer-setting.png" height="751" width="1045" />
This will open My Computer window. Right click and edit claude_desktop_config.json file (via Notepad) with as below JSON
{
"mcpServers": {
"Tally Prime": {
"command": "node",
"args": ["D:\\Software\\Tally MCP Server\\dist\\index.mjs"]
}
}
}
Note: single slash in folder path needs to be substituted with double slash
Save the file. Close Claude Desktop (menu > File > Exit) and again re-launch it.
Verify by clicking on Tools button and check if Tally Prime appears in the list (screenshot below)
<image src="https://excelkida.com/image/github/claude-desktop-tally-mcp-server-tool-display.png" height="595" width="722" />
Perplexity Desktop
Perplexity Desktop version for MacOS supports connecting to local MCP server. Configuration file (JSON format) is same as demonstrated for Claude Desktop. In absense of MacBook, documentation with screenshot could not be written. Kindly refer to below blog on perplexity website, which explains the steps.
Perplexity Desktop MCP Connectivity
Setup (Cloud)
This mode of setup is to be used, when using browser-based MCP client like ChatGPT, Claude AI, Copilot, OR mobile-based app for these LLM which cannot access Tally Prime running inside local PC. In this scenario, MCP Server needs to run as web-server, internally connected to Tally securely. Setup is quite complicated, and is covered in detail in docs folder of this project.
- Linux-based Server
- Windows Server (exploration in-progress)
Available Tools
This server currently exposes 19 MCP tools.
metadata-collection
Returns metadata for supported collections.
Input No input.
Output JSON array with objects containing:
collectiondescription
query-option-values
Returns predefined option values used by input fields.
Input
| Argument | Description |
|---|---|
| optionName | Supported: country-state |
Output JSON array of option values for the selected option name.
metadata-fields
Returns field metadata for a selected collection.
Input
| Argument | Description |
|---|---|
| collection | Collection name. Use metadata-collection to discover valid values |
Output
JSON array of field metadata containing field name, description (if any), and normalized datatype (string, number, date, boolean).
query-database
Runs SQL query on in-memory pglite tables previously created by reporting tools.
Input
| Argument | Description |
|---|---|
| sql | SELECT query only |
| outputFormat | One of JSON Array of Objects, JSON with Schema and Rows, CSV, Markdown Table. Default is JSON Array of Objects which is preferred format |
Output Query result in tab-separated text format.
query-collection
Queries a Tally collection for selected fields and caches output in an in-memory table.
Input
| Argument | Description |
|---|---|
| collection | Collection name |
| fields | Array of field names to fetch |
| targetCompany (optional) | Company name (defaults to active company) |
| fromDate (optional) | Date in YYYY-MM-DD |
| toDate (optional) | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." }
list-master
Fetches list of masters for validation and auto-completion.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| collection | One of: group, ledger, vouchertype, unit, godown, stockgroup, stockitem, costcategory, costcentre, attendancetype, company, currency, gstin, gstclassification |
| containsFilter (optional) | filter to apply CONTAINS operation to restrict values |
Output
JSON: { "list": [ ... ] }
chart-of-accounts
Extracts Chart of Accounts (or Group hierarchy) useful for preparing Balance Sheet, Profit and Loss, Trial Balance
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
Output
JSON: { "tableID": "..." } with columns:
ledger_namegroup_nameprimary_groupbs_pl(boolean) [true = Profit & Loss / false = Balance Sheet]dr_cr(boolean) [true = Debit / false = Credit]affects_gross_profit(boolean) [true = Affects Gross Profit / false = Does not affect Gross Profit]sort_position(number)
trial-balance
Fetches trial balance for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
| group_name (optional) | Filter by group name |
Output
JSON: { "tableID": "..." } with columns:
ledger_namegroup_nameopening_balance(number) [negative = Debit / positive = Credit]net_debitnet_creditclosing_balance(number) [negative = Debit / positive = Credit]
profit-loss
Fetches profit and loss data for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." } with columns:
ledger_namegroup_nameclosing_balance(number) [negative = Debit / positive = Credit]
balance-sheet
Fetches balance sheet data for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." } with columns:
ledger_namegroup_nameclosing_balance(number) [negative = Debit / positive = Credit]
stock-summary
Fetches stock item summary for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
| stockGroup (optional) | Filter by stock group name |
Output
JSON: { "tableID": "..." } with columns:
stock_item_namestock_group_nameopening_quantity(number)opening_value(number) [negative = Debit / positive = Credit]inward_quantity(number)inward_value(number)outward_quantity(number)outward_value(number)closing_quantity(number)closing_value(number) [negative = Debit / positive = Credit]
ledger-balance
Returns ledger closing balance as on date.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| ledgerName | Exact ledger name |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "amount": number } where negative = Debit and positive = Credit.
stock-item-balance
Returns stock item closing quantity as on date.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| itemName | Exact stock item name |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "quantity": number, "unit_of_measurement": string } when found.
bills-outstanding
Fetches receivable/payable bill-wise outstanding as on date.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| nature | receivable or payable |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." } with columns:
bill_datereference_numberoutstanding_amountparty_nameoverdue_days
ledger-account
Fetches ledger account statement for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| ledgerName | Ledger name |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." } with columns:
guiddatevoucher_typevoucher_numberalternate_ledgerparty_nameamount(number) [negative = Debit / positive = Credit]narration
stock-item-account
Fetches stock item account statement for period.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| itemName | Stock item name |
| fromDate | Date in YYYY-MM-DD |
| toDate | Date in YYYY-MM-DD |
Output
JSON: { "tableID": "..." } with columns:
datevoucher_typevoucher_numberparty_ledgerquantityamount(number) [negative = Debit / positive = Credit]narrationtracking_numbervoucher_category
ledger-create-update
Creates or updates one or more ledger.
Note: This tool has ability to modify existing ledger. Always backup your Company before instructing this tool.
Input
| Argument | Description |
|---|---|
| targetCompany (optional) | Company name (defaults to active company) |
| masters | Array of ledger master objects to create/update |
Master ledger object accepts following
| Property | Description |
|---|---|
| name | Ledger name or New Ledger name (during update) |
| _name | Existing ledger name |
| parent | Group under which ledger would exists |
| openingBalance | (optional) Opening Balance of the Ledger |
| isBillWise | (optional) flag to set Bill-by-Bill referencing |
| billCreditPeriod | (optional) Credit Period for bill in days |
| mailingDetails | (optional) Business Name for mailing purpose, country, state, pincode, address |
| gstRegistrationDetails | (optional) GST registration details like GST Number, Registration Type, Place of Supply (state) |
Output JSON result returned by import operation (success/failure details).
set-company
Sets active company context in Tally Prime.
Input
| Argument | Description |
|---|---|
| companyName | Company name to activate |
Output
JSON string: "OK" on success.
set-period
Sets active reporting period context in Tally Prime.
Input
| Argument | Description |
|---|---|
| fromDate | Start date in YYYY-MM-DD |
| toDate | End date in YYYY-MM-DD |
Output
JSON string: "OK" on success.
Contact
Project developed & maintained by: Qala Labs
Email: hello@qalalabs.com <br> GitHub: https://github.com/QalaLabs
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.