Skip to main content
Glama
clockworked247

Flight + Stay Search MCP

search_multi_city

Search for multi-city flight itineraries with multiple segments, cabin class preferences, and passenger details using Duffel API integration.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
segmentsYesFlight segments for multi-city trip
cabinClassYesCabin class
adultsNoNumber of adult passengers
maxConnectionsNoMaximum number of connections

Implementation Reference

  • Executes the search_multi_city tool by building flight slices from input segments and requesting offers from the Duffel flight client.
    async (params: MultiCityRequest) => {
      try {
        const slices = [];
        
        // Build slices from segments
        for (const segment of params.segments) {
          slices.push(flightClient.createSlice(
            segment.origin,
            segment.destination,
            segment.departureDate
          ));
        }
        
        // Create the offer request with a longer timeout for multi-city
        const response = await flightClient.createOfferRequest({
          slices,
          cabin_class: params.cabinClass,
          adult_count: params.adults,
          max_connections: params.maxConnections,
          return_offers: true,
          supplier_timeout: 30000 // 30 seconds
        });
        
        return {
          content: [
            {
              type: 'text',
              text: JSON.stringify(response, null, 2)
            }
          ]
        };
        
      } catch (error) {
        console.error(`Error searching multi-city flights: ${error}`);
        throw error;
      }
    }
  • src/server.ts:140-180 (registration)
    Registers the 'search_multi_city' tool with MCP server using the schema and handler function.
    server.tool(
      'search_multi_city',
      multiCityRequestSchema.shape,
      async (params: MultiCityRequest) => {
        try {
          const slices = [];
          
          // Build slices from segments
          for (const segment of params.segments) {
            slices.push(flightClient.createSlice(
              segment.origin,
              segment.destination,
              segment.departureDate
            ));
          }
          
          // Create the offer request with a longer timeout for multi-city
          const response = await flightClient.createOfferRequest({
            slices,
            cabin_class: params.cabinClass,
            adult_count: params.adults,
            max_connections: params.maxConnections,
            return_offers: true,
            supplier_timeout: 30000 // 30 seconds
          });
          
          return {
            content: [
              {
                type: 'text',
                text: JSON.stringify(response, null, 2)
              }
            ]
          };
          
        } catch (error) {
          console.error(`Error searching multi-city flights: ${error}`);
          throw error;
        }
      }
    );
  • Defines the input schema for search_multi_city using Zod, including array of flight segments.
    export const multiCityRequestSchema = z.object({
      segments: z.array(flightSegmentSchema).min(2).describe('Flight segments for multi-city trip'),
      cabinClass: z.enum(['economy', 'premium_economy', 'business', 'first']).describe('Cabin class'),
      adults: z.number().min(1).default(1).describe('Number of adult passengers'),
      maxConnections: z.number().optional().describe('Maximum number of connections')
    });
    
    export type MultiCityRequest = z.infer<typeof multiCityRequestSchema>;
  • Schema for individual flight segments used in multi-city requests.
    export const flightSegmentSchema = z.object({
      origin: z.string().describe('Origin airport or city IATA code (e.g., SFO, NYC)'),
      destination: z.string().describe('Destination airport or city IATA code (e.g., LAX, LHR)'),
      departureDate: z.string().describe('Departure date in YYYY-MM-DD format')
    });
    
    export type FlightSegment = z.infer<typeof flightSegmentSchema>;

Tool Definition Quality

Score is being calculated. Check back soon.

Install Server

Other 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/clockworked247/flights-mcp-ts'

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