mirror of
https://github.com/FranP-code/Baileys.git
synced 2025-10-13 00:32:22 +00:00
feat: add bulk "process" capability to BaileysBufferableEventEmitter
This commit is contained in:
@@ -56,46 +56,80 @@ const startSock = async() => {
|
||||
await sock.sendMessage(jid, msg)
|
||||
}
|
||||
|
||||
sock.ev.on('call', item => console.log('recv call event', item))
|
||||
sock.ev.on('chats.set', item => console.log(`recv ${item.chats.length} chats (is latest: ${item.isLatest})`))
|
||||
sock.ev.on('messages.set', item => console.log(`recv ${item.messages.length} messages (is latest: ${item.isLatest})`))
|
||||
sock.ev.on('contacts.set', item => console.log(`recv ${item.contacts.length} contacts`))
|
||||
// the process function lets you process all events that just occurred
|
||||
// efficiently in a batch
|
||||
sock.ev.process(
|
||||
// events is a map for event name => event data
|
||||
async(events) => {
|
||||
if(events['connection.update']) {
|
||||
const update = events['connection.update']
|
||||
const { connection, lastDisconnect } = update
|
||||
if(connection === 'close') {
|
||||
// reconnect if not logged out
|
||||
if((lastDisconnect?.error as Boom)?.output?.statusCode !== DisconnectReason.loggedOut) {
|
||||
startSock()
|
||||
} else {
|
||||
console.log('Connection closed. You are logged out.')
|
||||
}
|
||||
}
|
||||
|
||||
sock.ev.on('messages.upsert', async m => {
|
||||
console.log(JSON.stringify(m, undefined, 2))
|
||||
console.log('connection update', update)
|
||||
}
|
||||
|
||||
const msg = m.messages[0]
|
||||
if(!msg.key.fromMe && m.type === 'notify' && doReplies) {
|
||||
console.log('replying to', m.messages[0].key.remoteJid)
|
||||
await sock!.sendReadReceipt(msg.key.remoteJid, msg.key.participant, [msg.key.id])
|
||||
await sendMessageWTyping({ text: 'Hello there!' }, msg.key.remoteJid)
|
||||
}
|
||||
if(events['creds.update']) {
|
||||
await saveCreds()
|
||||
}
|
||||
|
||||
})
|
||||
if(events.call) {
|
||||
console.log('recv call event', events.call)
|
||||
}
|
||||
|
||||
sock.ev.on('messages.update', m => console.log(m))
|
||||
sock.ev.on('message-receipt.update', m => console.log(m))
|
||||
sock.ev.on('messages.reaction', m => console.log(m))
|
||||
sock.ev.on('presence.update', m => console.log(m))
|
||||
sock.ev.on('chats.update', m => console.log(m))
|
||||
sock.ev.on('chats.delete', m => console.log(m))
|
||||
sock.ev.on('contacts.upsert', m => console.log(m))
|
||||
if(events['chats.set']) {
|
||||
const { chats, isLatest } = events['chats.set']
|
||||
console.log(`recv ${chats.length} chats (is latest: ${isLatest})`)
|
||||
}
|
||||
|
||||
sock.ev.on('connection.update', (update) => {
|
||||
const { connection, lastDisconnect } = update
|
||||
if(connection === 'close') {
|
||||
// reconnect if not logged out
|
||||
if((lastDisconnect.error as Boom)?.output?.statusCode !== DisconnectReason.loggedOut) {
|
||||
startSock()
|
||||
} else {
|
||||
console.log('Connection closed. You are logged out.')
|
||||
if(events['messages.set']) {
|
||||
const { messages, isLatest } = events['messages.set']
|
||||
console.log(`recv ${messages.length} messages (is latest: ${isLatest})`)
|
||||
}
|
||||
|
||||
if(events['contacts.set']) {
|
||||
const { contacts, isLatest } = events['contacts.set']
|
||||
console.log(`recv ${contacts.length} contacts (is latest: ${isLatest})`)
|
||||
}
|
||||
|
||||
if(events['messages.upsert'] && events['messages.upsert'].type === 'notify') {
|
||||
for(const msg of events['messages.upsert'].messages) {
|
||||
if(!msg.key.fromMe && doReplies) {
|
||||
console.log('replying to', msg.key.remoteJid)
|
||||
await sock!.sendReadReceipt(msg.key.remoteJid!, msg.key.participant!, [msg.key.id!])
|
||||
await sendMessageWTyping({ text: 'Hello there!' }, msg.key.remoteJid!)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if(events['messages.update']) {
|
||||
console.log(events['messages.update'])
|
||||
}
|
||||
|
||||
if(events['message-receipt.update']) {
|
||||
console.log(events['message-receipt.update'])
|
||||
}
|
||||
|
||||
if(events['messages.reaction']) {
|
||||
console.log(events['messages.reaction'])
|
||||
}
|
||||
|
||||
if(events['presence.update']) {
|
||||
console.log(events['presence.update'])
|
||||
}
|
||||
|
||||
if(events['chats.update']) {
|
||||
console.log(events['chats.update'])
|
||||
}
|
||||
}
|
||||
|
||||
console.log('connection update', update)
|
||||
})
|
||||
// listen for when the auth credentials is updated
|
||||
sock.ev.on('creds.update', saveCreds)
|
||||
)
|
||||
|
||||
return sock
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user