@tambo-ai/react 0.22.0 → 0.23.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/model/component-metadata.d.ts +10 -1
- package/dist/model/component-metadata.d.ts.map +1 -1
- package/dist/model/component-metadata.js.map +1 -1
- package/dist/providers/tambo-mcp-provider.d.ts +10 -0
- package/dist/providers/tambo-mcp-provider.d.ts.map +1 -0
- package/dist/providers/tambo-mcp-provider.js +65 -0
- package/dist/providers/tambo-mcp-provider.js.map +1 -0
- package/dist/testing/tools.js.map +1 -1
- package/dist/util/mcp-client.d.ts +198 -0
- package/dist/util/mcp-client.d.ts.map +1 -0
- package/dist/util/mcp-client.js +108 -0
- package/dist/util/mcp-client.js.map +1 -0
- package/dist/util/mcp-tools-client.d.ts +96 -0
- package/dist/util/mcp-tools-client.d.ts.map +1 -0
- package/dist/util/mcp-tools-client.js +178 -0
- package/dist/util/mcp-tools-client.js.map +1 -0
- package/dist/util/registry.d.ts.map +1 -1
- package/dist/util/registry.js +18 -0
- package/dist/util/registry.js.map +1 -1
- package/esm/index.d.ts +1 -0
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +1 -0
- package/esm/index.js.map +1 -1
- package/esm/model/component-metadata.d.ts +10 -1
- package/esm/model/component-metadata.d.ts.map +1 -1
- package/esm/model/component-metadata.js.map +1 -1
- package/esm/providers/tambo-mcp-provider.d.ts +10 -0
- package/esm/providers/tambo-mcp-provider.d.ts.map +1 -0
- package/esm/providers/tambo-mcp-provider.js +61 -0
- package/esm/providers/tambo-mcp-provider.js.map +1 -0
- package/esm/testing/tools.js.map +1 -1
- package/esm/util/mcp-client.d.ts +198 -0
- package/esm/util/mcp-client.d.ts.map +1 -0
- package/esm/util/mcp-client.js +104 -0
- package/esm/util/mcp-client.js.map +1 -0
- package/esm/util/mcp-tools-client.d.ts +96 -0
- package/esm/util/mcp-tools-client.d.ts.map +1 -0
- package/esm/util/mcp-tools-client.js +174 -0
- package/esm/util/mcp-tools-client.js.map +1 -0
- package/esm/util/registry.d.ts.map +1 -1
- package/esm/util/registry.js +18 -0
- package/esm/util/registry.js.map +1 -1
- package/package.json +2 -1
package/dist/index.d.ts
CHANGED
|
@@ -11,4 +11,5 @@ export { useTamboThreadList } from "./hooks/use-tambo-threads";
|
|
|
11
11
|
export { type ComponentContextToolMetadata, type ComponentRegistry, type ParameterSpec, type RegisteredComponent, type TamboTool, } from "./model/component-metadata";
|
|
12
12
|
export { GenerationStage, type TamboThreadMessage, } from "./model/generate-component-response";
|
|
13
13
|
export { type TamboThread } from "./model/tambo-thread";
|
|
14
|
+
export { TamboMcpProvider } from "./providers/tambo-mcp-provider";
|
|
14
15
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,wKAAwK;AACxK,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,sBAAsB,GACvB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,cAAc,yBAAyB,CAAC;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAG/D,OAAO,EACL,mBAAmB,EACnB,sBAAsB,EACtB,aAAa,EACb,mBAAmB,EACnB,QAAQ,EACR,cAAc,EACd,cAAc,EACd,KAAK,cAAc,EACnB,KAAK,oBAAoB,GAC1B,MAAM,aAAa,CAAC;AAGrB,YAAY,EACV,QAAQ,EACR,cAAc,EACd,YAAY,GACb,MAAM,0BAA0B,CAAC;AAClC,YAAY,EACV,UAAU,EACV,wBAAwB,EACxB,0BAA0B,EAC1B,sBAAsB,GACvB,MAAM,6DAA6D,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EACL,KAAK,4BAA4B,EACjC,KAAK,iBAAiB,EACtB,KAAK,aAAa,EAClB,KAAK,mBAAmB,EACxB,KAAK,SAAS,GACf,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,eAAe,EACf,KAAK,kBAAkB,GACxB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,wKAAwK;AACxK,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,sBAAsB,GACvB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,cAAc,yBAAyB,CAAC;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAG/D,OAAO,EACL,mBAAmB,EACnB,sBAAsB,EACtB,aAAa,EACb,mBAAmB,EACnB,QAAQ,EACR,cAAc,EACd,cAAc,EACd,KAAK,cAAc,EACnB,KAAK,oBAAoB,GAC1B,MAAM,aAAa,CAAC;AAGrB,YAAY,EACV,QAAQ,EACR,cAAc,EACd,YAAY,GACb,MAAM,0BAA0B,CAAC;AAClC,YAAY,EACV,UAAU,EACV,wBAAwB,EACxB,0BAA0B,EAC1B,sBAAsB,GACvB,MAAM,6DAA6D,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EACL,KAAK,4BAA4B,EACjC,KAAK,iBAAiB,EACtB,KAAK,aAAa,EAClB,KAAK,mBAAmB,EACxB,KAAK,SAAS,GACf,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,eAAe,EACf,KAAK,kBAAkB,GACxB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.GenerationStage = exports.useTamboThreadList = exports.useTamboThread = exports.useTamboClient = exports.useTambo = exports.TamboThreadProvider = exports.TamboProvider = exports.TamboComponentProvider = exports.TamboClientProvider = exports.useTamboThreadInput = exports.useTamboStreamingProps = exports.useTamboMessageContext = exports.useTamboCurrentMessage = exports.TamboMessageProvider = exports.useTamboComponentState = void 0;
|
|
17
|
+
exports.TamboMcpProvider = exports.GenerationStage = exports.useTamboThreadList = exports.useTamboThread = exports.useTamboClient = exports.useTambo = exports.TamboThreadProvider = exports.TamboProvider = exports.TamboComponentProvider = exports.TamboClientProvider = exports.useTamboThreadInput = exports.useTamboStreamingProps = exports.useTamboMessageContext = exports.useTamboCurrentMessage = exports.TamboMessageProvider = exports.useTamboComponentState = void 0;
|
|
18
18
|
/** Exports for the library. Only publically available exports are re-exported here. Anything not exported here is not supported and may change or break at any time. */
|
|
19
19
|
var use_component_state_1 = require("./hooks/use-component-state");
|
|
20
20
|
Object.defineProperty(exports, "useTamboComponentState", { enumerable: true, get: function () { return use_component_state_1.useTamboComponentState; } });
|
|
@@ -40,4 +40,6 @@ var use_tambo_threads_1 = require("./hooks/use-tambo-threads");
|
|
|
40
40
|
Object.defineProperty(exports, "useTamboThreadList", { enumerable: true, get: function () { return use_tambo_threads_1.useTamboThreadList; } });
|
|
41
41
|
var generate_component_response_1 = require("./model/generate-component-response");
|
|
42
42
|
Object.defineProperty(exports, "GenerationStage", { enumerable: true, get: function () { return generate_component_response_1.GenerationStage; } });
|
|
43
|
+
var tambo_mcp_provider_1 = require("./providers/tambo-mcp-provider");
|
|
44
|
+
Object.defineProperty(exports, "TamboMcpProvider", { enumerable: true, get: function () { return tambo_mcp_provider_1.TamboMcpProvider; } });
|
|
43
45
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,wKAAwK;AACxK,mEAAqE;AAA5D,6HAAA,sBAAsB,OAAA;AAC/B,mEAIqC;AAHnC,2HAAA,oBAAoB,OAAA;AACpB,6HAAA,sBAAsB,OAAA;AACtB,6HAAA,sBAAsB,OAAA;AAExB,mEAAqE;AAA5D,6HAAA,sBAAsB,OAAA;AAC/B,0DAAwC;AACxC,6DAA+D;AAAtD,uHAAA,mBAAmB,OAAA;AAE5B,gCAAgC;AAChC,yCAUqB;AATnB,gHAAA,mBAAmB,OAAA;AACnB,mHAAA,sBAAsB,OAAA;AACtB,0GAAA,aAAa,OAAA;AACb,gHAAA,mBAAmB,OAAA;AACnB,qGAAA,QAAQ,OAAA;AACR,2GAAA,cAAc,OAAA;AACd,2GAAA,cAAc,OAAA;AAiBhB,+DAA+D;AAAtD,uHAAA,kBAAkB,OAAA;AAQ3B,mFAG6C;AAF3C,8HAAA,eAAe,OAAA","sourcesContent":["/** Exports for the library. Only publically available exports are re-exported here. Anything not exported here is not supported and may change or break at any time. */\nexport { useTamboComponentState } from \"./hooks/use-component-state\";\nexport {\n TamboMessageProvider,\n useTamboCurrentMessage,\n useTamboMessageContext,\n} from \"./hooks/use-current-message\";\nexport { useTamboStreamingProps } from \"./hooks/use-streaming-props\";\nexport * from \"./hooks/use-suggestions\";\nexport { useTamboThreadInput } from \"./hooks/use-thread-input\";\n\n// Re-export provider components\nexport {\n TamboClientProvider,\n TamboComponentProvider,\n TamboProvider,\n TamboThreadProvider,\n useTambo,\n useTamboClient,\n useTamboThread,\n type TamboComponent,\n type TamboRegistryContext,\n} from \"./providers\";\n\n// Re-export types from Tambo Node SDK\nexport type {\n APIError,\n RateLimitError,\n TamboAIError,\n} from \"@tambo-ai/typescript-sdk\";\nexport type {\n Suggestion,\n SuggestionGenerateParams,\n SuggestionGenerateResponse,\n SuggestionListResponse,\n} from \"@tambo-ai/typescript-sdk/resources/beta/threads/suggestions\";\nexport { useTamboThreadList } from \"./hooks/use-tambo-threads\";\nexport {\n type ComponentContextToolMetadata,\n type ComponentRegistry,\n type ParameterSpec,\n type RegisteredComponent,\n type TamboTool,\n} from \"./model/component-metadata\";\nexport {\n GenerationStage,\n type TamboThreadMessage,\n} from \"./model/generate-component-response\";\nexport { type TamboThread } from \"./model/tambo-thread\";\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,wKAAwK;AACxK,mEAAqE;AAA5D,6HAAA,sBAAsB,OAAA;AAC/B,mEAIqC;AAHnC,2HAAA,oBAAoB,OAAA;AACpB,6HAAA,sBAAsB,OAAA;AACtB,6HAAA,sBAAsB,OAAA;AAExB,mEAAqE;AAA5D,6HAAA,sBAAsB,OAAA;AAC/B,0DAAwC;AACxC,6DAA+D;AAAtD,uHAAA,mBAAmB,OAAA;AAE5B,gCAAgC;AAChC,yCAUqB;AATnB,gHAAA,mBAAmB,OAAA;AACnB,mHAAA,sBAAsB,OAAA;AACtB,0GAAA,aAAa,OAAA;AACb,gHAAA,mBAAmB,OAAA;AACnB,qGAAA,QAAQ,OAAA;AACR,2GAAA,cAAc,OAAA;AACd,2GAAA,cAAc,OAAA;AAiBhB,+DAA+D;AAAtD,uHAAA,kBAAkB,OAAA;AAQ3B,mFAG6C;AAF3C,8HAAA,eAAe,OAAA;AAIjB,qEAAkE;AAAzD,sHAAA,gBAAgB,OAAA","sourcesContent":["/** Exports for the library. Only publically available exports are re-exported here. Anything not exported here is not supported and may change or break at any time. */\nexport { useTamboComponentState } from \"./hooks/use-component-state\";\nexport {\n TamboMessageProvider,\n useTamboCurrentMessage,\n useTamboMessageContext,\n} from \"./hooks/use-current-message\";\nexport { useTamboStreamingProps } from \"./hooks/use-streaming-props\";\nexport * from \"./hooks/use-suggestions\";\nexport { useTamboThreadInput } from \"./hooks/use-thread-input\";\n\n// Re-export provider components\nexport {\n TamboClientProvider,\n TamboComponentProvider,\n TamboProvider,\n TamboThreadProvider,\n useTambo,\n useTamboClient,\n useTamboThread,\n type TamboComponent,\n type TamboRegistryContext,\n} from \"./providers\";\n\n// Re-export types from Tambo Node SDK\nexport type {\n APIError,\n RateLimitError,\n TamboAIError,\n} from \"@tambo-ai/typescript-sdk\";\nexport type {\n Suggestion,\n SuggestionGenerateParams,\n SuggestionGenerateResponse,\n SuggestionListResponse,\n} from \"@tambo-ai/typescript-sdk/resources/beta/threads/suggestions\";\nexport { useTamboThreadList } from \"./hooks/use-tambo-threads\";\nexport {\n type ComponentContextToolMetadata,\n type ComponentRegistry,\n type ParameterSpec,\n type RegisteredComponent,\n type TamboTool,\n} from \"./model/component-metadata\";\nexport {\n GenerationStage,\n type TamboThreadMessage,\n} from \"./model/generate-component-response\";\nexport { type TamboThread } from \"./model/tambo-thread\";\nexport { TamboMcpProvider } from \"./providers/tambo-mcp-provider\";\n"]}
|
|
@@ -24,11 +24,20 @@ export interface RegisteredComponent extends TamboAI.AvailableComponent {
|
|
|
24
24
|
}
|
|
25
25
|
export type ComponentRegistry = Record<string, RegisteredComponent>;
|
|
26
26
|
export type TamboToolRegistry = Record<string, TamboTool>;
|
|
27
|
+
/**
|
|
28
|
+
* A JSON Schema that is compatible with the MCP.
|
|
29
|
+
* This is a simplified JSON Schema that is compatible with the MCPClient and the toolSchema.
|
|
30
|
+
*
|
|
31
|
+
* Do not export this type from the SDK.
|
|
32
|
+
*/
|
|
33
|
+
export type JSONSchemaLite = ReturnType<typeof zodToJsonSchema> & {
|
|
34
|
+
description?: string;
|
|
35
|
+
};
|
|
27
36
|
export interface TamboTool<Args extends z.ZodTuple<any, any> = z.ZodTuple<any, any>, Returns extends z.ZodTypeAny = z.ZodTypeAny> {
|
|
28
37
|
name: string;
|
|
29
38
|
description: string;
|
|
30
39
|
tool: (...args: z.infer<Args>) => z.infer<Returns>;
|
|
31
|
-
toolSchema: z.ZodFunction<Args, Returns
|
|
40
|
+
toolSchema: z.ZodFunction<Args, Returns> | JSONSchemaLite;
|
|
32
41
|
}
|
|
33
42
|
export type TamboToolAssociations = Record<string, string[]>;
|
|
34
43
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component-metadata.d.ts","sourceRoot":"","sources":["../../src/model/component-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,0BAA0B,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,CAAC,MAAM,KAAK,CAAC;AACpB,OAAO,KAAK,eAAe,MAAM,oBAAoB,CAAC;AACtD,+FAA+F;AAC/F,MAAM,MAAM,aAAa,GAAG,OAAO,CAAC,cAAc,GAAG;IACnD,MAAM,CAAC,EAAE,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;CAC7C,CAAC;AAEF;;;GAGG;AACH,MAAM,WAAW,4BACf,SAAQ,OAAO,CAAC,4BAA4B;IAC5C,UAAU,EAAE,aAAa,EAAE,CAAC;CAC7B;AAED,MAAM,WAAW,oBAAoB;IACnC,mBAAmB,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;IACtD,UAAU,EAAE,4BAA4B,CAAC;CAC1C;AAED,MAAM,WAAW,mBAAoB,SAAQ,OAAO,CAAC,kBAAkB;IACrE,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAC9B,gBAAgB,CAAC,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;CACvC;AAED,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;AAEpE,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;AAE1D,MAAM,WAAW,SAAS,CACxB,IAAI,SAAS,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,EACxD,OAAO,SAAS,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU;IAE3C,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IACnD,UAAU,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"component-metadata.d.ts","sourceRoot":"","sources":["../../src/model/component-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,0BAA0B,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,CAAC,MAAM,KAAK,CAAC;AACpB,OAAO,KAAK,eAAe,MAAM,oBAAoB,CAAC;AACtD,+FAA+F;AAC/F,MAAM,MAAM,aAAa,GAAG,OAAO,CAAC,cAAc,GAAG;IACnD,MAAM,CAAC,EAAE,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;CAC7C,CAAC;AAEF;;;GAGG;AACH,MAAM,WAAW,4BACf,SAAQ,OAAO,CAAC,4BAA4B;IAC5C,UAAU,EAAE,aAAa,EAAE,CAAC;CAC7B;AAED,MAAM,WAAW,oBAAoB;IACnC,mBAAmB,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;IACtD,UAAU,EAAE,4BAA4B,CAAC;CAC1C;AAED,MAAM,WAAW,mBAAoB,SAAQ,OAAO,CAAC,kBAAkB;IACrE,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAC9B,gBAAgB,CAAC,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;CACvC;AAED,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;AAEpE,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;AAE1D;;;;;GAKG;AACH,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,OAAO,eAAe,CAAC,GAAG;IAChE,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,WAAW,SAAS,CACxB,IAAI,SAAS,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,EACxD,OAAO,SAAS,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU;IAE3C,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IACnD,UAAU,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,cAAc,CAAC;CAC3D;AAED,MAAM,MAAM,qBAAqB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;AAC7D;;GAEG;AAEH,MAAM,WAAW,cAAc;IAC7B,gCAAgC;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,uCAAuC;IACvC,WAAW,EAAE,MAAM,CAAC;IACpB;;;;;;;;;;;;;;;;;;OAkBG;IACH,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAE9B;;;OAGG;IACH,WAAW,CAAC,EAAE,CAAC,CAAC,UAAU,GAAG,WAAW,CAAC;IACzC;;;;OAIG;IACH,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,qEAAqE;IACrE,gBAAgB,CAAC,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACtC,uDAAuD;IACvD,eAAe,CAAC,EAAE,SAAS,EAAE,CAAC;CAC/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component-metadata.js","sourceRoot":"","sources":["../../src/model/component-metadata.ts"],"names":[],"mappings":"","sourcesContent":["import TamboAI from \"@tambo-ai/typescript-sdk\";\nimport { JSONSchema7 } from \"json-schema\";\nimport { ComponentType } from \"react\";\nimport z from \"zod\";\nimport type zodToJsonSchema from \"zod-to-json-schema\";\n/** Extension of the ToolParameters interface from Tambo AI to include JSONSchema definition */\nexport type ParameterSpec = TamboAI.ToolParameters & {\n schema?: ReturnType<typeof zodToJsonSchema>;\n};\n\n/**\n * Extends the base ContextTool interface from Tambo AI to include schema information\n * for parameter validation using zod-to-json-schema.\n */\nexport interface ComponentContextToolMetadata\n extends TamboAI.ComponentContextToolMetadata {\n parameters: ParameterSpec[];\n}\n\nexport interface ComponentContextTool {\n getComponentContext: (...args: any[]) => Promise<any>;\n definition: ComponentContextToolMetadata;\n}\n\nexport interface RegisteredComponent extends TamboAI.AvailableComponent {\n component: ComponentType<any>;\n loadingComponent?: ComponentType<any>;\n}\n\nexport type ComponentRegistry = Record<string, RegisteredComponent>;\n\nexport type TamboToolRegistry = Record<string, TamboTool>;\n\nexport interface TamboTool<\n Args extends z.ZodTuple<any, any> = z.ZodTuple<any, any>,\n Returns extends z.ZodTypeAny = z.ZodTypeAny,\n> {\n name: string;\n description: string;\n tool: (...args: z.infer<Args>) => z.infer<Returns>;\n toolSchema: z.ZodFunction<Args, Returns
|
|
1
|
+
{"version":3,"file":"component-metadata.js","sourceRoot":"","sources":["../../src/model/component-metadata.ts"],"names":[],"mappings":"","sourcesContent":["import TamboAI from \"@tambo-ai/typescript-sdk\";\nimport { JSONSchema7 } from \"json-schema\";\nimport { ComponentType } from \"react\";\nimport z from \"zod\";\nimport type zodToJsonSchema from \"zod-to-json-schema\";\n/** Extension of the ToolParameters interface from Tambo AI to include JSONSchema definition */\nexport type ParameterSpec = TamboAI.ToolParameters & {\n schema?: ReturnType<typeof zodToJsonSchema>;\n};\n\n/**\n * Extends the base ContextTool interface from Tambo AI to include schema information\n * for parameter validation using zod-to-json-schema.\n */\nexport interface ComponentContextToolMetadata\n extends TamboAI.ComponentContextToolMetadata {\n parameters: ParameterSpec[];\n}\n\nexport interface ComponentContextTool {\n getComponentContext: (...args: any[]) => Promise<any>;\n definition: ComponentContextToolMetadata;\n}\n\nexport interface RegisteredComponent extends TamboAI.AvailableComponent {\n component: ComponentType<any>;\n loadingComponent?: ComponentType<any>;\n}\n\nexport type ComponentRegistry = Record<string, RegisteredComponent>;\n\nexport type TamboToolRegistry = Record<string, TamboTool>;\n\n/**\n * A JSON Schema that is compatible with the MCP.\n * This is a simplified JSON Schema that is compatible with the MCPClient and the toolSchema.\n *\n * Do not export this type from the SDK.\n */\nexport type JSONSchemaLite = ReturnType<typeof zodToJsonSchema> & {\n description?: string;\n};\n\nexport interface TamboTool<\n Args extends z.ZodTuple<any, any> = z.ZodTuple<any, any>,\n Returns extends z.ZodTypeAny = z.ZodTypeAny,\n> {\n name: string;\n description: string;\n tool: (...args: z.infer<Args>) => z.infer<Returns>;\n toolSchema: z.ZodFunction<Args, Returns> | JSONSchemaLite;\n}\n\nexport type TamboToolAssociations = Record<string, string[]>;\n/**\n * A component that can be registered with the TamboRegistryProvider.\n */\n\nexport interface TamboComponent {\n /** The name of the component */\n name: string;\n /** The description of the component */\n description: string;\n /**\n * The React component to render.\n *\n * Make sure to pass the Component itself, not an instance of the component. For example,\n * if you have a component like this:\n *\n * ```tsx\n * const MyComponent = () => {\n * return <div>My Component</div>;\n * };\n * ```\n *\n * You should pass the `Component`:\n *\n * ```tsx\n * const components = [MyComponent];\n * <TamboRegistryProvider components={components} />\n * ```\n */\n component: ComponentType<any>;\n\n /**\n * A zod schema for the component props. (Recommended)\n * Either this or propsDefinition must be provided, but not both.\n */\n propsSchema?: z.ZodTypeAny | JSONSchema7;\n /**\n * The props definition of the component as a JSON object.\n * Either this or propsSchema must be provided, but not both.\n * @deprecated Use propsSchema instead.\n */\n propsDefinition?: any;\n /** The loading component to render while the component is loading */\n loadingComponent?: ComponentType<any>;\n /** The tools that are associated with the component */\n associatedTools?: TamboTool[];\n}\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* This provider is used to register tools from MCP servers.
|
|
4
|
+
* @returns the wrapped children
|
|
5
|
+
*/
|
|
6
|
+
export declare const TamboMcpProvider: FC<{
|
|
7
|
+
mcpServers: string[];
|
|
8
|
+
children: React.ReactNode;
|
|
9
|
+
}>;
|
|
10
|
+
//# sourceMappingURL=tambo-mcp-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tambo-mcp-provider.d.ts","sourceRoot":"","sources":["../../src/providers/tambo-mcp-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAa,MAAM,OAAO,CAAC;AAKtC;;;GAGG;AACH,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC;IAChC,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,CA6DA,CAAC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TamboMcpProvider = void 0;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
const mcp_client_1 = require("../util/mcp-client");
|
|
6
|
+
const tambo_registry_provider_1 = require("./tambo-registry-provider");
|
|
7
|
+
/**
|
|
8
|
+
* This provider is used to register tools from MCP servers.
|
|
9
|
+
* @returns the wrapped children
|
|
10
|
+
*/
|
|
11
|
+
const TamboMcpProvider = ({ mcpServers, children }) => {
|
|
12
|
+
const { registerTool } = (0, tambo_registry_provider_1.useTamboRegistry)();
|
|
13
|
+
(0, react_1.useEffect)(() => {
|
|
14
|
+
if (!mcpServers) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
async function registerMcpServers(mcpServers) {
|
|
18
|
+
// Maps tool names to the MCP client that registered them
|
|
19
|
+
const mcpServerMap = new Map();
|
|
20
|
+
const serverToolLists = mcpServers.map(async (mcpServer) => {
|
|
21
|
+
const mcpClient = await mcp_client_1.MCPClient.create(mcpServer, mcp_client_1.MCPTransport.SSE);
|
|
22
|
+
const tools = await mcpClient.listTools();
|
|
23
|
+
tools.forEach((tool) => {
|
|
24
|
+
mcpServerMap.set(tool.name, mcpClient);
|
|
25
|
+
});
|
|
26
|
+
return tools;
|
|
27
|
+
});
|
|
28
|
+
const toolResults = await Promise.allSettled(serverToolLists);
|
|
29
|
+
// Just log the failed tools, we can't do anything about them
|
|
30
|
+
const failedTools = toolResults.filter((result) => result.status === "rejected");
|
|
31
|
+
if (failedTools.length > 0) {
|
|
32
|
+
console.error("Failed to register tools from MCP servers:", failedTools.map((result) => result.reason));
|
|
33
|
+
}
|
|
34
|
+
// Register the successful tools
|
|
35
|
+
const allTools = toolResults
|
|
36
|
+
.filter((result) => result.status === "fulfilled")
|
|
37
|
+
.map((result) => result.value)
|
|
38
|
+
.flat();
|
|
39
|
+
allTools.forEach((tool) => {
|
|
40
|
+
registerTool({
|
|
41
|
+
description: tool.description ?? "",
|
|
42
|
+
name: tool.name,
|
|
43
|
+
tool: async (args) => {
|
|
44
|
+
const mcpServer = mcpServerMap.get(tool.name);
|
|
45
|
+
if (!mcpServer) {
|
|
46
|
+
// should never happen
|
|
47
|
+
throw new Error(`MCP server for tool ${tool.name} not found`);
|
|
48
|
+
}
|
|
49
|
+
const result = await mcpServer.callTool(tool.name, args);
|
|
50
|
+
if (result.isError) {
|
|
51
|
+
// TODO: is there a better way to handle this?
|
|
52
|
+
throw new Error(`${result.content}`);
|
|
53
|
+
}
|
|
54
|
+
return result.content;
|
|
55
|
+
},
|
|
56
|
+
toolSchema: tool.inputSchema,
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
registerMcpServers(mcpServers);
|
|
61
|
+
}, [mcpServers, registerTool]);
|
|
62
|
+
return children;
|
|
63
|
+
};
|
|
64
|
+
exports.TamboMcpProvider = TamboMcpProvider;
|
|
65
|
+
//# sourceMappingURL=tambo-mcp-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tambo-mcp-provider.js","sourceRoot":"","sources":["../../src/providers/tambo-mcp-provider.tsx"],"names":[],"mappings":";;;AAAA,iCAAsC;AAEtC,mDAA6D;AAC7D,uEAA6D;AAE7D;;;GAGG;AACI,MAAM,gBAAgB,GAGxB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE,EAAE;IAChC,MAAM,EAAE,YAAY,EAAE,GAAG,IAAA,0CAAgB,GAAE,CAAC;IAE5C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;QACD,KAAK,UAAU,kBAAkB,CAAC,UAAoB;YACpD,yDAAyD;YACzD,MAAM,YAAY,GAAG,IAAI,GAAG,EAAqB,CAAC;YAClD,MAAM,eAAe,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;gBACzD,MAAM,SAAS,GAAG,MAAM,sBAAS,CAAC,MAAM,CAAC,SAAS,EAAE,yBAAY,CAAC,GAAG,CAAC,CAAC;gBACtE,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,SAAS,EAAE,CAAC;gBAC1C,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;oBACrB,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;gBACzC,CAAC,CAAC,CAAC;gBACH,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;YAE9D,6DAA6D;YAC7D,MAAM,WAAW,GAAG,WAAW,CAAC,MAAM,CACpC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,UAAU,CACzC,CAAC;YACF,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3B,OAAO,CAAC,KAAK,CACX,4CAA4C,EAC5C,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAC3C,CAAC;YACJ,CAAC;YAED,gCAAgC;YAChC,MAAM,QAAQ,GAAG,WAAW;iBACzB,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,WAAW,CAAC;iBACjD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;iBAC7B,IAAI,EAAE,CAAC;YACV,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxB,YAAY,CAAC;oBACX,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,EAAE;oBACnC,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,IAAI,EAAE,KAAK,EAAE,IAA6B,EAAE,EAAE;wBAC5C,MAAM,SAAS,GAAG,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBAC9C,IAAI,CAAC,SAAS,EAAE,CAAC;4BACf,sBAAsB;4BACtB,MAAM,IAAI,KAAK,CAAC,uBAAuB,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC;wBAChE,CAAC;wBACD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;wBACzD,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;4BACnB,8CAA8C;4BAC9C,MAAM,IAAI,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;wBACvC,CAAC;wBACD,OAAO,MAAM,CAAC,OAAO,CAAC;oBACxB,CAAC;oBACD,UAAU,EAAE,IAAI,CAAC,WAAsC;iBACxD,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;QACD,kBAAkB,CAAC,UAAU,CAAC,CAAC;IACjC,CAAC,EAAE,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC;IAE/B,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC;AAhEW,QAAA,gBAAgB,oBAgE3B","sourcesContent":["import { FC, useEffect } from \"react\";\nimport { TamboTool } from \"../model/component-metadata\";\nimport { MCPClient, MCPTransport } from \"../util/mcp-client\";\nimport { useTamboRegistry } from \"./tambo-registry-provider\";\n\n/**\n * This provider is used to register tools from MCP servers.\n * @returns the wrapped children\n */\nexport const TamboMcpProvider: FC<{\n mcpServers: string[];\n children: React.ReactNode;\n}> = ({ mcpServers, children }) => {\n const { registerTool } = useTamboRegistry();\n\n useEffect(() => {\n if (!mcpServers) {\n return;\n }\n async function registerMcpServers(mcpServers: string[]) {\n // Maps tool names to the MCP client that registered them\n const mcpServerMap = new Map<string, MCPClient>();\n const serverToolLists = mcpServers.map(async (mcpServer) => {\n const mcpClient = await MCPClient.create(mcpServer, MCPTransport.SSE);\n const tools = await mcpClient.listTools();\n tools.forEach((tool) => {\n mcpServerMap.set(tool.name, mcpClient);\n });\n return tools;\n });\n const toolResults = await Promise.allSettled(serverToolLists);\n\n // Just log the failed tools, we can't do anything about them\n const failedTools = toolResults.filter(\n (result) => result.status === \"rejected\",\n );\n if (failedTools.length > 0) {\n console.error(\n \"Failed to register tools from MCP servers:\",\n failedTools.map((result) => result.reason),\n );\n }\n\n // Register the successful tools\n const allTools = toolResults\n .filter((result) => result.status === \"fulfilled\")\n .map((result) => result.value)\n .flat();\n allTools.forEach((tool) => {\n registerTool({\n description: tool.description ?? \"\",\n name: tool.name,\n tool: async (args: Record<string, unknown>) => {\n const mcpServer = mcpServerMap.get(tool.name);\n if (!mcpServer) {\n // should never happen\n throw new Error(`MCP server for tool ${tool.name} not found`);\n }\n const result = await mcpServer.callTool(tool.name, args);\n if (result.isError) {\n // TODO: is there a better way to handle this?\n throw new Error(`${result.content}`);\n }\n return result.content;\n },\n toolSchema: tool.inputSchema as TamboTool[\"toolSchema\"],\n });\n });\n }\n registerMcpServers(mcpServers);\n }, [mcpServers, registerTool]);\n\n return children;\n};\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../../src/testing/tools.ts"],"names":[],"mappings":";;;;;AASA,8CA0BC;AAlCD,4EAAiD;AAGjD;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,YAA8B;IAC9D,OAAO,YAAY,CAAC,GAAG,CACrB,CAAC,EACC,SAAS,EAAE,UAAU,EACrB,WAAW,EACX,eAAe,EACf,GAAG,cAAc,EAClB,EAAE,EAAE,CAAC,CAAC;QACL,GAAG,cAAc;QACjB,KAAK,EAAE,IAAA,4BAAe,EAAC,WAA2B,CAAC;QACnD,YAAY,EAAE,eAAe,EAAE,GAAG,CAChC,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC;YAC9C,GAAG,SAAS;YACZ,UAAU,
|
|
1
|
+
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../../src/testing/tools.ts"],"names":[],"mappings":";;;;;AASA,8CA0BC;AAlCD,4EAAiD;AAGjD;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,YAA8B;IAC9D,OAAO,YAAY,CAAC,GAAG,CACrB,CAAC,EACC,SAAS,EAAE,UAAU,EACrB,WAAW,EACX,eAAe,EACf,GAAG,cAAc,EAClB,EAAE,EAAE,CAAC,CAAC;QACL,GAAG,cAAc;QACjB,KAAK,EAAE,IAAA,4BAAe,EAAC,WAA2B,CAAC;QACnD,YAAY,EAAE,eAAe,EAAE,GAAG,CAChC,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC;YAC9C,GAAG,SAAS;YACZ,UAAU,EAAG,UAAsC;iBAChD,UAAU,EAAE;iBACZ,KAAK,CAAC,GAAG,CAAC,CAAC,CAAe,EAAE,KAAa,EAAE,EAAE,CAAC,CAAC;gBAC9C,IAAI,EAAE,QAAQ,KAAK,GAAG,CAAC,EAAE;gBACzB,MAAM,EAAE,IAAA,4BAAe,EAAC,CAAC,CAAC;gBAC1B,UAAU,EAAE,IAAI;gBAChB,WAAW,EAAE,CAAC,CAAC,WAAW;gBAC1B,IAAI,EAAG,IAAA,4BAAe,EAAC,CAAC,CAAS,CAAC,IAAI;aACvC,CAAC,CAAC;SACN,CAAC,CACH;KACF,CAAC,CACH,CAAC;AACJ,CAAC","sourcesContent":["import { z } from \"zod\";\nimport zodToJsonSchema from \"zod-to-json-schema\";\nimport { TamboComponent } from \"../providers\";\n\n/**\n * Serializes the registry for testing purposes\n * @param mockRegistry - The registry to serialize\n * @returns The serialized registry\n */\nexport function serializeRegistry(mockRegistry: TamboComponent[]) {\n return mockRegistry.map(\n ({\n component: _component,\n propsSchema,\n associatedTools,\n ...componentEntry\n }) => ({\n ...componentEntry,\n props: zodToJsonSchema(propsSchema as z.ZodTypeAny),\n contextTools: associatedTools?.map(\n ({ toolSchema, tool: _tool, ...toolEntry }) => ({\n ...toolEntry,\n parameters: (toolSchema as z.ZodFunction<any, any>)\n .parameters()\n .items.map((p: z.ZodTypeAny, index: number) => ({\n name: `param${index + 1}`,\n schema: zodToJsonSchema(p),\n isRequired: true,\n description: p.description,\n type: (zodToJsonSchema(p) as any).type,\n })),\n }),\n ),\n }),\n );\n}\n"]}
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { JSONSchema7 } from "json-schema";
|
|
2
|
+
export declare enum MCPTransport {
|
|
3
|
+
SSE = "sse",
|
|
4
|
+
HTTP = "http"
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* A client for interacting with MCP (Model Context Protocol) servers.
|
|
8
|
+
* Provides a simple interface for listing and calling tools exposed by the server.
|
|
9
|
+
* @example
|
|
10
|
+
* ```typescript
|
|
11
|
+
* const mcp = await MCPClient.create('https://api.example.com/mcp');
|
|
12
|
+
* const tools = await mcp.listTools();
|
|
13
|
+
* const result = await mcp.callTool('toolName', { arg1: 'value1' });
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export declare class MCPClient {
|
|
17
|
+
private client;
|
|
18
|
+
private transport;
|
|
19
|
+
/**
|
|
20
|
+
* Private constructor to enforce using the static create method.
|
|
21
|
+
* @param endpoint - The URL of the MCP server to connect to
|
|
22
|
+
* @param transport - The transport to use for the MCP client
|
|
23
|
+
* @param headers - Optional custom headers to include in requests
|
|
24
|
+
*/
|
|
25
|
+
private constructor();
|
|
26
|
+
/**
|
|
27
|
+
* Creates and initializes a new MCPClient instance.
|
|
28
|
+
* This is the recommended way to create an MCPClient as it handles both
|
|
29
|
+
* instantiation and connection setup.
|
|
30
|
+
* @param endpoint - The URL of the MCP server to connect to
|
|
31
|
+
* @param headers - Optional custom headers to include in requests
|
|
32
|
+
* @returns A connected MCPClient instance ready for use
|
|
33
|
+
* @throws Will throw an error if connection fails
|
|
34
|
+
*/
|
|
35
|
+
static create(endpoint: string, transport?: MCPTransport, headers?: Record<string, string>): Promise<MCPClient>;
|
|
36
|
+
/**
|
|
37
|
+
* Retrieves a complete list of all available tools from the MCP server.
|
|
38
|
+
* Handles pagination automatically by following cursors until all tools are fetched.
|
|
39
|
+
* @returns A complete list of all available tools and their descriptions
|
|
40
|
+
* @throws Will throw an error if any server request fails during pagination
|
|
41
|
+
*/
|
|
42
|
+
listTools(): Promise<MCPToolSpec[]>;
|
|
43
|
+
/**
|
|
44
|
+
* Calls a specific tool on the MCP server with the provided arguments.
|
|
45
|
+
* @param name - The name of the tool to call
|
|
46
|
+
* @param args - Arguments to pass to the tool, must match the tool's expected schema
|
|
47
|
+
* @returns The result from the tool execution
|
|
48
|
+
* @throws Will throw an error if the tool call fails or if arguments are invalid
|
|
49
|
+
*/
|
|
50
|
+
callTool(name: string, args: Record<string, unknown>): Promise<import("zod").objectOutputType<{
|
|
51
|
+
_meta: import("zod").ZodOptional<import("zod").ZodObject<{}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{}, import("zod").ZodTypeAny, "passthrough">>>;
|
|
52
|
+
} & {
|
|
53
|
+
content: import("zod").ZodArray<import("zod").ZodUnion<[import("zod").ZodObject<{
|
|
54
|
+
type: import("zod").ZodLiteral<"text">;
|
|
55
|
+
text: import("zod").ZodString;
|
|
56
|
+
}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{
|
|
57
|
+
type: import("zod").ZodLiteral<"text">;
|
|
58
|
+
text: import("zod").ZodString;
|
|
59
|
+
}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{
|
|
60
|
+
type: import("zod").ZodLiteral<"text">;
|
|
61
|
+
text: import("zod").ZodString;
|
|
62
|
+
}, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<{
|
|
63
|
+
type: import("zod").ZodLiteral<"image">;
|
|
64
|
+
data: import("zod").ZodString;
|
|
65
|
+
mimeType: import("zod").ZodString;
|
|
66
|
+
}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{
|
|
67
|
+
type: import("zod").ZodLiteral<"image">;
|
|
68
|
+
data: import("zod").ZodString;
|
|
69
|
+
mimeType: import("zod").ZodString;
|
|
70
|
+
}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{
|
|
71
|
+
type: import("zod").ZodLiteral<"image">;
|
|
72
|
+
data: import("zod").ZodString;
|
|
73
|
+
mimeType: import("zod").ZodString;
|
|
74
|
+
}, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<{
|
|
75
|
+
type: import("zod").ZodLiteral<"audio">;
|
|
76
|
+
data: import("zod").ZodString;
|
|
77
|
+
mimeType: import("zod").ZodString;
|
|
78
|
+
}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{
|
|
79
|
+
type: import("zod").ZodLiteral<"audio">;
|
|
80
|
+
data: import("zod").ZodString;
|
|
81
|
+
mimeType: import("zod").ZodString;
|
|
82
|
+
}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{
|
|
83
|
+
type: import("zod").ZodLiteral<"audio">;
|
|
84
|
+
data: import("zod").ZodString;
|
|
85
|
+
mimeType: import("zod").ZodString;
|
|
86
|
+
}, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<{
|
|
87
|
+
type: import("zod").ZodLiteral<"resource">;
|
|
88
|
+
resource: import("zod").ZodUnion<[import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
89
|
+
uri: import("zod").ZodString;
|
|
90
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
91
|
+
}, {
|
|
92
|
+
text: import("zod").ZodString;
|
|
93
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
94
|
+
uri: import("zod").ZodString;
|
|
95
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
96
|
+
}, {
|
|
97
|
+
text: import("zod").ZodString;
|
|
98
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
99
|
+
uri: import("zod").ZodString;
|
|
100
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
101
|
+
}, {
|
|
102
|
+
text: import("zod").ZodString;
|
|
103
|
+
}>, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
104
|
+
uri: import("zod").ZodString;
|
|
105
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
106
|
+
}, {
|
|
107
|
+
blob: import("zod").ZodString;
|
|
108
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
109
|
+
uri: import("zod").ZodString;
|
|
110
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
111
|
+
}, {
|
|
112
|
+
blob: import("zod").ZodString;
|
|
113
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
114
|
+
uri: import("zod").ZodString;
|
|
115
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
116
|
+
}, {
|
|
117
|
+
blob: import("zod").ZodString;
|
|
118
|
+
}>, import("zod").ZodTypeAny, "passthrough">>]>;
|
|
119
|
+
}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{
|
|
120
|
+
type: import("zod").ZodLiteral<"resource">;
|
|
121
|
+
resource: import("zod").ZodUnion<[import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
122
|
+
uri: import("zod").ZodString;
|
|
123
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
124
|
+
}, {
|
|
125
|
+
text: import("zod").ZodString;
|
|
126
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
127
|
+
uri: import("zod").ZodString;
|
|
128
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
129
|
+
}, {
|
|
130
|
+
text: import("zod").ZodString;
|
|
131
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
132
|
+
uri: import("zod").ZodString;
|
|
133
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
134
|
+
}, {
|
|
135
|
+
text: import("zod").ZodString;
|
|
136
|
+
}>, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
137
|
+
uri: import("zod").ZodString;
|
|
138
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
139
|
+
}, {
|
|
140
|
+
blob: import("zod").ZodString;
|
|
141
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
142
|
+
uri: import("zod").ZodString;
|
|
143
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
144
|
+
}, {
|
|
145
|
+
blob: import("zod").ZodString;
|
|
146
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
147
|
+
uri: import("zod").ZodString;
|
|
148
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
149
|
+
}, {
|
|
150
|
+
blob: import("zod").ZodString;
|
|
151
|
+
}>, import("zod").ZodTypeAny, "passthrough">>]>;
|
|
152
|
+
}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{
|
|
153
|
+
type: import("zod").ZodLiteral<"resource">;
|
|
154
|
+
resource: import("zod").ZodUnion<[import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
155
|
+
uri: import("zod").ZodString;
|
|
156
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
157
|
+
}, {
|
|
158
|
+
text: import("zod").ZodString;
|
|
159
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
160
|
+
uri: import("zod").ZodString;
|
|
161
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
162
|
+
}, {
|
|
163
|
+
text: import("zod").ZodString;
|
|
164
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
165
|
+
uri: import("zod").ZodString;
|
|
166
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
167
|
+
}, {
|
|
168
|
+
text: import("zod").ZodString;
|
|
169
|
+
}>, import("zod").ZodTypeAny, "passthrough">>, import("zod").ZodObject<import("zod").objectUtil.extendShape<{
|
|
170
|
+
uri: import("zod").ZodString;
|
|
171
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
172
|
+
}, {
|
|
173
|
+
blob: import("zod").ZodString;
|
|
174
|
+
}>, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<import("zod").objectUtil.extendShape<{
|
|
175
|
+
uri: import("zod").ZodString;
|
|
176
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
177
|
+
}, {
|
|
178
|
+
blob: import("zod").ZodString;
|
|
179
|
+
}>, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<import("zod").objectUtil.extendShape<{
|
|
180
|
+
uri: import("zod").ZodString;
|
|
181
|
+
mimeType: import("zod").ZodOptional<import("zod").ZodString>;
|
|
182
|
+
}, {
|
|
183
|
+
blob: import("zod").ZodString;
|
|
184
|
+
}>, import("zod").ZodTypeAny, "passthrough">>]>;
|
|
185
|
+
}, import("zod").ZodTypeAny, "passthrough">>]>, "many">;
|
|
186
|
+
isError: import("zod").ZodOptional<import("zod").ZodDefault<import("zod").ZodBoolean>>;
|
|
187
|
+
}, import("zod").ZodTypeAny, "passthrough"> | import("zod").objectOutputType<{
|
|
188
|
+
_meta: import("zod").ZodOptional<import("zod").ZodObject<{}, "passthrough", import("zod").ZodTypeAny, import("zod").objectOutputType<{}, import("zod").ZodTypeAny, "passthrough">, import("zod").objectInputType<{}, import("zod").ZodTypeAny, "passthrough">>>;
|
|
189
|
+
} & {
|
|
190
|
+
toolResult: import("zod").ZodUnknown;
|
|
191
|
+
}, import("zod").ZodTypeAny, "passthrough">>;
|
|
192
|
+
}
|
|
193
|
+
export interface MCPToolSpec {
|
|
194
|
+
name: string;
|
|
195
|
+
description?: string;
|
|
196
|
+
inputSchema?: JSONSchema7;
|
|
197
|
+
}
|
|
198
|
+
//# sourceMappingURL=mcp-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-client.d.ts","sourceRoot":"","sources":["../../src/util/mcp-client.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,oBAAY,YAAY;IACtB,GAAG,QAAQ;IACX,IAAI,SAAS;CACd;AACD;;;;;;;;;GASG;AACH,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,SAAS,CAAqD;IAEtE;;;;;OAKG;IACH,OAAO;IAoBP;;;;;;;;OAQG;WACU,MAAM,CACjB,QAAQ,EAAE,MAAM,EAChB,SAAS,GAAE,YAAgC,EAC3C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAC/B,OAAO,CAAC,SAAS,CAAC;IAMrB;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAiCzC;;;;;;OAMG;IACG,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAO3D;AASD,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MCPClient = exports.MCPTransport = void 0;
|
|
4
|
+
const index_js_1 = require("@modelcontextprotocol/sdk/client/index.js");
|
|
5
|
+
const sse_js_1 = require("@modelcontextprotocol/sdk/client/sse.js");
|
|
6
|
+
const streamableHttp_js_1 = require("@modelcontextprotocol/sdk/client/streamableHttp.js");
|
|
7
|
+
var MCPTransport;
|
|
8
|
+
(function (MCPTransport) {
|
|
9
|
+
MCPTransport["SSE"] = "sse";
|
|
10
|
+
MCPTransport["HTTP"] = "http";
|
|
11
|
+
})(MCPTransport || (exports.MCPTransport = MCPTransport = {}));
|
|
12
|
+
/**
|
|
13
|
+
* A client for interacting with MCP (Model Context Protocol) servers.
|
|
14
|
+
* Provides a simple interface for listing and calling tools exposed by the server.
|
|
15
|
+
* @example
|
|
16
|
+
* ```typescript
|
|
17
|
+
* const mcp = await MCPClient.create('https://api.example.com/mcp');
|
|
18
|
+
* const tools = await mcp.listTools();
|
|
19
|
+
* const result = await mcp.callTool('toolName', { arg1: 'value1' });
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
class MCPClient {
|
|
23
|
+
client;
|
|
24
|
+
transport;
|
|
25
|
+
/**
|
|
26
|
+
* Private constructor to enforce using the static create method.
|
|
27
|
+
* @param endpoint - The URL of the MCP server to connect to
|
|
28
|
+
* @param transport - The transport to use for the MCP client
|
|
29
|
+
* @param headers - Optional custom headers to include in requests
|
|
30
|
+
*/
|
|
31
|
+
constructor(endpoint, transport, headers) {
|
|
32
|
+
if (transport === MCPTransport.SSE) {
|
|
33
|
+
this.transport = new sse_js_1.SSEClientTransport(new URL(endpoint), {
|
|
34
|
+
requestInit: { headers },
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.transport = new streamableHttp_js_1.StreamableHTTPClientTransport(new URL(endpoint), {
|
|
39
|
+
requestInit: { headers },
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
this.client = new index_js_1.Client({
|
|
43
|
+
name: "tambo-mcp-client",
|
|
44
|
+
version: "1.0.0",
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Creates and initializes a new MCPClient instance.
|
|
49
|
+
* This is the recommended way to create an MCPClient as it handles both
|
|
50
|
+
* instantiation and connection setup.
|
|
51
|
+
* @param endpoint - The URL of the MCP server to connect to
|
|
52
|
+
* @param headers - Optional custom headers to include in requests
|
|
53
|
+
* @returns A connected MCPClient instance ready for use
|
|
54
|
+
* @throws Will throw an error if connection fails
|
|
55
|
+
*/
|
|
56
|
+
static async create(endpoint, transport = MCPTransport.HTTP, headers) {
|
|
57
|
+
const mcpClient = new MCPClient(endpoint, transport, headers);
|
|
58
|
+
await mcpClient.client.connect(mcpClient.transport);
|
|
59
|
+
return mcpClient;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Retrieves a complete list of all available tools from the MCP server.
|
|
63
|
+
* Handles pagination automatically by following cursors until all tools are fetched.
|
|
64
|
+
* @returns A complete list of all available tools and their descriptions
|
|
65
|
+
* @throws Will throw an error if any server request fails during pagination
|
|
66
|
+
*/
|
|
67
|
+
async listTools() {
|
|
68
|
+
const allTools = [];
|
|
69
|
+
let hasMore = true;
|
|
70
|
+
let cursor = undefined;
|
|
71
|
+
while (hasMore) {
|
|
72
|
+
const response = await this.client.listTools({ cursor }, {});
|
|
73
|
+
allTools.push(...response.tools.map((tool) => {
|
|
74
|
+
if (tool.inputSchema.type !== "object") {
|
|
75
|
+
throw new Error(`Input schema for tool ${tool.name} is not an object`);
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
name: tool.name,
|
|
79
|
+
description: tool.description,
|
|
80
|
+
inputSchema: tool.inputSchema,
|
|
81
|
+
};
|
|
82
|
+
}));
|
|
83
|
+
if (response.nextCursor) {
|
|
84
|
+
cursor = response.nextCursor;
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
hasMore = false;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return allTools;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Calls a specific tool on the MCP server with the provided arguments.
|
|
94
|
+
* @param name - The name of the tool to call
|
|
95
|
+
* @param args - Arguments to pass to the tool, must match the tool's expected schema
|
|
96
|
+
* @returns The result from the tool execution
|
|
97
|
+
* @throws Will throw an error if the tool call fails or if arguments are invalid
|
|
98
|
+
*/
|
|
99
|
+
async callTool(name, args) {
|
|
100
|
+
const result = await this.client.callTool({
|
|
101
|
+
name,
|
|
102
|
+
arguments: args,
|
|
103
|
+
});
|
|
104
|
+
return result;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.MCPClient = MCPClient;
|
|
108
|
+
//# sourceMappingURL=mcp-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-client.js","sourceRoot":"","sources":["../../src/util/mcp-client.ts"],"names":[],"mappings":";;;AAAA,wEAAmE;AACnE,oEAA6E;AAC7E,0FAAmG;AAGnG,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,2BAAW,CAAA;IACX,6BAAa,CAAA;AACf,CAAC,EAHW,YAAY,4BAAZ,YAAY,QAGvB;AACD;;;;;;;;;GASG;AACH,MAAa,SAAS;IACZ,MAAM,CAAS;IACf,SAAS,CAAqD;IAEtE;;;;;OAKG;IACH,YACE,QAAgB,EAChB,SAAuB,EACvB,OAAgC;QAEhC,IAAI,SAAS,KAAK,YAAY,CAAC,GAAG,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,IAAI,2BAAkB,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,EAAE;gBACzD,WAAW,EAAE,EAAE,OAAO,EAAE;aACzB,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,IAAI,iDAA6B,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,EAAE;gBACpE,WAAW,EAAE,EAAE,OAAO,EAAE;aACzB,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,IAAI,iBAAM,CAAC;YACvB,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;OAQG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CACjB,QAAgB,EAChB,YAA0B,YAAY,CAAC,IAAI,EAC3C,OAAgC;QAEhC,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC9D,MAAM,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QACpD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,SAAS;QACb,MAAM,QAAQ,GAAkB,EAAE,CAAC;QACnC,IAAI,OAAO,GAAG,IAAI,CAAC;QACnB,IAAI,MAAM,GAAuB,SAAS,CAAC;QAE3C,OAAO,OAAO,EAAE,CAAC;YACf,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;YAC7D,QAAQ,CAAC,IAAI,CACX,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAe,EAAE;gBAC1C,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;oBACvC,MAAM,IAAI,KAAK,CACb,yBAAyB,IAAI,CAAC,IAAI,mBAAmB,CACtD,CAAC;gBACJ,CAAC;gBAED,OAAO;oBACL,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,WAAW,EAAE,IAAI,CAAC,WAAW;oBAC7B,WAAW,EAAE,IAAI,CAAC,WAA0B;iBAC7C,CAAC;YACJ,CAAC,CAAC,CACH,CAAC;YAEF,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC;gBACxB,MAAM,GAAG,QAAQ,CAAC,UAAU,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,OAAO,GAAG,KAAK,CAAC;YAClB,CAAC;QACH,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CAAC,IAAY,EAAE,IAA6B;QACxD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YACxC,IAAI;YACJ,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAtGD,8BAsGC","sourcesContent":["import { Client } from \"@modelcontextprotocol/sdk/client/index.js\";\nimport { SSEClientTransport } from \"@modelcontextprotocol/sdk/client/sse.js\";\nimport { StreamableHTTPClientTransport } from \"@modelcontextprotocol/sdk/client/streamableHttp.js\";\nimport { JSONSchema7 } from \"json-schema\";\n\nexport enum MCPTransport {\n SSE = \"sse\",\n HTTP = \"http\",\n}\n/**\n * A client for interacting with MCP (Model Context Protocol) servers.\n * Provides a simple interface for listing and calling tools exposed by the server.\n * @example\n * ```typescript\n * const mcp = await MCPClient.create('https://api.example.com/mcp');\n * const tools = await mcp.listTools();\n * const result = await mcp.callTool('toolName', { arg1: 'value1' });\n * ```\n */\nexport class MCPClient {\n private client: Client;\n private transport: SSEClientTransport | StreamableHTTPClientTransport;\n\n /**\n * Private constructor to enforce using the static create method.\n * @param endpoint - The URL of the MCP server to connect to\n * @param transport - The transport to use for the MCP client\n * @param headers - Optional custom headers to include in requests\n */\n private constructor(\n endpoint: string,\n transport: MCPTransport,\n headers?: Record<string, string>,\n ) {\n if (transport === MCPTransport.SSE) {\n this.transport = new SSEClientTransport(new URL(endpoint), {\n requestInit: { headers },\n });\n } else {\n this.transport = new StreamableHTTPClientTransport(new URL(endpoint), {\n requestInit: { headers },\n });\n }\n this.client = new Client({\n name: \"tambo-mcp-client\",\n version: \"1.0.0\",\n });\n }\n\n /**\n * Creates and initializes a new MCPClient instance.\n * This is the recommended way to create an MCPClient as it handles both\n * instantiation and connection setup.\n * @param endpoint - The URL of the MCP server to connect to\n * @param headers - Optional custom headers to include in requests\n * @returns A connected MCPClient instance ready for use\n * @throws Will throw an error if connection fails\n */\n static async create(\n endpoint: string,\n transport: MCPTransport = MCPTransport.HTTP,\n headers?: Record<string, string>,\n ): Promise<MCPClient> {\n const mcpClient = new MCPClient(endpoint, transport, headers);\n await mcpClient.client.connect(mcpClient.transport);\n return mcpClient;\n }\n\n /**\n * Retrieves a complete list of all available tools from the MCP server.\n * Handles pagination automatically by following cursors until all tools are fetched.\n * @returns A complete list of all available tools and their descriptions\n * @throws Will throw an error if any server request fails during pagination\n */\n async listTools(): Promise<MCPToolSpec[]> {\n const allTools: MCPToolSpec[] = [];\n let hasMore = true;\n let cursor: string | undefined = undefined;\n\n while (hasMore) {\n const response = await this.client.listTools({ cursor }, {});\n allTools.push(\n ...response.tools.map((tool): MCPToolSpec => {\n if (tool.inputSchema.type !== \"object\") {\n throw new Error(\n `Input schema for tool ${tool.name} is not an object`,\n );\n }\n\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema as JSONSchema7,\n };\n }),\n );\n\n if (response.nextCursor) {\n cursor = response.nextCursor;\n } else {\n hasMore = false;\n }\n }\n\n return allTools;\n }\n\n /**\n * Calls a specific tool on the MCP server with the provided arguments.\n * @param name - The name of the tool to call\n * @param args - Arguments to pass to the tool, must match the tool's expected schema\n * @returns The result from the tool execution\n * @throws Will throw an error if the tool call fails or if arguments are invalid\n */\n async callTool(name: string, args: Record<string, unknown>) {\n const result = await this.client.callTool({\n name,\n arguments: args,\n });\n return result;\n }\n}\n\n// Example usage:\n/*\nconst mcp = await MCPClient.create('https://api.example.com/mcp', MCPTransport.HTTP);\nconst tools = await mcp.listTools();\nconst result = await mcp.callTool('toolName', { arg1: 'value1' });\n*/\n\nexport interface MCPToolSpec {\n name: string;\n description?: string;\n inputSchema?: JSONSchema7;\n}\n"]}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Minimal Model Context Protocol (MCP) client using JSON-RPC 2.0
|
|
3
|
+
* Supports only listTools() and callTool() operations
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Interface representing a Tool in the MCP
|
|
7
|
+
*/
|
|
8
|
+
export interface Tool {
|
|
9
|
+
name: string;
|
|
10
|
+
description?: string;
|
|
11
|
+
inputSchema: {
|
|
12
|
+
type: "object";
|
|
13
|
+
properties: Record<string, any>;
|
|
14
|
+
required?: string[];
|
|
15
|
+
};
|
|
16
|
+
annotations?: Record<string, any>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Response from tools/list endpoint
|
|
20
|
+
*/
|
|
21
|
+
export interface ListToolsResult {
|
|
22
|
+
tools: Tool[];
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Content type for tool responses
|
|
26
|
+
*/
|
|
27
|
+
export interface ToolContent {
|
|
28
|
+
type: string;
|
|
29
|
+
text?: string;
|
|
30
|
+
annotations?: Record<string, any>;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Response from tools/call endpoint
|
|
34
|
+
*/
|
|
35
|
+
export interface CallToolResult {
|
|
36
|
+
content: ToolContent[];
|
|
37
|
+
isError?: boolean;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* A minimal TypeScript client for the Model Context Protocol (MCP)
|
|
41
|
+
*
|
|
42
|
+
* This client provides a streamlined interface to communicate with MCP servers
|
|
43
|
+
* using JSON-RPC 2.0 over HTTP. It supports listing available tools and calling tools
|
|
44
|
+
* with arguments, including support for Server-Sent Events (SSE) streaming responses.
|
|
45
|
+
* @example
|
|
46
|
+
* ```typescript
|
|
47
|
+
* // Basic usage
|
|
48
|
+
* const mcpClient = new MCPClient('https://example.com/mcp');
|
|
49
|
+
* const tools = await mcpClient.listTools();
|
|
50
|
+
* const toolResponse = await mcpClient.callTool('my-tool', { arg1: 'value1' });
|
|
51
|
+
*
|
|
52
|
+
* // For streaming responses:
|
|
53
|
+
* const stream = await mcpClient.callToolStream('streaming-tool', { arg1: 'value1' });
|
|
54
|
+
* for await (const chunk of mcpClient.parseStreamingResponses(stream)) {
|
|
55
|
+
* console.log('Received chunk:', chunk);
|
|
56
|
+
* }
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
export declare class MCPClient {
|
|
60
|
+
private baseUrl;
|
|
61
|
+
private headers;
|
|
62
|
+
private requestId;
|
|
63
|
+
/**
|
|
64
|
+
* Creates a new MCP client
|
|
65
|
+
* @param url - The base URL of the MCP server
|
|
66
|
+
* @param extraHeaders - Optional additional headers to include in requests
|
|
67
|
+
*/
|
|
68
|
+
constructor(url: string, extraHeaders?: Record<string, string>);
|
|
69
|
+
/**
|
|
70
|
+
* Lists available tools on the MCP server
|
|
71
|
+
* @returns Promise resolving to the list of available tools
|
|
72
|
+
*/
|
|
73
|
+
listTools(): Promise<ListToolsResult>;
|
|
74
|
+
/**
|
|
75
|
+
* Calls a tool with the provided arguments
|
|
76
|
+
* @param toolName - The name of the tool to call
|
|
77
|
+
* @param args - The arguments to pass to the tool
|
|
78
|
+
* @returns Promise resolving to the tool's response
|
|
79
|
+
*/
|
|
80
|
+
callTool(toolName: string, args: any): Promise<CallToolResult>;
|
|
81
|
+
/**
|
|
82
|
+
* Calls a tool with the provided arguments and returns a stream of results
|
|
83
|
+
* @param toolName - The name of the tool to call
|
|
84
|
+
* @param args - The arguments to pass to the tool
|
|
85
|
+
* @returns ReadableStream of the tool's response
|
|
86
|
+
*/
|
|
87
|
+
callToolStream(toolName: string, args: any): Promise<ReadableStream<Uint8Array>>;
|
|
88
|
+
/**
|
|
89
|
+
* Parse SSE messages from a stream into JSON-RPC responses
|
|
90
|
+
* @param stream - ReadableStream to parse
|
|
91
|
+
* @returns AsyncGenerator yielding parsed JSON-RPC responses
|
|
92
|
+
* @yields {CallToolResult} The parsed JSON-RPC response
|
|
93
|
+
*/
|
|
94
|
+
parseStreamingResponses(stream: ReadableStream<Uint8Array>): AsyncGenerator<CallToolResult, void, unknown>;
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=mcp-tools-client.d.ts.map
|