mirror of
https://github.com/cheveguerra/bot-whatsapp.git
synced 2026-04-20 20:49:15 +00:00
Compare commits
1 Commits
fix/bailey
...
fix/venom
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
041bf6280e |
@@ -17,7 +17,6 @@
|
|||||||
"./mock": "./lib/mock/index.cjs",
|
"./mock": "./lib/mock/index.cjs",
|
||||||
"./twilio": "./lib/twilio/index.cjs",
|
"./twilio": "./lib/twilio/index.cjs",
|
||||||
"./web-whatsapp": "./lib/web-whatsapp/index.cjs",
|
"./web-whatsapp": "./lib/web-whatsapp/index.cjs",
|
||||||
"./venom": "./lib/venom/index.cjs",
|
"./venom": "./lib/venom/index.cjs"
|
||||||
"./baileys": "./lib/baileys/index.cjs"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,13 +39,4 @@ module.exports = [
|
|||||||
},
|
},
|
||||||
plugins: [commonjs()],
|
plugins: [commonjs()],
|
||||||
},
|
},
|
||||||
{
|
|
||||||
input: join(__dirname, 'src', 'baileys', 'index.js'),
|
|
||||||
output: {
|
|
||||||
banner: banner['banner.output'].join(''),
|
|
||||||
file: join(__dirname, 'lib', 'baileys', 'index.cjs'),
|
|
||||||
format: 'cjs',
|
|
||||||
},
|
|
||||||
plugins: [commonjs()],
|
|
||||||
},
|
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -1,171 +0,0 @@
|
|||||||
const { ProviderClass } = require('@bot-whatsapp/bot')
|
|
||||||
const pino = require('pino')
|
|
||||||
const {
|
|
||||||
default: makeWASocket,
|
|
||||||
useMultiFileAuthState,
|
|
||||||
} = require('@adiwajshing/baileys')
|
|
||||||
const {
|
|
||||||
baileyGenerateImage,
|
|
||||||
baileyCleanNumber,
|
|
||||||
baileyIsValidNumber,
|
|
||||||
} = require('./utils')
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ⚙️ BaileysProvider: Es una clase tipo adaptor
|
|
||||||
* que extiende clases de ProviderClass (la cual es como interfaz para sber que funciones rqueridas)
|
|
||||||
* https://github.com/adiwajshing/Baileys
|
|
||||||
*/
|
|
||||||
class BaileysProvider extends ProviderClass {
|
|
||||||
vendor
|
|
||||||
constructor() {
|
|
||||||
super()
|
|
||||||
this.initBailey().then(() => this.initBusEvents())
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iniciar todo Bailey
|
|
||||||
*/
|
|
||||||
async initBailey() {
|
|
||||||
const { state, saveCreds } = await useMultiFileAuthState('sessions')
|
|
||||||
|
|
||||||
try {
|
|
||||||
this.vendor = makeWASocket({
|
|
||||||
printQRInTerminal: false,
|
|
||||||
auth: state,
|
|
||||||
logger: pino({ level: 'error' }),
|
|
||||||
})
|
|
||||||
|
|
||||||
this.vendor.ev.on(
|
|
||||||
'connection.update',
|
|
||||||
async ({ qr, connection, lastDisconnect }) => {
|
|
||||||
if (qr) baileyGenerateImage(qr)
|
|
||||||
if (connection === 'open') this.emit('ready', true)
|
|
||||||
if (lastDisconnect?.error) {
|
|
||||||
saveCreds()
|
|
||||||
this.initBailey()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
} catch (e) {
|
|
||||||
this.emit('error', e)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Mapeamos los eventos nativos a los que la clase Provider espera
|
|
||||||
* para tener un standar de eventos
|
|
||||||
* @returns
|
|
||||||
*/
|
|
||||||
busEvents = () => [
|
|
||||||
{
|
|
||||||
event: 'connection.update',
|
|
||||||
func: async ({ qr, connection, lastDisconnect }) => {
|
|
||||||
if (qr) {
|
|
||||||
this.emit('require_action', {
|
|
||||||
instructions: [
|
|
||||||
`Debes escanear el QR Code para iniciar session reivsa qr.png`,
|
|
||||||
`Recuerda que el QR se actualiza cada minuto `,
|
|
||||||
`Necesitas ayuda: https://link.codigoencasa.com/DISCORD`,
|
|
||||||
],
|
|
||||||
})
|
|
||||||
baileyGenerateImage(qr)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lastDisconnect?.error) {
|
|
||||||
this.emit('require_action', {
|
|
||||||
instructions: [
|
|
||||||
`Algo sucedio reinicia el bot o revisa tu whatsapp`,
|
|
||||||
`Necesitas ayuda: https://link.codigoencasa.com/DISCORD`,
|
|
||||||
],
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if (connection === 'open') this.emit('ready', true)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
event: 'messages.upsert',
|
|
||||||
func: ({ messages }) => {
|
|
||||||
const [messageCtx] = messages
|
|
||||||
let payload = {
|
|
||||||
...messageCtx,
|
|
||||||
body: messageCtx?.message?.conversation,
|
|
||||||
from: messageCtx?.key?.remoteJid,
|
|
||||||
}
|
|
||||||
if (payload.from === 'status@broadcast') {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!baileyIsValidNumber(payload.from)) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
payload.from = baileyCleanNumber(payload.from, true)
|
|
||||||
this.emit('message', payload)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
]
|
|
||||||
|
|
||||||
initBusEvents = () => {
|
|
||||||
const listEvents = this.busEvents()
|
|
||||||
|
|
||||||
for (const { event, func } of listEvents) {
|
|
||||||
this.vendor.ev.on(event, func)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @alpha
|
|
||||||
* @param {string} number
|
|
||||||
* @param {string} message
|
|
||||||
* @example await sendMessage('+XXXXXXXXXXX', 'https://dominio.com/imagen.jpg' | 'img/imagen.jpg')
|
|
||||||
*/
|
|
||||||
|
|
||||||
sendMedia = async (number, imageUrl) => {
|
|
||||||
await this.vendor.sendMessage(number, {
|
|
||||||
image: { url: imageUrl },
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @alpha
|
|
||||||
* @param {string} number
|
|
||||||
* @param {string} message
|
|
||||||
* @param {boolean} voiceNote optional
|
|
||||||
* @example await sendMessage('+XXXXXXXXXXX', 'audio.mp3')
|
|
||||||
*/
|
|
||||||
|
|
||||||
sendAudio = async (number, audioUrl, voiceNote = false) => {
|
|
||||||
const numberClean = number.replace('+', '')
|
|
||||||
await this.vendor.sendMessage(`${numberClean}@c.us`, {
|
|
||||||
audio: { url: audioUrl },
|
|
||||||
ptt: voiceNote,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {string} number
|
|
||||||
* @param {string} message
|
|
||||||
* @returns
|
|
||||||
*/
|
|
||||||
sendText = async (number, message) => {
|
|
||||||
return this.vendor.sendMessage(number, { text: message })
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* TODO: Necesita terminar de implementar el sendMedia y sendButton guiarse:
|
|
||||||
* https://github.com/leifermendez/bot-whatsapp/blob/4e0fcbd8347f8a430adb43351b5415098a5d10df/packages/provider/src/web-whatsapp/index.js#L165
|
|
||||||
* @param {string} number
|
|
||||||
* @param {string} message
|
|
||||||
* @example await sendMessage('+XXXXXXXXXXX', 'Hello World')
|
|
||||||
*/
|
|
||||||
sendMessage = async (numberIn, message, { options }) => {
|
|
||||||
const number = baileyCleanNumber(numberIn)
|
|
||||||
|
|
||||||
// if (options?.buttons?.length)
|
|
||||||
// return this.sendButtons(number, message, options.buttons)
|
|
||||||
if (options?.media) return this.sendMedia(number, options.media)
|
|
||||||
return this.sendText(number, message)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = BaileysProvider
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
const { createWriteStream } = require('fs')
|
|
||||||
const qr = require('qr-image')
|
|
||||||
|
|
||||||
const baileyCleanNumber = (number, full = false) => {
|
|
||||||
number = number.replace('@s.whatsapp.net', '')
|
|
||||||
number = !full ? `${number}@s.whatsapp.net` : `${number}`
|
|
||||||
return number
|
|
||||||
}
|
|
||||||
|
|
||||||
const baileyGenerateImage = (base64) => {
|
|
||||||
let qr_svg = qr.image(base64, { type: 'png', margin: 4 })
|
|
||||||
qr_svg.pipe(createWriteStream(`${process.cwd()}/qr.png`))
|
|
||||||
}
|
|
||||||
|
|
||||||
const baileyIsValidNumber = (rawNumber) => {
|
|
||||||
const regexGroup = /\@g.us\b/gm
|
|
||||||
const exist = rawNumber.match(regexGroup)
|
|
||||||
return !exist
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = { baileyCleanNumber, baileyGenerateImage, baileyIsValidNumber }
|
|
||||||
@@ -4,7 +4,7 @@ const {
|
|||||||
venomCleanNumber,
|
venomCleanNumber,
|
||||||
venomGenerateImage,
|
venomGenerateImage,
|
||||||
venomisValidNumber,
|
venomisValidNumber,
|
||||||
} = require('./utils')
|
} = require('./utils/utils')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ⚙️ VenomProvider: Es una clase tipo adaptor
|
* ⚙️ VenomProvider: Es una clase tipo adaptor
|
||||||
@@ -13,6 +13,7 @@ const {
|
|||||||
*/
|
*/
|
||||||
class VenomProvider extends ProviderClass {
|
class VenomProvider extends ProviderClass {
|
||||||
vendor
|
vendor
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super()
|
super()
|
||||||
this.init().then(() => this.initBusEvents())
|
this.init().then(() => this.initBusEvents())
|
||||||
|
|||||||
@@ -3,10 +3,10 @@ const { ProviderClass } = require('@bot-whatsapp/bot')
|
|||||||
const { Console } = require('console')
|
const { Console } = require('console')
|
||||||
const { createWriteStream } = require('fs')
|
const { createWriteStream } = require('fs')
|
||||||
const {
|
const {
|
||||||
wwebCleanNumber,
|
cleanNumber,
|
||||||
wwebDownloadMedia,
|
generateImage,
|
||||||
wwebGenerateImage,
|
isValidNumber,
|
||||||
wwebIsValidNumber,
|
downloadMedia,
|
||||||
} = require('./utils')
|
} = require('./utils')
|
||||||
|
|
||||||
const logger = new Console({
|
const logger = new Console({
|
||||||
@@ -65,7 +65,7 @@ class WebWhatsappProvider extends ProviderClass {
|
|||||||
`Necesitas ayuda: https://link.codigoencasa.com/DISCORD`,
|
`Necesitas ayuda: https://link.codigoencasa.com/DISCORD`,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
wwebGenerateImage(qr)
|
generateImage(qr)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -79,10 +79,10 @@ class WebWhatsappProvider extends ProviderClass {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!wwebIsValidNumber(payload.from)) {
|
if (!isValidNumber(payload.from)) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
payload.from = wwebCleanNumber(payload.from, true)
|
payload.from = cleanNumber(payload.from, true)
|
||||||
this.emit('message', payload)
|
this.emit('message', payload)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@@ -98,7 +98,7 @@ class WebWhatsappProvider extends ProviderClass {
|
|||||||
*/
|
*/
|
||||||
sendMedia = async (number, mediaInput = null) => {
|
sendMedia = async (number, mediaInput = null) => {
|
||||||
if (!mediaInput) throw new Error(`NO_SE_ENCONTRO: ${mediaInput}`)
|
if (!mediaInput) throw new Error(`NO_SE_ENCONTRO: ${mediaInput}`)
|
||||||
const fileDownloaded = await wwebDownloadMedia(mediaInput)
|
const fileDownloaded = await downloadMedia(mediaInput)
|
||||||
const media = MessageMedia.fromFilePath(fileDownloaded)
|
const media = MessageMedia.fromFilePath(fileDownloaded)
|
||||||
return this.vendor.sendMessage(number, media, {
|
return this.vendor.sendMessage(number, media, {
|
||||||
sendAudioAsVoice: true,
|
sendAudioAsVoice: true,
|
||||||
@@ -163,7 +163,7 @@ class WebWhatsappProvider extends ProviderClass {
|
|||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
sendMessage = async (userId, message, { options }) => {
|
sendMessage = async (userId, message, { options }) => {
|
||||||
const number = wwebCleanNumber(userId)
|
const number = cleanNumber(userId)
|
||||||
if (options?.buttons?.length)
|
if (options?.buttons?.length)
|
||||||
return this.sendButtons(number, message, options.buttons)
|
return this.sendButtons(number, message, options.buttons)
|
||||||
if (options?.media) return this.sendMedia(number, options.media)
|
if (options?.media) return this.sendMedia(number, options.media)
|
||||||
|
|||||||
@@ -4,18 +4,18 @@ const { tmpdir } = require('os')
|
|||||||
const http = require('http')
|
const http = require('http')
|
||||||
const https = require('https')
|
const https = require('https')
|
||||||
|
|
||||||
const wwebCleanNumber = (number, full = false) => {
|
const cleanNumber = (number, full = false) => {
|
||||||
number = number.replace('@c.us', '')
|
number = number.replace('@c.us', '')
|
||||||
number = !full ? `${number}@c.us` : `${number}`
|
number = !full ? `${number}@c.us` : `${number}`
|
||||||
return number
|
return number
|
||||||
}
|
}
|
||||||
|
|
||||||
const wwebGenerateImage = (base64) => {
|
const generateImage = (base64) => {
|
||||||
let qr_svg = qr.image(base64, { type: 'png', margin: 4 })
|
let qr_svg = qr.image(base64, { type: 'png', margin: 4 })
|
||||||
qr_svg.pipe(createWriteStream(`${process.cwd()}/qr.png`))
|
qr_svg.pipe(createWriteStream(`${process.cwd()}/qr.svg`))
|
||||||
}
|
}
|
||||||
|
|
||||||
const wwebIsValidNumber = (rawNumber) => {
|
const isValidNumber = (rawNumber) => {
|
||||||
const regexGroup = /\@g.us\b/gm
|
const regexGroup = /\@g.us\b/gm
|
||||||
const exist = rawNumber.match(regexGroup)
|
const exist = rawNumber.match(regexGroup)
|
||||||
return !exist
|
return !exist
|
||||||
@@ -27,7 +27,7 @@ const wwebIsValidNumber = (rawNumber) => {
|
|||||||
* @param {*} url
|
* @param {*} url
|
||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
const wwebDownloadMedia = (url) => {
|
const downloadMedia = (url) => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
const ext = url.split('.').pop()
|
const ext = url.split('.').pop()
|
||||||
const checkProtocol = url.includes('https:')
|
const checkProtocol = url.includes('https:')
|
||||||
@@ -50,9 +50,4 @@ const wwebDownloadMedia = (url) => {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = { cleanNumber, generateImage, isValidNumber, downloadMedia }
|
||||||
wwebCleanNumber,
|
|
||||||
wwebGenerateImage,
|
|
||||||
wwebIsValidNumber,
|
|
||||||
wwebDownloadMedia,
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user