mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* WIP: initial logging changes add several transports in ~/config/winston omit messages in logs, truncate long strings add short blurb in dotenv for debug logging GoogleClient: using logger OpenAIClient: using logger, handleOpenAIErrors Adding typedef for payload message bumped winston and using winston-daily-rotate-file moved config for server paths to ~/config dir Added `DEBUG_LOGGING=true` to .env.example * WIP: Refactor logging statements in code * WIP: Refactor logging statements and import configurations * WIP: Refactor logging statements and import configurations * refactor: broadcast Redis initialization message with `info` not `debug` * refactor: complete Refactor logging statements and import configurations * chore: delete unused tools * fix: circular dependencies due to accessing logger * refactor(handleText): handle booleans and write tests * refactor: redact sensitive values, better formatting * chore: improve log formatting, avoid passing strings to 2nd arg * fix(ci): fix jest tests due to logger changes * refactor(getAvailablePluginsController): cache plugins as they are static and avoids async addOpenAPISpecs call every time * chore: update docs * chore: update docs * chore: create separate meiliSync logger, clean up logs to avoid being unnecessarily verbose * chore: spread objects where they are commonly logged to allow string truncation * chore: improve error log formatting
121 lines
4.4 KiB
JavaScript
121 lines
4.4 KiB
JavaScript
const { StructuredTool } = require('langchain/tools');
|
|
const axios = require('axios');
|
|
const { z } = require('zod');
|
|
|
|
function getServerURL() {
|
|
const url = process.env.CODESHERPA_SERVER_URL || '';
|
|
if (!url) {
|
|
throw new Error('Missing CODESHERPA_SERVER_URL environment variable.');
|
|
}
|
|
return url;
|
|
}
|
|
|
|
const headers = {
|
|
'Content-Type': 'application/json',
|
|
};
|
|
|
|
class RunCode extends StructuredTool {
|
|
constructor(fields) {
|
|
super();
|
|
this.name = 'RunCode';
|
|
this.url = fields.CODESHERPA_SERVER_URL || getServerURL();
|
|
this.description_for_model = `// A plugin for interactive code execution
|
|
// Guidelines:
|
|
// Always provide code and language as such: {{"code": "print('Hello World!')", "language": "python"}}
|
|
// Execute Python code interactively for general programming, tasks, data analysis, visualizations, and more.
|
|
// Pre-installed packages: matplotlib, seaborn, pandas, numpy, scipy, openpyxl.If you need to install additional packages, use the \`pip install\` command.
|
|
// When a user asks for visualization, save the plot to \`static/images/\` directory, and embed it in the response using \`${this.url}/static/images/\` URL.
|
|
// Always save alls media files created to \`static/images/\` directory, and embed them in responses using \`${this.url}/static/images/\` URL.
|
|
// Always embed media files created or uploaded using \`${this.url}/static/images/\` URL in responses.
|
|
// Access user-uploaded files in\`static/uploads/\` directory using \`${this.url}/static/uploads/\` URL.
|
|
// Remember to save any plots/images created, so you can embed it in the response, to \`static/images/\` directory, and embed them as instructed before.`;
|
|
this.description =
|
|
'This plugin allows interactive code execution. Follow the guidelines to get the best results.';
|
|
this.headers = headers;
|
|
this.schema = z.object({
|
|
code: z.string().optional().describe('The code to be executed in the REPL-like environment.'),
|
|
language: z
|
|
.string()
|
|
.optional()
|
|
.describe('The programming language of the code to be executed.'),
|
|
});
|
|
}
|
|
|
|
async _call({ code, language = 'python' }) {
|
|
// logger.debug('<--------------- Running Code --------------->', { code, language });
|
|
const response = await axios({
|
|
url: `${this.url}/repl`,
|
|
method: 'post',
|
|
headers: this.headers,
|
|
data: { code, language },
|
|
});
|
|
// logger.debug('<--------------- Sucessfully ran Code --------------->', response.data);
|
|
return response.data.result;
|
|
}
|
|
}
|
|
|
|
class RunCommand extends StructuredTool {
|
|
constructor(fields) {
|
|
super();
|
|
this.name = 'RunCommand';
|
|
this.url = fields.CODESHERPA_SERVER_URL || getServerURL();
|
|
this.description_for_model = `// Run terminal commands and interact with the filesystem, run scripts, and more.
|
|
// Guidelines:
|
|
// Always provide command as such: {{"command": "ls -l"}}
|
|
// Install python packages using \`pip install\` command.
|
|
// Always embed media files created or uploaded using \`${this.url}/static/images/\` URL in responses.
|
|
// Access user-uploaded files in\`static/uploads/\` directory using \`${this.url}/static/uploads/\` URL.`;
|
|
this.description =
|
|
'A plugin for interactive shell command execution. Follow the guidelines to get the best results.';
|
|
this.headers = headers;
|
|
this.schema = z.object({
|
|
command: z.string().describe('The terminal command to be executed.'),
|
|
});
|
|
}
|
|
|
|
async _call(data) {
|
|
const response = await axios({
|
|
url: `${this.url}/command`,
|
|
method: 'post',
|
|
headers: this.headers,
|
|
data,
|
|
});
|
|
return response.data.result;
|
|
}
|
|
}
|
|
|
|
/* TODO: support file upload */
|
|
// class UploadFile extends StructuredTool {
|
|
// constructor(fields) {
|
|
// super();
|
|
// this.name = 'UploadFile';
|
|
// this.url = fields.CODESHERPA_SERVER_URL || getServerURL();
|
|
// this.description = 'Endpoint to upload a file.';
|
|
// this.headers = headers;
|
|
// this.schema = z.object({
|
|
// file: z.string().describe('The file to be uploaded.'),
|
|
// });
|
|
// }
|
|
|
|
// async _call(data) {
|
|
// const formData = new FormData();
|
|
// formData.append('file', fs.createReadStream(data.file));
|
|
|
|
// const response = await axios({
|
|
// url: `${this.url}/upload`,
|
|
// method: 'post',
|
|
// headers: {
|
|
// ...this.headers,
|
|
// 'Content-Type': `multipart/form-data; boundary=${formData._boundary}`,
|
|
// },
|
|
// data: formData,
|
|
// });
|
|
// return response.data;
|
|
// }
|
|
// }
|
|
|
|
module.exports = [
|
|
RunCode,
|
|
RunCommand,
|
|
// UploadFile
|
|
];
|