get_offer_details
Retrieve detailed information about a specific flight offer from the Duffel API, including pricing, itinerary, and accommodation options.
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| offerId | Yes | Unique identifier for the flight offer |
Implementation Reference
- src/server.ts:116-137 (handler)The MCP tool registration and inline handler implementation for 'get_offer_details'. It takes an offerId parameter and fetches the detailed offer information from the Duffel API client, returning the JSON response.server.tool( 'get_offer_details', offerDetailsSchema.shape, async (params: OfferDetails) => { try { const response = await flightClient.getOffer(params.offerId); return { content: [ { type: 'text', text: JSON.stringify(response, null, 2) } ] }; } catch (error) { console.error(`Error getting offer details: ${error}`); throw error; } } );
- src/models/flightSearch.ts:37-41 (schema)Zod schema and TypeScript type definition for the input parameters of the 'get_offer_details' tool, requiring a single 'offerId' string.export const offerDetailsSchema = z.object({ offerId: z.string().describe('Unique identifier for the flight offer') }); export type OfferDetails = z.infer<typeof offerDetailsSchema>;
- src/api/duffelClient.ts:210-223 (helper)The DuffelClient.getOffer helper method that performs the actual API request to retrieve detailed information for a specific flight offer by ID.async getOffer(offerId: string): Promise<any> { try { if (!offerId.startsWith('off_')) { throw new Error('Invalid offer ID format - must start with "off_"'); } const response = await this.client.get(`/offers/${offerId}`); return response.data; } catch (error) { console.error(`Error getting offer ${offerId}: ${error}`); throw error; } }