From 5a09bfad69f0c78f0886dda92b6920d43af93020 Mon Sep 17 00:00:00 2001 From: Adam Mendlik Date: Mon, 6 May 2024 09:40:50 -0600 Subject: [PATCH] Return SSML content from response bots --- lambda/fulfillment/lib/middleware/lexRouter.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/lambda/fulfillment/lib/middleware/lexRouter.js b/lambda/fulfillment/lib/middleware/lexRouter.js index 0c6e494c..8c130b3a 100644 --- a/lambda/fulfillment/lib/middleware/lexRouter.js +++ b/lambda/fulfillment/lib/middleware/lexRouter.js @@ -220,6 +220,11 @@ async function handleRequest(req, res, botName, botAlias) { const lexv2response = await lexV2ClientRequester(params); qnabot.log(`Lex V2 response: ${JSON.stringify(lexv2response)}`); response.message = _.get(lexv2response, 'messages[0].content', ''); + response.messages = {} + for (const message of _.get(lexv2response, 'messages', [])) { + response.messages[message.contentType] = message.content + } + // lex v2 FallbackIntent match means it failed to fill desired slot(s). if (lexv2response.sessionState.intent.name === 'FallbackIntent' || lexv2response.sessionState.intent.state === 'Failed') { @@ -277,13 +282,8 @@ async function processResponse(req, res, hook, msg) { const botResp = await handleRequest(req, res, hook, 'live'); qnabot.log(`botResp: ${JSON.stringify(botResp, null, 2)}`); - let plainMessage = botResp.message; - let ssmlMessage; - // if messsage contains SSML tags, strip tags for plain text, but preserve tags for SSML - if (plainMessage?.includes('')) { - ssmlMessage = botResp.message; - plainMessage = plainMessage.replace(/<\/?[^>]+(>|$)/g, ''); // NOSONAR - javascript:S5852 - input is user controlled and we have a limit on the number of characters - } + let plainMessage = _.get(botResp, 'messages.PlainText', ''); + let ssmlMessage = _.get(botResp, 'messages.SSML', ''); let elicitResponseLoopCount = _.get(res, 'session.qnabotcontext.elicitResponse.loopCount', 0); switch (botResp.dialogState) {