Skip to main content
Glama
getAlby

Lightning Tools MCP Server

by getAlby

request_invoice

Generate a Lightning Network invoice by specifying recipient address, amount, and optional payment details for Bitcoin transactions.

Instructions

Request an invoice from a lightning address

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
lightning_addressYesthe recipient's lightning address
amountYesamount in sats
descriptionNo
payer_dataNo

Implementation Reference

  • The handler function that executes the tool: creates a LightningAddress from the input, fetches LNURL data, requests an invoice with the given amount, description, and payer data, then returns the invoice as JSON text content.
    async (params) => { const ln = new LightningAddress(params.lightning_address); // fetch the LNURL data await ln.fetch(); const invoice = await ln.requestInvoice({ satoshi: params.amount, comment: params.description || undefined, payerdata: params.payer_data || undefined, }); return { content: [ { type: "text", text: JSON.stringify(invoice, null, 2), }, ], }; }
  • Zod schema defining the input parameters: lightning_address (string), amount (number in sats), optional description (string), optional payer_data (object).
    { lightning_address: z .string() .describe("the recipient's lightning address"), amount: z.number().describe("amount in sats"), description: z .string() .describe("note, memo or description describing the invoice") .nullish(), payer_data: z .object({}) .passthrough() .describe( "metadata to include with the payment such as the payer's name" ) .nullish(), },
  • The registerRequestInvoiceTool function that registers the "request_invoice" tool on the MCP server using server.tool with name, description, input schema, and handler.
    export function registerRequestInvoiceTool(server: McpServer) { server.tool( "request_invoice", "Request an invoice from a lightning address", { lightning_address: z .string() .describe("the recipient's lightning address"), amount: z.number().describe("amount in sats"), description: z .string() .describe("note, memo or description describing the invoice") .nullish(), payer_data: z .object({}) .passthrough() .describe( "metadata to include with the payment such as the payer's name" ) .nullish(), }, async (params) => { const ln = new LightningAddress(params.lightning_address); // fetch the LNURL data await ln.fetch(); const invoice = await ln.requestInvoice({ satoshi: params.amount, comment: params.description || undefined, payerdata: params.payer_data || undefined, }); return { content: [ { type: "text", text: JSON.stringify(invoice, null, 2), }, ], }; } ); }
  • src/index.ts:28-28 (registration)
    Invocation of the registerRequestInvoiceTool function in the main server constructor to add the tool to the MCP server instance.
    registerRequestInvoiceTool(this._server);

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/getAlby/lightning-tools-mcp-server'

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