@peopl-health/nexus 3.0.5 → 3.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,7 +3,7 @@ const axios = require('axios');
3
3
  const runtimeConfig = require('../config/runtimeConfig');
4
4
  const { uploadMediaToS3, getFileExtension } = require('../helpers/mediaHelper');
5
5
  const { ensureWhatsAppFormat } = require('../helpers/twilioHelper');
6
- const { sanitizeMediaFilename } = require('../utils/sanitizer');
6
+ const { sanitizeMediaFilename } = require('../utils/inputSanitizer');
7
7
  const { generatePresignedUrl } = require('../config/awsConfig');
8
8
  const { validateMedia, getMediaType } = require('../utils/mediaValidator');
9
9
  const { logger } = require('../utils/logger');
@@ -7,7 +7,7 @@ const sharp = require('sharp');
7
7
 
8
8
  const { downloadFileFromS3 } = require('../config/awsConfig.js');
9
9
  const { Message } = require('../models/messageModel.js');
10
- const { sanitizeFilename } = require('../utils/sanitizer.js');
10
+ const { sanitizeFilename } = require('../utils/inputSanitizer.js');
11
11
  const { logger } = require('../utils/logger');
12
12
 
13
13
  async function convertPdfToImages(pdfName, existingPdfPath = null) {
@@ -1,7 +1,7 @@
1
1
  const path = require('path');
2
2
  const fs = require('fs');
3
3
  const AWS = require('../config/awsConfig.js');
4
- const { sanitizeMediaFilename } = require('../utils/sanitizer.js');
4
+ const { sanitizeMediaFilename } = require('../utils/inputSanitizer.js');
5
5
  const { logger } = require('../utils/logger');
6
6
 
7
7
  async function uploadMediaToS3(buffer, messageID, titleFile, bucketName, contentType, messageType) {
@@ -2,8 +2,7 @@ const fs = require('fs');
2
2
  const { generatePresignedUrl } = require('../config/awsConfig.js');
3
3
  const { analyzeImage } = require('./llmsHelper.js');
4
4
  const { cleanupFiles, downloadMediaAndCreateFile } = require('./filesHelper.js');
5
- const { formatMessage } = require('./messageHelper.js');
6
- const { sanitizeLogMetadata } = require('../utils/sanitizer.js');
5
+ const { sanitizeLogMetadata } = require('../utils/inputSanitizer.js');
7
6
  const { withTracing } = require('../utils/tracingDecorator.js');
8
7
 
9
8
  /**
@@ -13,7 +13,9 @@ const { processThreadMessage } = require('../helpers/processHelper.js');
13
13
  const { getLastNMessages, updateMessageRecord } = require('../helpers/messageHelper.js');
14
14
  const { combineImagesToPDF, cleanupFiles } = require('../helpers/filesHelper.js');
15
15
  const { getAssistantById } = require('./assistantResolver');
16
+
16
17
  const { logger } = require('../utils/logger');
18
+ const { sanitizeOutput } = require('../utils/outputSanitizer');
17
19
 
18
20
  const createAssistantCore = async (code, assistant_id, messages = [], force = false) => {
19
21
  const findThread = await Thread.findOne({ code: code });
@@ -225,7 +227,16 @@ const replyAssistantCore = async (code, message_ = null, thread_ = null, runOpti
225
227
  timings.run_assistant_ms = Date.now() - runStart;
226
228
  timings.total_ms = Date.now() - startTotal;
227
229
 
228
- const { output, completed, retries, predictionTimeMs, tools_executed } = runResult;
230
+ const { output: rawOutput, completed, retries, predictionTimeMs, tools_executed } = runResult;
231
+
232
+ const output = sanitizeOutput(rawOutput);
233
+ if (rawOutput !== output) {
234
+ logger.debug('[replyAssistantCore] Output sanitized', {
235
+ originalLength: rawOutput?.length || 0,
236
+ sanitizedLength: output?.length || 0,
237
+ removedContent: rawOutput?.length ? 'brackets_removed' : 'none'
238
+ });
239
+ }
229
240
 
230
241
  logger.info('[Assistant Reply Complete]', {
231
242
  code: code ? `${code.substring(0, 3)}***${code.slice(-4)}` : 'unknown',
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Sanitize AI response output by removing unwanted content
3
+ */
4
+
5
+ function removeBracketContent(text) {
6
+ if (!text || typeof text !== 'string') return text;
7
+ return text.replace(/\[([^\]]*)\]/g, '').trim();
8
+ }
9
+
10
+ function sanitizeOutput(text) {
11
+ if (!text || typeof text !== 'string') return text;
12
+
13
+ let sanitized = text;
14
+ sanitized = removeBracketContent(sanitized);
15
+ sanitized = sanitized.replace(/\s+/g, ' ').trim();
16
+
17
+ return sanitized;
18
+ }
19
+
20
+ module.exports = {
21
+ sanitizeOutput,
22
+ removeBracketContent
23
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@peopl-health/nexus",
3
- "version": "3.0.5",
3
+ "version": "3.0.6",
4
4
  "description": "Core messaging and assistant library for WhatsApp communication platforms",
5
5
  "keywords": [
6
6
  "whatsapp",
@@ -107,7 +107,7 @@
107
107
  "baileys": "^6.4.0",
108
108
  "express": "^4.22.1",
109
109
  "openai": "6.7.0",
110
- "twilio": "5.6.0"
110
+ "twilio": "5.11.2"
111
111
  },
112
112
  "engines": {
113
113
  "node": ">=20.0.0"
File without changes