crm-api-template-generator/backend/controllers/transcriptionController.js

50 lines
1.7 KiB
JavaScript
Raw Normal View History

2025-06-16 17:56:12 +00:00
const HubspotService = require('../services/hubspotService');
const { get, del } = require('../utils/redisClient')
const hubspotService = new HubspotService();
2025-06-16 17:56:12 +00:00
const receiveTranscription = async (req, res) => {
try {
2025-06-16 17:56:12 +00:00
const { crmPhone, uniqueId, transcription, recordingUrl, companyId } = req.body;
if (!crmPhone || !uniqueId || !transcription || !recordingUrl) {
return res.status(400).json({ error: 'Campos obrigatórios ausentes.' });
}
2025-06-16 17:56:12 +00:00
console.log(`Recebida transcrição para crmPhone: ${crmPhone}, uniqueId: ${uniqueId}`);
console.log('Transcrição:', transcription.summary);
// 1. Buscar ticketId no Redis
2025-06-16 17:56:12 +00:00
const ticketId = await get(crmPhone);
if (!ticketId) {
2025-06-16 17:56:12 +00:00
console.warn(`Nenhum ticketId encontrado no Redis para o crmPhone: ${crmPhone}. A transcrição será salva como uma nota sem associação ao ticket.`);
}
2025-06-16 17:56:12 +00:00
// 2. Buscar ou criar contato no HubSpot
2025-06-16 17:56:12 +00:00
const contact = await hubspotService.createContactIfNotExists(companyId, crmPhone);
// 3. Criar nota no HubSpot e associar ao contato e ao ticket (se existir)
2025-06-16 17:56:12 +00:00
await hubspotService.createCallNote(contact.contactId, {
transcription: `${transcription.client || ''}\n${transcription.agent || ''}`,
summary: transcription.summary,
recordingUrl,
2025-06-16 17:56:12 +00:00
crmPhone,
uniqueId,
ticketId
});
2025-06-16 17:56:12 +00:00
await del(crmPhone)
return res.status(200).json({ message: 'Transcrição recebida e processada com sucesso!' });
} catch (error) {
console.error('Erro ao receber transcrição:', error?.response?.data || error.message || error);
return res.status(500).json({ error: 'Erro ao processar a transcrição.' });
}
};
2025-06-16 17:56:12 +00:00
module.exports ={
receiveTranscription
}