Skip to main content
Glama
DynamicEndpoints

pocketbase-mcp-server

create_stripe_customer

Generate a new customer profile in Stripe using this tool from pocketbase-mcp-server, enabling streamlined integration with Stripe for payment management and customer tracking.

Instructions

Create a new customer in Stripe

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault

No arguments

Implementation Reference

  • Core helper method implementing Stripe customer creation: checks for duplicates in PocketBase, creates in Stripe API, saves to PocketBase.
    async createCustomer(data: {
      email: string;
      name?: string;
      userId?: string;
      metadata?: Record<string, any>;
    }): Promise<StripeCustomer> {
      try {      // Check if customer already exists
        const existingCustomer = await this.pb.collection('stripe_customers')
          .getFirstListItem(`email="${data.email}"`)
          .catch(() => null);
    
        if (existingCustomer) {
          return existingCustomer as StripeCustomer;
        }
    
        // Create customer in Stripe
        const stripeCustomer = await this.stripe.customers.create({
          email: data.email,
          name: data.name,
          metadata: {
            userId: data.userId || '',
            ...data.metadata,
          },
        });
    
        // Save to PocketBase
        const customerRecord = await this.pb.collection('stripe_customers').create({
          email: data.email,
          name: data.name,
          stripeCustomerId: stripeCustomer.id,
          userId: data.userId,
          metadata: data.metadata || {},
        });
    
        return customerRecord as unknown as StripeCustomer;
      } catch (error: any) {
        throw new Error(`Failed to create customer: ${error.message}`);
      }
    }
  • Registers the create_stripe_customer MCP tool on the server, provides input schema, and defines handler that uses StripeService.createCustomer
    export function registerTools(server: any, pb: any): void {
      server.tool('create_stripe_customer', 'Create a Stripe customer', { type: 'object', properties: { email: { type: 'string' }, name: { type: 'string' } } }, async (args: any) => {
        const stripeService = new StripeService(pb);
        const customer = await stripeService.createCustomer({ email: args.email, name: args.name });
        return { success: true, customer };
      });
    }
  • Direct registration and detailed handler for create_stripe_customer in agent-simple.ts, with error handling and lazy service loading.
    'create_stripe_customer',
    'Create a new customer in Stripe',
    {
      type: 'object',
      properties: {
        email: { type: 'string', format: 'email', description: 'Customer email' },
        name: { type: 'string', description: 'Customer name' }
      },
      required: ['email']
    },
    async ({ email, name }) => {
      // Lazy load Stripe service
      await this.ensureStripeService();
      
      if (!this.stripeService) {
        return {
          content: [{
            type: 'text',
            text: JSON.stringify({
              error: 'Stripe service not available. Please set STRIPE_SECRET_KEY environment variable.'
            })
          }]
        };
      }
    
      try {
        const customer = await this.stripeService.createCustomer({ email, name });
        return {
          content: [{
            type: 'text',
            text: JSON.stringify(customer, null, 2)
          }]
        };
      } catch (error: any) {
        return {
          content: [{
            type: 'text',
            text: JSON.stringify({
              error: `Failed to create Stripe customer: ${error.message}`
            })
          }]
        };
      }
    }
  • Tool schema definition in the static tools list returned by tools/list in Cloudflare Worker mode.
      name: 'create_stripe_customer',
      description: 'Create a new customer in Stripe',
      inputSchema: {
        type: 'object',
        properties: {
          email: { type: 'string', format: 'email', description: 'Customer email' },
          name: { type: 'string', description: 'Customer name' }
        },
        required: ['email']
      }
    },
Install Server

Other Tools

Related Tools

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/DynamicEndpoints/pocketbase-mcp-server'

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