Skip to main content
Glama

Xero MCP Server

Official
MIT License
293
128
  • Apple
  • Linux
list-xero-report-balance-sheet.handler.ts1.83 kB
import { xeroClient } from "../clients/xero-client.js"; import { formatError } from "../helpers/format-error.js"; import { getClientHeaders } from "../helpers/get-client-headers.js"; import { ReportWithRow } from "xero-node"; import { XeroClientResponse } from "../types/tool-response.js"; import { ListReportBalanceSheetParams } from "../types/list-report-balance-sheet-params.js"; async function getReportBalanceSheet(params: ListReportBalanceSheetParams): Promise<ReportWithRow | null> { const { date, periods, timeframe, trackingOptionID1, trackingOptionID2, standardLayout, paymentsOnly, } = params; await xeroClient.authenticate(); const response = await xeroClient.accountingApi.getReportBalanceSheet( xeroClient.tenantId, date || undefined, periods || undefined, timeframe || undefined, trackingOptionID1 || undefined, trackingOptionID2 || undefined, standardLayout ?? undefined, paymentsOnly ?? undefined, getClientHeaders(), ); return response.body.reports?.[0] ?? null; } export async function listXeroReportBalanceSheet(params: ListReportBalanceSheetParams): Promise<XeroClientResponse<ReportWithRow>> { try { const balanceSheet = await getReportBalanceSheet(params); if (!balanceSheet) { return { result: null, isError: true, error: "Failed to fetch balance sheet data from Xero.", }; } return { result: balanceSheet, isError: false, error: null, }; } catch (error) { return { result: null, isError: true, error: formatError(error), }; } };

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/XeroAPI/xero-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server