gifted-baileys 1.5.0 → 1.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +1429 -684
- package/package.json +11 -26
- package/src/Defaults/baileys-version.json +3 -0
- package/{lib → src}/Defaults/index.js +16 -8
- package/src/Defaults/index.ts +131 -0
- package/src/Defaults/phonenumber-mcc.json +223 -0
- package/src/Signal/libsignal.js +180 -0
- package/src/Signal/libsignal.ts +141 -0
- package/src/Socket/Client/abstract-socket-client.ts +19 -0
- package/src/Socket/Client/index.ts +3 -0
- package/src/Socket/Client/mobile-socket-client.js +78 -0
- package/src/Socket/Client/mobile-socket-client.ts +66 -0
- package/src/Socket/Client/web-socket-client.js +75 -0
- package/src/Socket/Client/web-socket-client.ts +57 -0
- package/{lib → src}/Socket/business.js +33 -27
- package/src/Socket/business.ts +281 -0
- package/{lib → src}/Socket/chats.js +197 -178
- package/src/Socket/chats.ts +1030 -0
- package/{lib → src}/Socket/groups.js +69 -79
- package/src/Socket/groups.ts +356 -0
- package/{lib → src}/Socket/index.js +1 -4
- package/src/Socket/index.ts +13 -0
- package/{lib → src}/Socket/messages-recv.js +160 -108
- package/src/Socket/messages-recv.ts +985 -0
- package/{lib → src}/Socket/messages-send.js +183 -100
- package/src/Socket/messages-send.ts +871 -0
- package/src/Socket/newsletter.js +227 -0
- package/src/Socket/newsletter.ts +282 -0
- package/{lib → src}/Socket/registration.js +55 -63
- package/src/Socket/registration.ts +250 -0
- package/{lib → src}/Socket/socket.js +107 -66
- package/src/Socket/socket.ts +777 -0
- package/src/Store/index.ts +3 -0
- package/{lib → src}/Store/make-cache-manager-store.js +34 -25
- package/src/Store/make-cache-manager-store.ts +100 -0
- package/{lib → src}/Store/make-in-memory-store.js +51 -61
- package/src/Store/make-in-memory-store.ts +475 -0
- package/src/Store/make-ordered-dictionary.ts +86 -0
- package/{lib → src}/Store/object-repository.js +1 -1
- package/src/Store/object-repository.ts +32 -0
- package/src/Tests/test.app-state-sync.js +204 -0
- package/src/Tests/test.app-state-sync.ts +207 -0
- package/src/Tests/test.event-buffer.js +270 -0
- package/src/Tests/test.event-buffer.ts +319 -0
- package/src/Tests/test.key-store.js +76 -0
- package/src/Tests/test.key-store.ts +92 -0
- package/src/Tests/test.libsignal.js +141 -0
- package/src/Tests/test.libsignal.ts +186 -0
- package/src/Tests/test.media-download.js +93 -0
- package/src/Tests/test.media-download.ts +76 -0
- package/src/Tests/test.messages.js +33 -0
- package/src/Tests/test.messages.ts +37 -0
- package/src/Tests/utils.js +34 -0
- package/src/Tests/utils.ts +36 -0
- package/src/Types/Auth.ts +113 -0
- package/src/Types/Call.ts +15 -0
- package/src/Types/Chat.ts +106 -0
- package/{lib/Types/Contact.d.ts → src/Types/Contact.ts} +9 -8
- package/src/Types/Events.ts +93 -0
- package/src/Types/GroupMetadata.ts +53 -0
- package/{lib → src}/Types/Label.js +1 -1
- package/src/Types/Label.ts +36 -0
- package/{lib → src}/Types/LabelAssociation.js +1 -1
- package/{lib/Types/LabelAssociation.d.ts → src/Types/LabelAssociation.ts} +22 -16
- package/src/Types/Message.ts +288 -0
- package/src/Types/Newsletter.js +32 -0
- package/src/Types/Newsletter.ts +98 -0
- package/src/Types/Product.ts +85 -0
- package/src/Types/Signal.ts +68 -0
- package/{lib/Types/Socket.d.ts → src/Types/Socket.ts} +68 -56
- package/src/Types/State.ts +29 -0
- package/{lib → src}/Types/index.js +2 -1
- package/src/Types/index.ts +59 -0
- package/{lib → src}/Utils/auth-utils.js +95 -76
- package/src/Utils/auth-utils.ts +222 -0
- package/src/Utils/baileys-event-stream.js +92 -0
- package/src/Utils/baileys-event-stream.ts +66 -0
- package/{lib → src}/Utils/business.js +45 -17
- package/src/Utils/business.ts +275 -0
- package/{lib → src}/Utils/chat-utils.js +74 -46
- package/src/Utils/chat-utils.ts +860 -0
- package/{lib → src}/Utils/crypto.js +31 -21
- package/src/Utils/crypto.ts +131 -0
- package/src/Utils/decode-wa-message.js +211 -0
- package/src/Utils/decode-wa-message.ts +228 -0
- package/{lib → src}/Utils/event-buffer.js +13 -4
- package/src/Utils/event-buffer.ts +613 -0
- package/{lib → src}/Utils/generics.js +98 -45
- package/src/Utils/generics.ts +434 -0
- package/{lib → src}/Utils/history.js +39 -10
- package/src/Utils/history.ts +112 -0
- package/src/Utils/index.ts +17 -0
- package/{lib → src}/Utils/link-preview.js +54 -17
- package/src/Utils/link-preview.ts +122 -0
- package/src/Utils/logger.ts +3 -0
- package/src/Utils/lt-hash.ts +61 -0
- package/{lib → src}/Utils/make-mutex.js +13 -4
- package/src/Utils/make-mutex.ts +44 -0
- package/{lib → src}/Utils/messages-media.js +296 -192
- package/src/Utils/messages-media.ts +847 -0
- package/{lib → src}/Utils/messages.js +124 -113
- package/src/Utils/messages.ts +956 -0
- package/{lib → src}/Utils/noise-handler.js +16 -3
- package/src/Utils/noise-handler.ts +197 -0
- package/{lib → src}/Utils/process-message.js +33 -29
- package/src/Utils/process-message.ts +414 -0
- package/{lib → src}/Utils/signal.js +23 -14
- package/src/Utils/signal.ts +177 -0
- package/{lib → src}/Utils/use-multi-file-auth-state.js +28 -19
- package/src/Utils/use-multi-file-auth-state.ts +90 -0
- package/{lib → src}/Utils/validate-connection.js +25 -42
- package/src/Utils/validate-connection.ts +238 -0
- package/src/WABinary/constants.ts +42 -0
- package/{lib → src}/WABinary/decode.js +17 -7
- package/src/WABinary/decode.ts +265 -0
- package/{lib → src}/WABinary/encode.js +17 -7
- package/src/WABinary/encode.ts +236 -0
- package/{lib → src}/WABinary/generic-utils.js +2 -2
- package/src/WABinary/generic-utils.ts +121 -0
- package/src/WABinary/index.ts +5 -0
- package/{lib → src}/WABinary/jid-utils.js +4 -1
- package/src/WABinary/jid-utils.ts +68 -0
- package/src/WABinary/types.ts +17 -0
- package/src/WAM/BinaryInfo.js +13 -0
- package/src/WAM/BinaryInfo.ts +12 -0
- package/src/WAM/constants.js +15350 -0
- package/src/WAM/constants.ts +15382 -0
- package/src/WAM/encode.js +155 -0
- package/src/WAM/encode.ts +174 -0
- package/src/WAM/index.js +19 -0
- package/src/WAM/index.ts +3 -0
- package/src/gifted +1 -0
- package/{lib → src}/index.js +1 -0
- package/src/index.ts +13 -0
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -284
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Signal/libsignal.js +0 -152
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
- package/lib/Socket/Client/index.d.ts +0 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.d.ts +0 -12
- package/lib/Socket/Client/web-socket-client.js +0 -62
- package/lib/Socket/business.d.ts +0 -135
- package/lib/Socket/chats.d.ts +0 -79
- package/lib/Socket/groups.d.ts +0 -113
- package/lib/Socket/index.d.ts +0 -137
- package/lib/Socket/messages-recv.d.ts +0 -124
- package/lib/Socket/messages-send.d.ts +0 -119
- package/lib/Socket/registration.d.ts +0 -232
- package/lib/Socket/socket.d.ts +0 -42
- package/lib/Store/index.d.ts +0 -3
- package/lib/Store/make-cache-manager-store.d.ts +0 -13
- package/lib/Store/make-in-memory-store.d.ts +0 -117
- package/lib/Store/make-ordered-dictionary.d.ts +0 -13
- package/lib/Store/object-repository.d.ts +0 -10
- package/lib/Types/Auth.d.ts +0 -108
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -102
- package/lib/Types/Events.d.ts +0 -157
- package/lib/Types/GroupMetadata.d.ts +0 -52
- package/lib/Types/Label.d.ts +0 -35
- package/lib/Types/Message.d.ts +0 -261
- package/lib/Types/Product.d.ts +0 -78
- package/lib/Types/Signal.d.ts +0 -57
- package/lib/Types/State.d.ts +0 -27
- package/lib/Types/index.d.ts +0 -56
- package/lib/Utils/auth-utils.d.ts +0 -18
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/baileys-event-stream.js +0 -63
- package/lib/Utils/business.d.ts +0 -22
- package/lib/Utils/chat-utils.d.ts +0 -71
- package/lib/Utils/crypto.d.ts +0 -41
- package/lib/Utils/decode-wa-message.d.ts +0 -19
- package/lib/Utils/decode-wa-message.js +0 -174
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -94
- package/lib/Utils/history.d.ts +0 -15
- package/lib/Utils/index.d.ts +0 -17
- package/lib/Utils/link-preview.d.ts +0 -21
- package/lib/Utils/logger.d.ts +0 -4
- package/lib/Utils/lt-hash.d.ts +0 -12
- package/lib/Utils/make-mutex.d.ts +0 -7
- package/lib/Utils/messages-media.d.ts +0 -107
- package/lib/Utils/messages.d.ts +0 -76
- package/lib/Utils/noise-handler.d.ts +0 -20
- package/lib/Utils/process-message.d.ts +0 -41
- package/lib/Utils/signal.d.ts +0 -32
- package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
- package/lib/Utils/validate-connection.d.ts +0 -11
- package/lib/WABinary/constants.d.ts +0 -27
- package/lib/WABinary/decode.d.ts +0 -7
- package/lib/WABinary/encode.d.ts +0 -3
- package/lib/WABinary/generic-utils.d.ts +0 -15
- package/lib/WABinary/index.d.ts +0 -5
- package/lib/WABinary/jid-utils.d.ts +0 -29
- package/lib/WABinary/types.d.ts +0 -18
- package/lib/index.d.ts +0 -10
- /package/{lib → src}/Socket/Client/abstract-socket-client.js +0 -0
- /package/{lib → src}/Socket/Client/index.js +0 -0
- /package/{lib → src}/Store/index.js +0 -0
- /package/{lib → src}/Store/make-ordered-dictionary.js +0 -0
- /package/{lib → src}/Types/Auth.js +0 -0
- /package/{lib → src}/Types/Call.js +0 -0
- /package/{lib → src}/Types/Chat.js +0 -0
- /package/{lib → src}/Types/Contact.js +0 -0
- /package/{lib → src}/Types/Events.js +0 -0
- /package/{lib → src}/Types/GroupMetadata.js +0 -0
- /package/{lib → src}/Types/Message.js +0 -0
- /package/{lib → src}/Types/Product.js +0 -0
- /package/{lib → src}/Types/Signal.js +0 -0
- /package/{lib → src}/Types/Socket.js +0 -0
- /package/{lib → src}/Types/State.js +0 -0
- /package/{lib → src}/Utils/index.js +0 -0
- /package/{lib → src}/Utils/logger.js +0 -0
- /package/{lib → src}/Utils/lt-hash.js +0 -0
- /package/{lib → src}/WABinary/constants.js +0 -0
- /package/{lib → src}/WABinary/index.js +0 -0
- /package/{lib → src}/WABinary/types.js +0 -0
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.getBinaryNodeMessages = exports.reduceBinaryNodeToDictionary = exports.assertNodeErrorFree = exports.getBinaryNodeChildUInt = exports.getBinaryNodeChildString = exports.getBinaryNodeChildBuffer = exports.getBinaryNodeChild = exports.getAllBinaryNodeChildren = exports.getBinaryNodeChildren = void 0;
|
|
4
|
+
exports.binaryNodeToString = binaryNodeToString;
|
|
4
5
|
const boom_1 = require("@hapi/boom");
|
|
5
6
|
const WAProto_1 = require("../../WAProto");
|
|
6
7
|
// some extra useful utilities
|
|
@@ -107,4 +108,3 @@ function binaryNodeToString(node, i = 0) {
|
|
|
107
108
|
const content = children ? `>\n${children}\n${tabs(i)}</${node.tag}>` : '/>';
|
|
108
109
|
return tag + content;
|
|
109
110
|
}
|
|
110
|
-
exports.binaryNodeToString = binaryNodeToString;
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { Boom } from '@hapi/boom'
|
|
2
|
+
import { proto } from '../../WAProto'
|
|
3
|
+
import { BinaryNode } from './types'
|
|
4
|
+
|
|
5
|
+
// some extra useful utilities
|
|
6
|
+
|
|
7
|
+
export const getBinaryNodeChildren = (node: BinaryNode | undefined, childTag: string) => {
|
|
8
|
+
if(Array.isArray(node?.content)) {
|
|
9
|
+
return node!.content.filter(item => item.tag === childTag)
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
return []
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export const getAllBinaryNodeChildren = ({ content }: BinaryNode) => {
|
|
16
|
+
if(Array.isArray(content)) {
|
|
17
|
+
return content
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
return []
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export const getBinaryNodeChild = (node: BinaryNode | undefined, childTag: string) => {
|
|
24
|
+
if(Array.isArray(node?.content)) {
|
|
25
|
+
return node?.content.find(item => item.tag === childTag)
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export const getBinaryNodeChildBuffer = (node: BinaryNode | undefined, childTag: string) => {
|
|
30
|
+
const child = getBinaryNodeChild(node, childTag)?.content
|
|
31
|
+
if(Buffer.isBuffer(child) || child instanceof Uint8Array) {
|
|
32
|
+
return child
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export const getBinaryNodeChildString = (node: BinaryNode | undefined, childTag: string) => {
|
|
37
|
+
const child = getBinaryNodeChild(node, childTag)?.content
|
|
38
|
+
if(Buffer.isBuffer(child) || child instanceof Uint8Array) {
|
|
39
|
+
return Buffer.from(child).toString('utf-8')
|
|
40
|
+
} else if(typeof child === 'string') {
|
|
41
|
+
return child
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export const getBinaryNodeChildUInt = (node: BinaryNode, childTag: string, length: number) => {
|
|
46
|
+
const buff = getBinaryNodeChildBuffer(node, childTag)
|
|
47
|
+
if(buff) {
|
|
48
|
+
return bufferToUInt(buff, length)
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export const assertNodeErrorFree = (node: BinaryNode) => {
|
|
53
|
+
const errNode = getBinaryNodeChild(node, 'error')
|
|
54
|
+
if(errNode) {
|
|
55
|
+
throw new Boom(errNode.attrs.text || 'Unknown error', { data: +errNode.attrs.code })
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export const reduceBinaryNodeToDictionary = (node: BinaryNode, tag: string) => {
|
|
60
|
+
const nodes = getBinaryNodeChildren(node, tag)
|
|
61
|
+
const dict = nodes.reduce(
|
|
62
|
+
(dict, { attrs }) => {
|
|
63
|
+
dict[attrs.name || attrs.config_code] = attrs.value || attrs.config_value
|
|
64
|
+
return dict
|
|
65
|
+
}, { } as { [_: string]: string }
|
|
66
|
+
)
|
|
67
|
+
return dict
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export const getBinaryNodeMessages = ({ content }: BinaryNode) => {
|
|
71
|
+
const msgs: proto.WebMessageInfo[] = []
|
|
72
|
+
if(Array.isArray(content)) {
|
|
73
|
+
for(const item of content) {
|
|
74
|
+
if(item.tag === 'message') {
|
|
75
|
+
msgs.push(proto.WebMessageInfo.decode(item.content as Buffer))
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
return msgs
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
function bufferToUInt(e: Uint8Array | Buffer, t: number) {
|
|
84
|
+
let a = 0
|
|
85
|
+
for(let i = 0; i < t; i++) {
|
|
86
|
+
a = 256 * a + e[i]
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
return a
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
const tabs = (n: number) => '\t'.repeat(n)
|
|
93
|
+
|
|
94
|
+
export function binaryNodeToString(node: BinaryNode | BinaryNode['content'], i = 0) {
|
|
95
|
+
if(!node) {
|
|
96
|
+
return node
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
if(typeof node === 'string') {
|
|
100
|
+
return tabs(i) + node
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
if(node instanceof Uint8Array) {
|
|
104
|
+
return tabs(i) + Buffer.from(node).toString('hex')
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if(Array.isArray(node)) {
|
|
108
|
+
return node.map((x) => tabs(i + 1) + binaryNodeToString(x, i + 1)).join('\n')
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
const children = binaryNodeToString(node.content, i + 1)
|
|
112
|
+
|
|
113
|
+
const tag = `<${node.tag} ${Object.entries(node.attrs || {})
|
|
114
|
+
.filter(([, v]) => v !== undefined)
|
|
115
|
+
.map(([k, v]) => `${k}='${v}'`)
|
|
116
|
+
.join(' ')}`
|
|
117
|
+
|
|
118
|
+
const content: string = children ? `>\n${children}\n${tabs(i)}</${node.tag}>` : '/>'
|
|
119
|
+
|
|
120
|
+
return tag + content
|
|
121
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.jidNormalizedUser = exports.isJidStatusBroadcast = exports.isJidGroup = exports.isJidBroadcast = exports.isLidUser = exports.isJidUser = exports.areJidsSameUser = exports.jidDecode = exports.jidEncode = exports.STORIES_JID = exports.PSA_WID = exports.SERVER_JID = exports.OFFICIAL_BIZ_JID = exports.S_WHATSAPP_NET = void 0;
|
|
3
|
+
exports.jidNormalizedUser = exports.isJidNewsLetter = exports.isJidStatusBroadcast = exports.isJidGroup = exports.isJidBroadcast = exports.isLidUser = exports.isJidUser = exports.areJidsSameUser = exports.jidDecode = exports.jidEncode = exports.STORIES_JID = exports.PSA_WID = exports.SERVER_JID = exports.OFFICIAL_BIZ_JID = exports.S_WHATSAPP_NET = void 0;
|
|
4
4
|
exports.S_WHATSAPP_NET = '@s.whatsapp.net';
|
|
5
5
|
exports.OFFICIAL_BIZ_JID = '16505361212@c.us';
|
|
6
6
|
exports.SERVER_JID = 'server@c.us';
|
|
@@ -48,6 +48,9 @@ exports.isJidGroup = isJidGroup;
|
|
|
48
48
|
/** is the jid the status broadcast */
|
|
49
49
|
const isJidStatusBroadcast = (jid) => jid === 'status@broadcast';
|
|
50
50
|
exports.isJidStatusBroadcast = isJidStatusBroadcast;
|
|
51
|
+
/** is the jid the newsletter */
|
|
52
|
+
const isJidNewsLetter = (jid) => (jid === null || jid === void 0 ? void 0 : jid.endsWith('newsletter'));
|
|
53
|
+
exports.isJidNewsLetter = isJidNewsLetter;
|
|
51
54
|
const jidNormalizedUser = (jid) => {
|
|
52
55
|
const result = (0, exports.jidDecode)(jid);
|
|
53
56
|
if (!result) {
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
export const S_WHATSAPP_NET = '@s.whatsapp.net'
|
|
2
|
+
export const OFFICIAL_BIZ_JID = '16505361212@c.us'
|
|
3
|
+
export const SERVER_JID = 'server@c.us'
|
|
4
|
+
export const PSA_WID = '0@c.us'
|
|
5
|
+
export const STORIES_JID = 'status@broadcast'
|
|
6
|
+
|
|
7
|
+
export type JidServer = 'c.us' | 'g.us' | 'broadcast' | 's.whatsapp.net' | 'call' | 'lid' | 'newsletter'
|
|
8
|
+
|
|
9
|
+
export type JidWithDevice = {
|
|
10
|
+
user: string
|
|
11
|
+
device?: number
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type FullJid = JidWithDevice & {
|
|
15
|
+
server: JidServer | string
|
|
16
|
+
domainType?: number
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export const jidEncode = (user: string | number | null, server: JidServer, device?: number, agent?: number) => {
|
|
20
|
+
return `${user || ''}${!!agent ? `_${agent}` : ''}${!!device ? `:${device}` : ''}@${server}`
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export const jidDecode = (jid: string | undefined): FullJid | undefined => {
|
|
24
|
+
const sepIdx = typeof jid === 'string' ? jid.indexOf('@') : -1
|
|
25
|
+
if(sepIdx < 0) {
|
|
26
|
+
return undefined
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const server = jid!.slice(sepIdx + 1)
|
|
30
|
+
const userCombined = jid!.slice(0, sepIdx)
|
|
31
|
+
|
|
32
|
+
const [userAgent, device] = userCombined.split(':')
|
|
33
|
+
const user = userAgent.split('_')[0]
|
|
34
|
+
|
|
35
|
+
return {
|
|
36
|
+
server,
|
|
37
|
+
user,
|
|
38
|
+
domainType: server === 'lid' ? 1 : 0,
|
|
39
|
+
device: device ? +device : undefined
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/** is the jid a user */
|
|
44
|
+
export const areJidsSameUser = (jid1: string | undefined, jid2: string | undefined) => (
|
|
45
|
+
jidDecode(jid1)?.user === jidDecode(jid2)?.user
|
|
46
|
+
)
|
|
47
|
+
/** is the jid a user */
|
|
48
|
+
export const isJidUser = (jid: string | undefined) => (jid?.endsWith('@s.whatsapp.net'))
|
|
49
|
+
/** is the jid a group */
|
|
50
|
+
export const isLidUser = (jid: string | undefined) => (jid?.endsWith('@lid'))
|
|
51
|
+
/** is the jid a broadcast */
|
|
52
|
+
export const isJidBroadcast = (jid: string | undefined) => (jid?.endsWith('@broadcast'))
|
|
53
|
+
/** is the jid a group */
|
|
54
|
+
export const isJidGroup = (jid: string | undefined) => (jid?.endsWith('@g.us'))
|
|
55
|
+
/** is the jid the status broadcast */
|
|
56
|
+
export const isJidStatusBroadcast = (jid: string) => jid === 'status@broadcast'
|
|
57
|
+
/** is the jid the newsletter */
|
|
58
|
+
export const isJidNewsLetter = (jid: string | undefined) => (jid?.endsWith('newsletter'))
|
|
59
|
+
|
|
60
|
+
export const jidNormalizedUser = (jid: string | undefined) => {
|
|
61
|
+
const result = jidDecode(jid)
|
|
62
|
+
if(!result) {
|
|
63
|
+
return ''
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const { user, server } = result
|
|
67
|
+
return jidEncode(user, server === 'c.us' ? 's.whatsapp.net' : server as JidServer)
|
|
68
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as constants from './constants'
|
|
2
|
+
/**
|
|
3
|
+
* the binary node WA uses internally for communication
|
|
4
|
+
*
|
|
5
|
+
* this is manipulated soley as an object and it does not have any functions.
|
|
6
|
+
* This is done for easy serialization, to prevent running into issues with prototypes &
|
|
7
|
+
* to maintain functional code structure
|
|
8
|
+
* */
|
|
9
|
+
export type BinaryNode = {
|
|
10
|
+
tag: string
|
|
11
|
+
attrs: { [key: string]: string }
|
|
12
|
+
content?: BinaryNode[] | string | Uint8Array
|
|
13
|
+
}
|
|
14
|
+
export type BinaryNodeAttributes = BinaryNode['attrs']
|
|
15
|
+
export type BinaryNodeData = BinaryNode['content']
|
|
16
|
+
|
|
17
|
+
export type BinaryNodeCodingOptions = typeof constants
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BinaryInfo = void 0;
|
|
4
|
+
class BinaryInfo {
|
|
5
|
+
constructor(options = {}) {
|
|
6
|
+
this.protocolVersion = 5;
|
|
7
|
+
this.sequence = 0;
|
|
8
|
+
this.events = [];
|
|
9
|
+
this.buffer = [];
|
|
10
|
+
Object.assign(this, options);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.BinaryInfo = BinaryInfo;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { EventInputType } from './constants'
|
|
2
|
+
|
|
3
|
+
export class BinaryInfo {
|
|
4
|
+
protocolVersion = 5
|
|
5
|
+
sequence = 0
|
|
6
|
+
events = [] as EventInputType[]
|
|
7
|
+
buffer: Buffer[] = []
|
|
8
|
+
|
|
9
|
+
constructor(options: Partial<BinaryInfo> = {}) {
|
|
10
|
+
Object.assign(this, options)
|
|
11
|
+
}
|
|
12
|
+
}
|