add_activities
Add activities to a travel program by specifying details like date, time, passengers, services, hotels, guides, and vehicles. Ensure all entities are pre-existing for accurate association.
Instructions
Crea actividades asociadas a un programa. Es importante que los servicios, hoteles, guías, vehículos y extras ya existan
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| activities | Yes | Lista de actividades a agregar | |
| programId | Yes | ID del programa |
Implementation Reference
- src/handlers/tools.handler.ts:1394-1406 (handler)Handler function in callTool method that processes the add_activities tool call: formats activity dates and invokes the ApiService.addActivities method.case 'add_activities': { const { programId, activities } = args activities.forEach((activity: any) => { activity.date = formatDate(activity.date) }) const program = await this.apiService.addActivities({ programId, activities }) return { content: [{ type: 'text', text: `Actividades agregadas exitosamente al programa.\n\nDetalles del programa actualizado:\n${JSON.stringify(program, null, 2)}` }] }
- Input schema definition for the add_activities tool, defining parameters like programId and activities array with detailed properties.name: 'add_activities', description: 'Crea actividades asociadas a un programa. Es importante que los servicios, hoteles, guías, vehículos y extras ya existan', inputSchema: { type: 'object', properties: { programId: { type: 'string', description: 'ID del programa' }, activities: { type: 'array', description: 'Lista de actividades a agregar', items: { type: 'object', properties: { primaryPassenger: { type: 'string', description: 'ID del pasajero principal, si no se especifica se asume que el primer pasajero es el principal. Siempre se debe especificar el pasajero principal.' }, passengers: { type: 'array', description: 'Lista de pasajeros a asociar a la actividad, es importante que los pasajeros ya existan', items: { type: 'object', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] } }, date: { type: 'string', description: 'Fecha de la actividad (DD-MM-YYYY), debe ser una fecha entre la fecha de inicio y fin del programa' }, hour: { type: 'string', description: 'Hora de la actividad (HH:mm)' }, service: { type: 'object', description: 'Servicio a asociar a la actividad, es importante que el servicio ya exista', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] }, hotel: { type: 'object', description: 'Hotel a asociar a la actividad, es importante que el hotel ya exista', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] }, leader: { type: 'object', description: 'Guía a asociar a la actividad, es importante que el guía ya exista', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] }, vehicle: { type: 'object', description: 'Vehículo a asociar a la actividad, es importante que el vehículo ya exista', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] }, includes: { type: 'array', description: 'Lista de extras o incluídos a asociar a la actividad, es importante que los extras ya existan', items: { type: 'object', properties: { id: { type: 'string' }, name: { type: 'string' } } } }, servicelanguage: { type: 'object', description: 'Idioma en el que se va a prestar el servicio, si no se especifica se mantiene el idioma actual. Es importante que el idioma ya exista', properties: { id: { type: 'string' }, name: { type: 'string' } }, required: ['id', 'name'] }, code: { type: 'string', description: 'Código de la actividad' }, itinerary: { type: 'string', description: 'Itinerario de la actividad' }, news: { type: 'string', description: 'Noticias de la actividad' } }, required: ['date', 'hour', 'primaryPassenger'] } } }, required: ['programId', 'activities'] }
- src/index.ts:38-47 (registration)MCP server registration of tool handlers: setRequestHandler for ListToolsRequestSchema (exposes tool schemas including add_activities) and CallToolRequestSchema (executes tool calls).this.server.setRequestHandler( ListToolsRequestSchema, async () => this.toolsHandler.listTools() ) // Configure handlers for tools this.server.setRequestHandler( CallToolRequestSchema, async (request) => await this.toolsHandler.callTool(request.params.name, request.params.arguments, this.server) )
- src/services/api.service.ts:155-201 (helper)ApiService method that performs the HTTP POST request to the backend API endpoint for adding activities to a program.async addActivities (data: { programId: string activities: Array<{ date: string hour: string service?: { id: string name: string } hotel?: { id: string name: string } leader?: { id: string name: string } vehicle?: { id: string name: string } primaryPassenger: string passengers: Array<{ id: string name: string }> includes?: Array<{ id: string name: string }> servicelanguage?: { id: string name: string } code?: string itinerary?: string news?: string }> }) { const headers = await this.getHeaders() const response = await fetch(`${API_CONFIG.baseUrl}/integrations/mcp/programs/activity/add`, { method: 'POST', headers: { ...headers, 'Content-Type': 'application/json' }, body: JSON.stringify(data) }) return await this.handleResponse<any>(response) }