| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  | const lookupContactByPhone = require('./lookupCRMContactByPhone') | 
					
						
							|  |  |  | const createContact = require('./createContact') | 
					
						
							|  |  |  | const sendMessageSocket = require('./sendMessageSocket') | 
					
						
							|  |  |  | const findProperty = require('./findProperty') | 
					
						
							|  |  |  | const journalingRequest = require('./journalingRequest') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 12:17:54 +00:00
										 |  |  | async function templateValidator(crmPhoneTest, crm, companyId) { | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     let phoneTest = crmPhoneTest ? crmPhoneTest : '5511900112233' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let contact = await lookupContactByPhone( | 
					
						
							|  |  |  |         rest = crm.crmRest, | 
					
						
							|  |  |  |         authentication = crm.authentication, | 
					
						
							| 
									
										
										
										
											2025-10-13 13:54:49 +00:00
										 |  |  |         crmPhone = phoneTest.replace("+", ""), | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |         companyId, | 
					
						
							| 
									
										
										
										
											2024-11-28 12:17:54 +00:00
										 |  |  |         test = { testing: true }) | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (!contact.exist) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 12:17:54 +00:00
										 |  |  |         console.log('O CONTATO SER CRIADO') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |         contact = await createContact(companyId, | 
					
						
							|  |  |  |             rest = crm.crmRest, | 
					
						
							|  |  |  |             authentication = crm.authentication, | 
					
						
							|  |  |  |             crmPhone = phoneTest, | 
					
						
							| 
									
										
										
										
											2024-09-30 13:53:32 +00:00
										 |  |  |             crmFirstName = 'Username', | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |             crmLastName = '', | 
					
						
							|  |  |  |             crmEmail = '', | 
					
						
							| 
									
										
										
										
											2024-11-28 12:17:54 +00:00
										 |  |  |             test = { testing: true }) | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         sendMessageSocket({ companyId, status: 'processing', data: { msg } }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |         msg = `Contato de numero ${phoneTest} já existe no crm` | 
					
						
							| 
									
										
										
										
											2025-04-10 18:28:38 +00:00
										 |  |  |         console.log("======> msg testing: ", msg) | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |         sendMessageSocket({ companyId, status: 'processing', data: { msg } }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let { request, calls, response } = findProperty(crm.crmRest, 'callJournaling') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (const operation of calls) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         msg = `Tentando inserir registro de chamada(call journal) ${Object.keys(operation)[0]} para o contato ${phoneTest}` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-10 18:28:38 +00:00
										 |  |  |         console.log("======> msg testing: ", msg, " | companyId: ", companyId) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |         await journalingRequest(request, | 
					
						
							|  |  |  |             body = operation[Object.keys(operation)[0]], | 
					
						
							|  |  |  |             crmCallDuration = "900", | 
					
						
							|  |  |  |             contact, | 
					
						
							|  |  |  |             crmAgent = "2245", | 
					
						
							|  |  |  |             crmPhone = phoneTest, | 
					
						
							|  |  |  |             authentication = crm.authentication, | 
					
						
							| 
									
										
										
										
											2025-04-10 18:28:38 +00:00
										 |  |  |             test = { testing: true, msg, companyId }, | 
					
						
							|  |  |  |             companyId) | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         msg = `Registro de chamada inserido com sucesso ${Object.keys(operation)[0]} para o contato ${phoneTest}` | 
					
						
							| 
									
										
										
										
											2025-04-10 18:28:38 +00:00
										 |  |  |         console.log("======> msg testing: ", msg) | 
					
						
							| 
									
										
										
										
											2023-11-29 20:05:48 +00:00
										 |  |  |         sendMessageSocket({ companyId, status: 'processing', data: { msg } }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     sendMessageSocket({ companyId, status: 'finished', data: { crmPhoneTest: phoneTest } }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = templateValidator |