mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* refactor: Simplify grid column calculation in SourcesGroup component * refactor: Centralize default agent capabilities and simplify capability assignment * Edge case: use defined/fallback capabilities for ephemeral agents when the "agents" endpoint is not enabled * refactor: consolidate gemini 2 vision check * feat: enhance capability check logging for agents * chore: update librechat-data-provider version to 0.7.86 * refactor: import default agent capabilities for enhanced capability management * chore: standardize quotes in error message check for consistency * fix: improve error logging both client and api-side for mistral ocr upload errors * ci: update error handling in MistralOCR tests to use specific error message
46 lines
1.7 KiB
JavaScript
46 lines
1.7 KiB
JavaScript
const { logger } = require('~/config');
|
|
|
|
/**
|
|
* Logs Axios errors based on the error object and a custom message.
|
|
*
|
|
* @param {Object} options - The options object.
|
|
* @param {string} options.message - The custom message to be logged.
|
|
* @param {import('axios').AxiosError} options.error - The Axios error object.
|
|
* @returns {string} The log message.
|
|
*/
|
|
const logAxiosError = ({ message, error }) => {
|
|
let logMessage = message;
|
|
try {
|
|
const stack = error.stack || 'No stack trace available';
|
|
|
|
if (error.response?.status) {
|
|
const { status, headers, data } = error.response;
|
|
logMessage = `${message} The server responded with status ${status}: ${error.message}`;
|
|
logger.error(logMessage, {
|
|
status,
|
|
headers,
|
|
data,
|
|
stack,
|
|
});
|
|
} else if (error.request) {
|
|
const { method, url } = error.config || {};
|
|
logMessage = `${message} No response received for ${method ? method.toUpperCase() : ''} ${url || ''}: ${error.message}`;
|
|
logger.error(logMessage, {
|
|
requestInfo: { method, url },
|
|
stack,
|
|
});
|
|
} else if (error?.message?.includes("Cannot read properties of undefined (reading 'status')")) {
|
|
logMessage = `${message} It appears the request timed out or was unsuccessful: ${error.message}`;
|
|
logger.error(logMessage, { stack });
|
|
} else {
|
|
logMessage = `${message} An error occurred while setting up the request: ${error.message}`;
|
|
logger.error(logMessage, { stack });
|
|
}
|
|
} catch (err) {
|
|
logMessage = `Error in logAxiosError: ${err.message}`;
|
|
logger.error(logMessage, { stack: err.stack || 'No stack trace available' });
|
|
}
|
|
return logMessage;
|
|
};
|
|
|
|
module.exports = { logAxiosError };
|