197 lines
37 KiB
JavaScript
197 lines
37 KiB
JavaScript
// console.log(req.params);
|
|
// console.log(req.query);
|
|
console.log(req.body);
|
|
const external = req.body.event?.external;
|
|
const sessionId = req.body.event?.conversationId;
|
|
const input = req.body.event?.input;
|
|
const params = req.body.event?.params || {};
|
|
const modelName = params?.modelName || settings_66a1322d44405adda4fe9f53.nlu.modelName;
|
|
const env = params?.env;
|
|
const postBack = req.body.event?.postBack;
|
|
const metadata = {
|
|
...req.body.event?.metadata,
|
|
userId: req.body.event?.sentBy?.userId
|
|
};
|
|
switch (metadata?.tenantName) {
|
|
case 'lexingtonLaw':
|
|
settings_66a1322d44405adda4fe9f53.messenger.avatar = '';
|
|
break;sessionId
|
|
case 'credit':
|
|
settings_66a1322d44405adda4fe9f53.messenger.avatar = '';
|
|
break;
|
|
case 'creditRepair':
|
|
settings_66a1322d44405adda4fe9f53.messenger.avatar = '';
|
|
break;
|
|
}
|
|
const configuration = req.body.event?.configuration;
|
|
(async () => {
|
|
try {
|
|
const smStr = `session-map-${sessionId}`;
|
|
console.log('line 30');
|
|
console.log(smStr);
|
|
if (external) { } else {
|
|
await axios.post(`${settings_66a1322d44405adda4fe9f53.messenger.apiBaseURL}Conversation/join`, {
|
|
_id: sessionId,
|
|
participant: {
|
|
userId: settings_66a1322d44405adda4fe9f53.messenger.participantId,
|
|
type: 'bot',
|
|
name: settings_66a1322d44405adda4fe9f53.messenger.name,
|
|
avatar: settings_66a1322d44405adda4fe9f53.messenger.avatar
|
|
}
|
|
}, {
|
|
headers: {
|
|
Authorization: `Bearer ${settings_66a1322d44405adda4fe9f53.messenger.token}`
|
|
}
|
|
}).then(response => {
|
|
if (response?.data?._id) { } else throw new Error();
|
|
});
|
|
axios.post(`${settings_66a1322d44405adda4fe9f53.messenger.apiBaseURL}Event/isTyping`, {
|
|
workspaceId: req.params.workspaceId,
|
|
conversationId: sessionId,
|
|
userId: settings_66a1322d44405adda4fe9f53.messenger.participantId,
|
|
typing: true
|
|
}, {
|
|
headers: {
|
|
Authorization: `Bearer ${settings_66a1322d44405adda4fe9f53.messenger.token}`
|
|
}
|
|
});
|
|
}
|
|
const sessionMap = await redis.hGetAll(smStr);
|
|
// console.log(sessionMap);
|
|
const recognizedData = await axios.post(`${settings_66a1322d44405adda4fe9f53.nlu.apiBaseURL}Model/run/${req.params.workspaceId}/${req.params.branch}/${modelName}`, {
|
|
input: input,
|
|
conversationId: sessionMap.conversationId,
|
|
settings: settings_66a1322d44405adda4fe9f53.nlu.settings,
|
|
metadata: metadata,
|
|
postBack: postBack,
|
|
configuration: configuration
|
|
}).then(response => {
|
|
return response.data;
|
|
}).catch(error => {
|
|
//If we have error handling turned off, don't record the error
|
|
if (settings_66a1322d44405adda4fe9f53.errorHandling === false) {
|
|
throw error;
|
|
} else {
|
|
// Conversation ID is generated by the NLU
|
|
// Must make sure Conversation ID is created properly for an error transaction
|
|
// Get it from session map if it exists, or generate it if we got the error at the very first transaction.
|
|
const conversationId = sessionMap.conversationId || uuidv4();
|
|
let errorPayload = {
|
|
id: uuidv4(),
|
|
workspaceId: req.params.workspaceId,
|
|
errorInfo: {
|
|
name: error.name,
|
|
message: error.message,
|
|
stack: error.stack
|
|
},
|
|
conversationId,
|
|
input,
|
|
answers: [settings_66a1322d44405adda4fe9f53.responses.modelError],
|
|
req: {
|
|
params: req.params,
|
|
query: req.query,
|
|
body: req.body,
|
|
headers: req.headers
|
|
},
|
|
metadata,
|
|
classificationResults: [{
|
|
label: "Model Error",
|
|
value: 0.0
|
|
}],
|
|
nerResults: {
|
|
entities: [],
|
|
sourceEntities: []
|
|
},
|
|
// Reporting tags to match GlobalSupport function reporting
|
|
tag: "ERROR",
|
|
reporting: {
|
|
tag: "ERROR",
|
|
modelResponse: "ERROR"
|
|
}
|
|
};
|
|
|
|
// Add model name
|
|
errorPayload.req.params.route = modelName;
|
|
|
|
//add any other details you wish to see in transaction data
|
|
|
|
return errorPayload;
|
|
}
|
|
});
|
|
let formFlowEnd = recognizedData.formFlowEnd;
|
|
if (formFlowEnd) {
|
|
await redis.hSet(smStr, {
|
|
formFlow: "false",
|
|
});
|
|
}
|
|
if (recognizedData.conversationId) {
|
|
await redis.hSet(smStr, 'conversationId', recognizedData.conversationId);
|
|
await redis.expire(smStr, 3600);
|
|
if (sessionMap.conversationId) { } else {
|
|
db.analytics.addConversation({
|
|
id: recognizedData.conversationId
|
|
});
|
|
}
|
|
}
|
|
// NOTE: Additonal logic could be used to provide answer from alternative sources
|
|
// recognizedData.answers = API_RESPONSE || ['Example'];
|
|
if (recognizedData.tag === "ERROR") { } else if (recognizedData.classificationResults.length === 0 && recognizedData.answers.length === 0) {
|
|
recognizedData.answers = [settings_66a1322d44405adda4fe9f53.responses.unrecognized];
|
|
} else if (recognizedData.answers.length === 0) {
|
|
recognizedData.answers = [settings_66a1322d44405adda4fe9f53.responses.unanswered];
|
|
}
|
|
recognizedData._id = (await db.analytics.addTransaction(recognizedData)).insertedId;
|
|
console.log({ recognizedData });
|
|
//edh_gvf_664f9ce8a46543d70da1ed74(recognizedData); //added for EDH hookup based on documentations
|
|
if (external) { } else {
|
|
new Promise(async resolve => {
|
|
for (const [index, answer] of recognizedData.answers.entries()) {
|
|
console.log(recognizedData.tag)
|
|
try {
|
|
console.log(151);
|
|
console.log(sessionId);
|
|
await axios.post(`${settings_66a1322d44405adda4fe9f53.messenger.apiBaseURL}Event/create`, {
|
|
conversationId: sessionId,
|
|
input: answer,
|
|
sentBy: {
|
|
userId: settings_66a1322d44405adda4fe9f53.messenger.participantId,
|
|
name: settings_66a1322d44405adda4fe9f53.messenger.name,
|
|
avatar: settings_66a1322d44405adda4fe9f53.messenger.avatar
|
|
},
|
|
ping: nanoid(),
|
|
sentAt: Date.now(),
|
|
options: recognizedData?.options,
|
|
metadata: {
|
|
outputs: recognizedData.answers.length == index + 1 ? recognizedData?.outputs : {},
|
|
transactionId: recognizedData._id,
|
|
feedbackable: ['seaiSelfServiceComplete', 'seaiSelfServiceInformational', 'LLM'].includes(recognizedData.tag)
|
|
}
|
|
}, {
|
|
headers: {
|
|
Authorization: `Bearer ${settings_66a1322d44405adda4fe9f53.messenger.token}`
|
|
}
|
|
});
|
|
} catch (e) { }
|
|
}
|
|
resolve(true);
|
|
});
|
|
axios.post(`${settings_66a1322d44405adda4fe9f53.messenger.apiBaseURL}Event/isTyping`, {
|
|
workspaceId: req.params.workspaceId,
|
|
conversationId: sessionId,
|
|
userId: settings_66a1322d44405adda4fe9f53.messenger.participantId,
|
|
typing: false
|
|
}, {
|
|
headers: {
|
|
Authorization: `Bearer ${settings_66a1322d44405adda4fe9f53.messenger.token}`
|
|
}
|
|
});
|
|
}
|
|
res.send(recognizedData);
|
|
} catch (error) {
|
|
console.log(error.message);
|
|
res.send({
|
|
answers: ['Something went wrong. Please try again.'],
|
|
outputs: {}
|
|
});
|
|
}
|
|
})(); |