2024-01-01 21:08:02 +01:00
|
|
|
const axios = require('axios');
|
2025-10-01 23:30:47 -04:00
|
|
|
const { isEnabled } = require('@librechat/api');
|
|
|
|
|
const { logger } = require('@librechat/data-schemas');
|
2024-04-21 08:31:54 -04:00
|
|
|
const { ErrorTypes } = require('librechat-data-provider');
|
2024-01-01 21:08:02 +01:00
|
|
|
const denyRequest = require('./denyRequest');
|
|
|
|
|
|
|
|
|
|
async function moderateText(req, res, next) {
|
2025-04-03 20:42:56 -04:00
|
|
|
if (!isEnabled(process.env.OPENAI_MODERATION)) {
|
|
|
|
|
return next();
|
|
|
|
|
}
|
|
|
|
|
try {
|
|
|
|
|
const { text } = req.body;
|
2024-01-01 21:08:02 +01:00
|
|
|
|
2025-04-03 20:42:56 -04:00
|
|
|
const response = await axios.post(
|
|
|
|
|
process.env.OPENAI_MODERATION_REVERSE_PROXY || 'https://api.openai.com/v1/moderations',
|
|
|
|
|
{
|
|
|
|
|
input: text,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
headers: {
|
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
|
Authorization: `Bearer ${process.env.OPENAI_MODERATION_API_KEY}`,
|
2024-01-01 21:08:02 +01:00
|
|
|
},
|
2025-04-03 20:42:56 -04:00
|
|
|
},
|
|
|
|
|
);
|
2024-01-01 21:08:02 +01:00
|
|
|
|
2025-04-03 20:42:56 -04:00
|
|
|
const results = response.data.results;
|
|
|
|
|
const flagged = results.some((result) => result.flagged);
|
2024-01-01 21:08:02 +01:00
|
|
|
|
2025-04-03 20:42:56 -04:00
|
|
|
if (flagged) {
|
|
|
|
|
const type = ErrorTypes.MODERATION;
|
|
|
|
|
const errorMessage = { type };
|
2024-01-01 21:08:02 +01:00
|
|
|
return await denyRequest(req, res, errorMessage);
|
|
|
|
|
}
|
2025-04-03 20:42:56 -04:00
|
|
|
} catch (error) {
|
|
|
|
|
logger.error('Error in moderateText:', error);
|
|
|
|
|
const errorMessage = 'error in moderation check';
|
|
|
|
|
return await denyRequest(req, res, errorMessage);
|
2024-01-01 21:08:02 +01:00
|
|
|
}
|
|
|
|
|
next();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
module.exports = moderateText;
|