Compare commits
	
		
			3 Commits 
		
	
	
		
			ec6e84f567
			...
			279c4697dd
		
	
	| Author | SHA1 | Date | 
|---|---|---|
|  | 279c4697dd | |
|  | e020a5f75d | |
|  | c5c5ddb5a4 | 
|  | @ -93,7 +93,7 @@ export const index = async (req: Request, res: Response): Promise<Response> => { | |||
| 
 | ||||
|   let queueIds: number[] = []; | ||||
| 
 | ||||
|   if (queueIdsStringified) { | ||||
|   if (queueIdsStringified && queueIdsStringified.trim().length > 0) { | ||||
|     queueIds = JSON.parse(queueIdsStringified); | ||||
|   } | ||||
| 
 | ||||
|  |  | |||
|  | @ -265,6 +265,10 @@ export const weebhook = async ( | |||
|       }); | ||||
| 
 | ||||
|       if (type == "text") { | ||||
|         if (!message?.text?.body) { | ||||
|           return res.status(400).json({ error: "body not found" }); | ||||
|         } | ||||
| 
 | ||||
|         type = "chat"; | ||||
|         msg = { | ||||
|           ...msg, | ||||
|  | @ -272,6 +276,10 @@ export const weebhook = async ( | |||
|           type | ||||
|         }; | ||||
|       } else { | ||||
|         if (!message[message?.type]?.id) { | ||||
|           return res.status(400).json({ error: "id not found" }); | ||||
|         } | ||||
| 
 | ||||
|         const mediaId = message[message.type].id; | ||||
|         const mimetype = message[message.type].mime_type; | ||||
| 
 | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ const GetDefaultWhatsApp = async ({ | |||
|     where: { isDefault: true } | ||||
|   }); | ||||
| 
 | ||||
|   if (!defaultWhatsapp && !ignoreNoWhatsappFound) { | ||||
|   if (!defaultWhatsapp) {  | ||||
|     if (userId) { | ||||
|       let whatsapps = await wbotByUserQueue({ userId, queueId }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -27,9 +27,13 @@ const CheckIsValidContact = async ( | |||
|   } | ||||
| 
 | ||||
|   try { | ||||
|     let _status: any; | ||||
| 
 | ||||
|     if (!isValidNumber) { | ||||
| 
 | ||||
|       const { data } = await axios.post( | ||||
|       console.log('kkkkkkkkkkkkkkkkkkkkkkkkkkkkk ') | ||||
| 
 | ||||
|       const { data, status } = await axios.post( | ||||
|         `${process.env.WHATS_NUMBER_VALIDATOR_URL}/api/validate`, | ||||
|         { mobile: number }, | ||||
|         { | ||||
|  | @ -40,10 +44,14 @@ const CheckIsValidContact = async ( | |||
|       ); | ||||
| 
 | ||||
|       isValidNumber = data; | ||||
|       _status = status;  | ||||
|     } | ||||
|   | ||||
|     if (ignoreThrow) return isValidNumber?.number; | ||||
|     | ||||
|   console.log('_status: ', _status) | ||||
| 
 | ||||
|     if (_status && _status == 422) throw new AppError("ERR_NO_WAPP_FOUND"); | ||||
| 
 | ||||
|     if (!isValidNumber || (isValidNumber && !isValidNumber.isValid)) { | ||||
|       throw new AppError("invalidNumber"); | ||||
|     } | ||||
|  |  | |||
|  | @ -98,7 +98,7 @@ import FindOrCreateTicketServiceBot from "../TicketServices/FindOrCreateTicketSe | |||
| import ShowTicketService from "../TicketServices/ShowTicketService"; | ||||
| import ShowQueuesByUser from "../UserServices/ShowQueuesByUser"; | ||||
| import ListWhatsappQueuesByUserQueue from "../UserServices/ListWhatsappQueuesByUserQueue"; | ||||
| import CreateContactService from "../ContactServices/CreateContactService" | ||||
| import CreateContactService from "../ContactServices/CreateContactService"; | ||||
| 
 | ||||
| var lst: any[] = getWhatsappIds(); | ||||
| 
 | ||||
|  | @ -318,13 +318,14 @@ const verifyQueue = async ( | |||
|     selectedOption = 1; | ||||
|     choosenQueue = queues[+selectedOption - 1]; | ||||
|   } else { | ||||
|     selectedOption = msg.body; | ||||
|     selectedOption = msg?.body; | ||||
| 
 | ||||
|     //////////////// EXTRAIR APENAS O NÚMERO ///////////////////
 | ||||
|     selectedOption = selectedOption.replace(/[^1-9]/g, ""); | ||||
|     ///////////////////////////////////
 | ||||
| 
 | ||||
|     choosenQueue = queues[+selectedOption - 1]; | ||||
|     if (selectedOption && selectedOption.trim().length > 0) { | ||||
|       //////////////// EXTRAIR APENAS O NÚMERO ///////////////////
 | ||||
|       selectedOption = selectedOption.replace(/[^1-9]/g, ""); | ||||
|       ///////////////////////////////////
 | ||||
|       choosenQueue = queues[+selectedOption - 1]; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   if (choosenQueue) { | ||||
|  | @ -780,33 +781,33 @@ const handleMessage = async ( | |||
|       await verifyQueue(wbot, msg, ticket, contact); | ||||
|     } | ||||
| 
 | ||||
|       if (msg.type === "vcard") { | ||||
|         try { | ||||
|           const array = msg.body.split("\n"); | ||||
|           const obj = []; | ||||
|           let contact = ""; | ||||
|           for (let index = 0; index < array.length; index++) { | ||||
|             const v = array[index]; | ||||
|             const values = v.split(":"); | ||||
|             for (let ind = 0; ind < values.length; ind++) { | ||||
|               if (values[ind].indexOf("+") !== -1) { | ||||
|                 obj.push({ number: values[ind] }); | ||||
|               } | ||||
|               if (values[ind].indexOf("FN") !== -1) { | ||||
|                 contact = values[ind + 1]; | ||||
|               } | ||||
|     if (msg.type === "vcard") { | ||||
|       try { | ||||
|         const array = msg.body.split("\n"); | ||||
|         const obj = []; | ||||
|         let contact = ""; | ||||
|         for (let index = 0; index < array.length; index++) { | ||||
|           const v = array[index]; | ||||
|           const values = v.split(":"); | ||||
|           for (let ind = 0; ind < values.length; ind++) { | ||||
|             if (values[ind].indexOf("+") !== -1) { | ||||
|               obj.push({ number: values[ind] }); | ||||
|             } | ||||
|             if (values[ind].indexOf("FN") !== -1) { | ||||
|               contact = values[ind + 1]; | ||||
|             } | ||||
|           } | ||||
|           for await (const ob of obj) { | ||||
|             const cont = await CreateContactService({ | ||||
|               name: contact, | ||||
|               number: ob.number.replace(/\D/g, "") | ||||
|             }); | ||||
|           } | ||||
|         } catch (error) { | ||||
|           console.log(error); | ||||
|         } | ||||
|         for await (const ob of obj) { | ||||
|           const cont = await CreateContactService({ | ||||
|             name: contact, | ||||
|             number: ob.number.replace(/\D/g, "") | ||||
|           }); | ||||
|         } | ||||
|       } catch (error) { | ||||
|         console.log(error); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     const botInfo = await BotIsOnQueue("botqueue"); | ||||
| 
 | ||||
|  |  | |||
|  | @ -126,10 +126,10 @@ const ContactModal = ({ open, onClose, contactId, initialValues, onSave }) => { | |||
| 				handleClose() | ||||
| 			} | ||||
| 			toast.success(i18n.t("contactModal.success"))   | ||||
| 			setSaving(false) | ||||
| 		} catch (err) { | ||||
| 			toastError(err) | ||||
| 		} | ||||
| 		setSaving(false) | ||||
| 	} | ||||
| 
 | ||||
| 	return ( | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue