mirror of
https://github.com/FranP-code/Baileys.git
synced 2025-10-13 00:32:22 +00:00
Merge pull request #1364 from WhiskeySockets/fix-receipt-meta-ia-messages
fix: proper send receipt to Meta Ia
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
import { Boom } from '@hapi/boom'
|
import { Boom } from '@hapi/boom'
|
||||||
import { proto } from '../../WAProto'
|
import { proto } from '../../WAProto'
|
||||||
import { SignalRepository, WAMessageKey } from '../Types'
|
import { SignalRepository, WAMessageKey } from '../Types'
|
||||||
import { areJidsSameUser, BinaryNode, isJidBroadcast, isJidGroup, isJidNewsletter, isJidStatusBroadcast, isJidUser, isLidUser } from '../WABinary'
|
import { areJidsSameUser, BinaryNode, isJidBroadcast, isJidGroup, isJidMetaIa, isJidNewsletter, isJidStatusBroadcast, isJidUser, isLidUser } from '../WABinary'
|
||||||
import { unpadRandomMax16 } from './generics'
|
import { unpadRandomMax16 } from './generics'
|
||||||
import { ILogger } from './logger'
|
import { ILogger } from './logger'
|
||||||
|
|
||||||
@@ -47,22 +47,9 @@ export function decodeMessageNode(
|
|||||||
const isMe = (jid: string) => areJidsSameUser(jid, meId)
|
const isMe = (jid: string) => areJidsSameUser(jid, meId)
|
||||||
const isMeLid = (jid: string) => areJidsSameUser(jid, meLid)
|
const isMeLid = (jid: string) => areJidsSameUser(jid, meLid)
|
||||||
|
|
||||||
if(isJidUser(from)) {
|
if(isJidUser(from) || isLidUser(from)) {
|
||||||
if(recipient) {
|
if(recipient && !isJidMetaIa(recipient)) {
|
||||||
if(!isMe(from)) {
|
if(!isMe(from) && !isMeLid(from)) {
|
||||||
throw new Boom('receipient present, but msg not from me', { data: stanza })
|
|
||||||
}
|
|
||||||
|
|
||||||
chatId = recipient
|
|
||||||
} else {
|
|
||||||
chatId = from
|
|
||||||
}
|
|
||||||
|
|
||||||
msgType = 'chat'
|
|
||||||
author = from
|
|
||||||
} else if(isLidUser(from)) {
|
|
||||||
if(recipient) {
|
|
||||||
if(!isMeLid(from)) {
|
|
||||||
throw new Boom('receipient present, but msg not from me', { data: stanza })
|
throw new Boom('receipient present, but msg not from me', { data: stanza })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ export const jidDecode = (jid: string | undefined): FullJid | undefined => {
|
|||||||
export const areJidsSameUser = (jid1: string | undefined, jid2: string | undefined) => (
|
export const areJidsSameUser = (jid1: string | undefined, jid2: string | undefined) => (
|
||||||
jidDecode(jid1)?.user === jidDecode(jid2)?.user
|
jidDecode(jid1)?.user === jidDecode(jid2)?.user
|
||||||
)
|
)
|
||||||
|
/** is the jid Meta IA */
|
||||||
|
export const isJidMetaIa = (jid: string | undefined) => (jid?.endsWith('@bot'))
|
||||||
/** is the jid a user */
|
/** is the jid a user */
|
||||||
export const isJidUser = (jid: string | undefined) => (jid?.endsWith('@s.whatsapp.net'))
|
export const isJidUser = (jid: string | undefined) => (jid?.endsWith('@s.whatsapp.net'))
|
||||||
/** is the jid a group */
|
/** is the jid a group */
|
||||||
|
|||||||
Reference in New Issue
Block a user