72 lines
2.5 KiB
JavaScript
72 lines
2.5 KiB
JavaScript
|
import { Tool } from "@langchain/core/tools";
|
||
|
/**
|
||
|
* Class for creating instances of AI tools from plugins. It extends the
|
||
|
* Tool class and implements the AIPluginToolParams interface.
|
||
|
*/
|
||
|
export class AIPluginTool extends Tool {
|
||
|
static lc_name() {
|
||
|
return "AIPluginTool";
|
||
|
}
|
||
|
get name() {
|
||
|
return this._name;
|
||
|
}
|
||
|
get description() {
|
||
|
return this._description;
|
||
|
}
|
||
|
constructor(params) {
|
||
|
super(params);
|
||
|
Object.defineProperty(this, "_name", {
|
||
|
enumerable: true,
|
||
|
configurable: true,
|
||
|
writable: true,
|
||
|
value: void 0
|
||
|
});
|
||
|
Object.defineProperty(this, "_description", {
|
||
|
enumerable: true,
|
||
|
configurable: true,
|
||
|
writable: true,
|
||
|
value: void 0
|
||
|
});
|
||
|
Object.defineProperty(this, "apiSpec", {
|
||
|
enumerable: true,
|
||
|
configurable: true,
|
||
|
writable: true,
|
||
|
value: void 0
|
||
|
});
|
||
|
this._name = params.name;
|
||
|
this._description = params.description;
|
||
|
this.apiSpec = params.apiSpec;
|
||
|
}
|
||
|
/** @ignore */
|
||
|
async _call(_input) {
|
||
|
return this.apiSpec;
|
||
|
}
|
||
|
/**
|
||
|
* Static method that creates an instance of AIPluginTool from a given
|
||
|
* plugin URL. It fetches the plugin and its API specification from the
|
||
|
* provided URL and returns a new instance of AIPluginTool with the
|
||
|
* fetched data.
|
||
|
* @param url The URL of the AI plugin.
|
||
|
* @returns A new instance of AIPluginTool.
|
||
|
*/
|
||
|
static async fromPluginUrl(url) {
|
||
|
const aiPluginRes = await fetch(url);
|
||
|
if (!aiPluginRes.ok) {
|
||
|
throw new Error(`Failed to fetch plugin from ${url} with status ${aiPluginRes.status}`);
|
||
|
}
|
||
|
const aiPluginJson = await aiPluginRes.json();
|
||
|
const apiUrlRes = await fetch(aiPluginJson.api.url);
|
||
|
if (!apiUrlRes.ok) {
|
||
|
throw new Error(`Failed to fetch API spec from ${aiPluginJson.api.url} with status ${apiUrlRes.status}`);
|
||
|
}
|
||
|
const apiUrlJson = await apiUrlRes.text();
|
||
|
return new AIPluginTool({
|
||
|
name: aiPluginJson.name_for_model,
|
||
|
description: `Call this tool to get the OpenAPI spec (and usage guide) for interacting with the ${aiPluginJson.name_for_human} API. You should only call this ONCE! What is the ${aiPluginJson.name_for_human} API useful for? ${aiPluginJson.description_for_human}`,
|
||
|
apiSpec: `Usage Guide: ${aiPluginJson.description_for_model}
|
||
|
|
||
|
OpenAPI Spec in JSON or YAML format:\n${apiUrlJson}`,
|
||
|
});
|
||
|
}
|
||
|
}
|