| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | const loadCRM = require('./loadCRM') | 
					
						
							|  |  |  | const lookupContactByPhone = require('./lookupCRMContactByPhone') | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | const lookupContactByEmail = require('./lookupCRMContactByEmail') | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | const createContact = require('./createContact') | 
					
						
							|  |  |  | const findProperty = require('./findProperty') | 
					
						
							|  |  |  | const CRM_Contact = require('../models/CRM_Contact') | 
					
						
							|  |  |  | const CRM_Ticket = require('../models/CRM_Ticket') | 
					
						
							|  |  |  | const CRM = require('../models/CRM') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const lookupCRMTicket = require('./lookupCRMTicket') | 
					
						
							|  |  |  | const sendEventTicketCreatedToSocket = require('./sendEventTicketCreatedToSocket') | 
					
						
							|  |  |  | const journalingRequest = require('./journalingRequest') | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-18 19:30:51 +00:00
										 |  |  | const getIntegrationsConfig = require('../utils/getIntegrationsConfig') | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | const updateLeadStatus = require('./updateLeadStatus') | 
					
						
							|  |  |  | const extractLeadStatusChange = require('./extractLeadStatusChange') | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | async function whatsappJournalingCRM(companyId, crmPhone = '', crmAgent, crmFirstName = 'Username', ticketId = null, crmEmail = '', dynamicBodyRequest = {}) { | 
					
						
							|  |  |  |     // async function whatsappJournalingCRM(companyId, crmPhone, crmAgent, crmFirstName = 'Username', ticketId = null) {
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     const crmFiles = await loadCRM(companyId) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |     const crmContactIds = [] | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (const crmConfig of crmFiles) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const { crmRest: rest, authentication } = crmConfig.crm | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Record whatsapp conversation that happened in omnihit v2
 | 
					
						
							|  |  |  |         let chatJournaling = findProperty(rest, 'chatJournaling') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-14 17:13:49 +00:00
										 |  |  |         console.log('===============> chatJournaling: ', JSON.stringify(chatJournaling, null, 6)) | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (chatJournaling) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |             let contact = await _lookupContact(rest, authentication, crmPhone, crmEmail, companyId, crmFirstName) | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-13 13:54:49 +00:00
										 |  |  |             console.log("================> whatsappJournalingCRM contact: ", JSON.stringify(contact, null, 6)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |             let { request, chats, response } = chatJournaling | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             let body = findProperty(chats, 'chatDone') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |             let config = await getIntegrationsConfig(companyId, 'omnihit') | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-18 19:30:51 +00:00
										 |  |  |             if (ticketId && config) { | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-18 19:30:51 +00:00
										 |  |  |                 const { accountId, api: { url, urlHttps, token } = {}, | 
					
						
							|  |  |  |                     createConversation: { inbox_id, status, team_id } = {} = {} } = config | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 console.log('===============> body1: ', body) | 
					
						
							|  |  |  |                 body = JSON.stringify(body) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (body.includes('chatLink')) { | 
					
						
							|  |  |  |                     body = body.replace('chatLink', `${urlHttps}/app/accounts/${accountId}/conversations/${ticketId}`) | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 console.log('===============> body2: ', body) | 
					
						
							|  |  |  |                 body = JSON.parse(body) | 
					
						
							| 
									
										
										
										
											2025-10-14 17:13:49 +00:00
										 |  |  |                 console.log('===============> body3: ', JSON.stringify(body, null, 6)) | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |             await journalingRequest(request, body, crmCallDuration = 0, contact, crmAgent, crmPhone, authentication, rest, companyId, dynamicBodyRequest) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // Se vier um novo status (__newLeadStatus), executa PATCH aproveitando as validações do fluxo de Activity
 | 
					
						
							|  |  |  |             try { | 
					
						
							|  |  |  |                 const { shouldUpdate, newStatus, leadId: leadIdFromBody } = extractLeadStatusChange(dynamicBodyRequest) | 
					
						
							|  |  |  |                 const leadId = leadIdFromBody || contact?.contactId | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (shouldUpdate && leadId) { | 
					
						
							|  |  |  |                     console.log('whatsappJournalingCRM: Atualizando Status do Lead', { leadId, newStatus }) | 
					
						
							|  |  |  |                     await updateLeadStatus(rest, authentication, leadId, newStatus, companyId) | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } catch (err) { | 
					
						
							|  |  |  |                 console.error('whatsappJournalingCRM: falha ao atualizar Status do Lead', err?.message || err) | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         //
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return crmContactIds | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = whatsappJournalingCRM | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | // async function _lookupContact(rest, authentication, crmPhone, companyId, crmFirstName) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //     let contact = await lookupContactByPhone(rest, authentication, crmPhone, companyId)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //     if (contact?.exist) {
 | 
					
						
							|  |  |  | //         return { created: false, contactId: contact.contactId }
 | 
					
						
							|  |  |  | //     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //     if (!contact?.exist) {
 | 
					
						
							|  |  |  | //         contact = await createContact(companyId, rest, authentication, crmPhone, crmFirstName)
 | 
					
						
							|  |  |  | //     }
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | //     return { created: true, contactId: contact.contactId }
 | 
					
						
							|  |  |  | // }
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | async function _lookupContact(rest, authentication, crmPhone, crmEmail, companyId, crmFirstName) { | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |     let contact = null | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // 1. Tenta buscar o contato por telefone se o crmPhone for fornecido
 | 
					
						
							|  |  |  |     if (crmPhone) { | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |         console.log(`Buscando contato por telefone: ${crmPhone}`) | 
					
						
							|  |  |  |         contact = await lookupContactByPhone(rest, authentication, crmPhone, companyId) | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // 2. Se não encontrou por telefone, tenta buscar por e-mail se o crmEmail for fornecido
 | 
					
						
							|  |  |  |     if (!contact?.exist && crmEmail) { | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |         console.log(`Contato não encontrado por telefone. Tentando por e-mail: ${crmEmail}`) | 
					
						
							|  |  |  |         contact = await lookupContactByEmail(rest, authentication, crmEmail, companyId) | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // 3. Se o contato já existe (seja por telefone ou e-mail), retorna as informações
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |     if (contact?.exist) { | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |         console.log(`Contato encontrado! ID: ${contact.contactId}`) | 
					
						
							|  |  |  |         return { created: false, contactId: contact.contactId, contactId2: contact?.contactId2 } | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     // 4. Se o contato não foi encontrado por nenhuma das formas, cria um novo
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |     console.log(`Contato não encontrado. Criando um novo com base no ${crmPhone ? 'telefone' : 'e-mail'}.`) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     // AQUI ESTÁ A ÚNICA MUDANÇA NECESSÁRIA:
 | 
					
						
							|  |  |  |     // Chamamos createContact passando os valores de telefone e e-mail separadamente.
 | 
					
						
							|  |  |  |     // A função createContact agora sabe como lidar com ambos, mesmo que um deles seja vazio.
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |     // createContact(companyId, rest, authentication, crmPhone = '', crmFirstName = 'Username', crmLastName = 'Last name', crmEmail = '', test = {}, dynamicBodyRequest = {}, flow = 1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     console.log("=================> whatsappJournalingCRM contact?.flow: ", contact?.flow) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     contact = await createContact(companyId, rest, authentication, crmPhone, crmFirstName, 'Last name', crmEmail, test = {}, dynamicBodyRequest = {}, flow = contact?.flow) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     // Se o contato for criado, retorna suas informações
 | 
					
						
							|  |  |  |     if (contact?.contactId) { | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |         console.log(`Novo contato criado com ID: ${contact.contactId}`) | 
					
						
							|  |  |  |         return { created: true, contactId: contact.contactId, contactId2: contact?.contactId2 } | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-09 17:29:44 +00:00
										 |  |  |     // Caso não tenha nem telefone nem e-mail, retorna um erro ou um valor nulo
 | 
					
						
							| 
									
										
										
										
											2025-10-21 12:18:51 +00:00
										 |  |  |     console.error("Erro: Não foi possível encontrar ou criar um contato. Telefone e e-mail não fornecidos.") | 
					
						
							|  |  |  |     return null | 
					
						
							| 
									
										
										
										
											2024-11-05 18:37:36 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 |