Skip to main content
Glama
elcukro

bank-mcp

by elcukro

search_transactions

Find specific bank transactions by searching descriptions, merchant names, and references to identify payments or payees.

Instructions

Full-text search across transaction descriptions, merchant names, and references. Use for finding specific payments or payees.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
queryYesSearch text — matched against description, merchant name, and reference.
connectionIdNo
dateFromNo
dateToNo
limitNoMax results. Default 50.

Implementation Reference

  • Main handler function that executes search_transactions logic. Fetches transactions using listTransactions for the specified date range/connection, then filters them locally by matching the query string (case-insensitive) against description, merchant name, and reference fields, applying the specified limit.
    export async function searchTransactions(
      args: z.infer<typeof searchTransactionsSchema>,
    ): Promise<unknown> {
      // Fetch all transactions for the date range, then filter locally
      const transactions = await listTransactions({
        connectionId: args.connectionId,
        dateFrom: args.dateFrom,
        dateTo: args.dateTo,
      });
    
      const q = args.query.toLowerCase();
      const limit = args.limit || 50;
    
      const matches = transactions.filter((t) => {
        const fields = [t.description, t.merchantName, t.reference].filter(Boolean);
        return fields.some((f) => f!.toLowerCase().includes(q));
      });
    
      return matches.slice(0, limit);
    }
  • Input schema for search_transactions tool using Zod. Defines required 'query' parameter (search text) and optional parameters: connectionId, dateFrom, dateTo, and limit (default 50).
    export const searchTransactionsSchema = z.object({
      query: z
        .string()
        .describe("Search text — matched against description, merchant name, and reference."),
      connectionId: z.string().optional(),
      dateFrom: z.string().optional(),
      dateTo: z.string().optional(),
      limit: z.number().optional().describe("Max results. Default 50."),
    });
  • src/server.ts:37-42 (registration)
    Tool registration in the TOOLS array. Defines the tool name 'search_transactions', description for full-text search across transactions, and maps to the searchTransactionsSchema for input validation.
    {
      name: "search_transactions",
      description:
        "Full-text search across transaction descriptions, merchant names, and references. Use for finding specific payments or payees.",
      inputSchema: z.toJSONSchema(searchTransactionsSchema),
    },
  • src/server.ts:63-64 (registration)
    Handler mapping in the handlers record that routes 'search_transactions' tool calls to the searchTransactions function with schema validation.
    search_transactions: (args) =>
      searchTransactions(searchTransactionsSchema.parse(args)),

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/elcukro/bank-mcp'

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