@stripe/mcp
Version:
A command line tool for setting up Stripe MCP server
120 lines (119 loc) • 4.36 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.parseArgs = parseArgs;
exports.main = main;
const modelcontextprotocol_1 = require("@stripe/agent-toolkit/modelcontextprotocol");
const stdio_js_1 = require("@modelcontextprotocol/sdk/server/stdio.js");
const colors_1 = require("colors");
const ACCEPTED_ARGS = ['api-key', 'tools', 'stripe-account'];
const ACCEPTED_TOOLS = [
'customers.create',
'customers.read',
'products.create',
'products.read',
'prices.create',
'prices.read',
'paymentLinks.create',
'invoices.create',
'invoices.update',
'invoiceItems.create',
'balance.read',
'refunds.create',
'paymentIntents.read',
'subscriptions.read',
'subscriptions.update',
'documentation.read',
];
function parseArgs(args) {
const options = {};
args.forEach((arg) => {
if (arg.startsWith('--')) {
const [key, value] = arg.slice(2).split('=');
if (key == 'tools') {
options.tools = value.split(',');
}
else if (key == 'api-key') {
if (!value.startsWith('sk_') && !value.startsWith('rk_')) {
throw new Error('API key must start with "sk_" or "rk_".');
}
options.apiKey = value;
}
else if (key == 'stripe-account') {
// Validate api-key format
if (!value.startsWith('acct_')) {
throw new Error('Stripe account must start with "acct_".');
}
options.stripeAccount = value;
}
else {
throw new Error(`Invalid argument: ${key}. Accepted arguments are: ${ACCEPTED_ARGS.join(', ')}`);
}
}
});
// Check if required tools arguments is present
if (!options.tools) {
throw new Error('The --tools arguments must be provided.');
}
// Validate tools against accepted enum values
options.tools.forEach((tool) => {
if (tool == 'all') {
return;
}
if (!ACCEPTED_TOOLS.includes(tool.trim())) {
throw new Error(`Invalid tool: ${tool}. Accepted tools are: ${ACCEPTED_TOOLS.join(', ')}`);
}
});
// Check if API key is either provided in args or set in environment variables
const apiKey = options.apiKey || process.env.STRIPE_SECRET_KEY;
if (!apiKey) {
throw new Error('Stripe API key not provided. Please either pass it as an argument --api-key=$KEY or set the STRIPE_SECRET_KEY environment variable.');
}
options.apiKey = apiKey;
return options;
}
function handleError(error) {
console.error((0, colors_1.red)('\n🚨 Error initializing Stripe MCP server:\n'));
console.error((0, colors_1.yellow)(` ${error.message}\n`));
}
async function main() {
const options = parseArgs(process.argv.slice(2));
// Create the StripeAgentToolkit instance
const selectedTools = options.tools;
const configuration = { actions: {} };
if (selectedTools.includes('all')) {
ACCEPTED_TOOLS.forEach((tool) => {
const [product, action] = tool.split('.');
configuration.actions[product] = {
...configuration.actions[product],
[action]: true,
};
});
}
else {
selectedTools.forEach((tool) => {
const [product, action] = tool.split('.');
configuration.actions[product] = { [action]: true };
});
}
configuration.context = {
mode: 'modelcontextprotocol',
};
// Append stripe account to configuration if provided
if (options.stripeAccount) {
configuration.context.account = options.stripeAccount;
}
const server = new modelcontextprotocol_1.StripeAgentToolkit({
secretKey: options.apiKey,
configuration: configuration,
});
const transport = new stdio_js_1.StdioServerTransport();
await server.connect(transport);
// We use console.error instead of console.log since console.log will output to stdio, which will confuse the MCP server
console.error((0, colors_1.green)('✅ Stripe MCP Server running on stdio'));
}
if (require.main === module) {
main().catch((error) => {
handleError(error);
});
}