extract_crm_data
Extract structured CRM data from call transcripts to organize customer information for sales and support teams.
Instructions
Extract CRM-ready structured data from a call transcript. Cost: $0.010 USDC. Service: callsight.
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| transcript | Yes |
Implementation Reference
- src/index.ts:166-223 (handler)This codebase uses a dynamic registry. The tool "extract_crm_data" is not hardcoded but is fetched from an external registry URL. The `CallToolRequestSchema` handler in `src/index.ts` dynamically handles the tool call by matching the request name against the tools loaded from the remote registry.
server.setRequestHandler(CallToolRequestSchema, async (request) => { const { name, arguments: args } = request.params; let registry: Registry; try { registry = await fetchRegistry(); } catch (error) { return { content: [ { type: "text", text: JSON.stringify({ error: "Failed to fetch tool registry", detail: String(error) }), }, ], }; } const tool = registry.tools.find((t) => t.name === name); if (!tool) { return { content: [ { type: "text", text: JSON.stringify({ error: `Tool '${name}' not found`, available_tools: registry.tools.map((t) => t.name), }), }, ], }; } try { const result = await callTool(tool, args as Record<string, unknown>); return { content: [ { type: "text", text: JSON.stringify(result, null, 2), }, ], }; } catch (error) { return { content: [ { type: "text", text: JSON.stringify({ error: "Tool call failed", tool: name, service: tool.service, detail: String(error), }), }, ], }; } });