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
73 lines
2.5 KiB
JavaScript
73 lines
2.5 KiB
JavaScript
const { logger } = require('~/config');
|
|
|
|
/**
|
|
* The `addImages` function corrects any erroneous image URLs in the `responseMessage.text`
|
|
* and appends image observations from `intermediateSteps` if they are not already present.
|
|
*
|
|
* @function
|
|
* @module addImages
|
|
*
|
|
* @param {Array.<Object>} intermediateSteps - An array of objects, each containing an observation.
|
|
* @param {Object} responseMessage - An object containing the text property which might have image URLs.
|
|
*
|
|
* @property {string} intermediateSteps[].observation - The observation string which might contain an image markdown.
|
|
* @property {string} responseMessage.text - The text which might contain image URLs.
|
|
*
|
|
* @example
|
|
*
|
|
* const intermediateSteps = [
|
|
* { observation: '' }
|
|
* ];
|
|
* const responseMessage = { text: 'Some text with ' };
|
|
*
|
|
* addImages(intermediateSteps, responseMessage);
|
|
*
|
|
* logger.debug(responseMessage.text);
|
|
* // Outputs: 'Some text with \n'
|
|
*
|
|
* @returns {void}
|
|
*/
|
|
function addImages(intermediateSteps, responseMessage) {
|
|
if (!intermediateSteps || !responseMessage) {
|
|
return;
|
|
}
|
|
|
|
// Correct any erroneous URLs in the responseMessage.text first
|
|
intermediateSteps.forEach((step) => {
|
|
const { observation } = step;
|
|
if (!observation || !observation.includes('![')) {
|
|
return;
|
|
}
|
|
|
|
const match = observation.match(/\/images\/.*\.\w*/);
|
|
if (!match) {
|
|
return;
|
|
}
|
|
const essentialImagePath = match[0];
|
|
|
|
const regex = /!\[.*?\]\((.*?)\)/g;
|
|
let matchErroneous;
|
|
while ((matchErroneous = regex.exec(responseMessage.text)) !== null) {
|
|
if (matchErroneous[1] && !matchErroneous[1].startsWith('/images/')) {
|
|
responseMessage.text = responseMessage.text.replace(matchErroneous[1], essentialImagePath);
|
|
}
|
|
}
|
|
});
|
|
|
|
// Now, check if the responseMessage already includes the correct image file path and append if not
|
|
intermediateSteps.forEach((step) => {
|
|
const { observation } = step;
|
|
if (!observation || !observation.includes('![')) {
|
|
return;
|
|
}
|
|
const observedImagePath = observation.match(/\(\/images\/.*\.\w*\)/g);
|
|
if (observedImagePath && !responseMessage.text.includes(observedImagePath[0])) {
|
|
responseMessage.text += '\n' + observation;
|
|
if (process.env.DEBUG_PLUGINS) {
|
|
logger.debug('[addImages] added image from intermediateSteps:', observation);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
module.exports = addImages;
|