@neelegirl/baileys 1.5.3 → 1.5.4
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 +21 -21
- package/README.md +195 -195
- package/WAProto/GenerateStatics.sh +3 -0
- package/WAProto/WAProto.proto +478 -1153
- package/WAProto/fix-imports.js +29 -0
- package/WAProto/index.d.ts +2645 -51971
- package/WAProto/index.js +48649 -154035
- package/engine-requirements.js +10 -0
- package/lib/Defaults/index.d.ts +62 -78
- package/lib/Defaults/index.d.ts.map +1 -0
- package/lib/Defaults/index.js +115 -149
- package/lib/Defaults/index.js.map +1 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +10 -0
- package/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
- package/lib/Signal/Group/ciphertext-message.js +12 -0
- package/lib/Signal/Group/ciphertext-message.js.map +1 -0
- package/lib/Signal/{WASignalGroup → Group}/group-session-builder.d.ts +11 -13
- package/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
- package/lib/Signal/Group/group-session-builder.js +30 -0
- package/lib/Signal/Group/group-session-builder.js.map +1 -0
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.d.ts.map +1 -0
- package/lib/Signal/{WASignalGroup → Group}/group_cipher.js +41 -70
- package/lib/Signal/Group/group_cipher.js.map +1 -0
- package/lib/Signal/Group/index.d.ts +12 -0
- package/lib/Signal/Group/index.d.ts.map +1 -0
- package/lib/Signal/Group/index.js +12 -0
- package/lib/Signal/Group/index.js.map +1 -0
- package/lib/Signal/Group/keyhelper.d.ts +11 -0
- package/lib/Signal/Group/keyhelper.d.ts.map +1 -0
- package/lib/Signal/Group/keyhelper.js +18 -0
- package/lib/Signal/Group/keyhelper.js.map +1 -0
- package/lib/Signal/Group/sender-chain-key.d.ts +14 -0
- package/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
- package/lib/Signal/Group/sender-chain-key.js +26 -0
- package/lib/Signal/Group/sender-chain-key.js.map +1 -0
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +17 -0
- package/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +63 -0
- package/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
- package/lib/Signal/Group/sender-key-message.d.ts +19 -0
- package/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
- package/lib/Signal/Group/sender-key-message.js +66 -0
- package/lib/Signal/Group/sender-key-message.js.map +1 -0
- package/lib/Signal/Group/sender-key-name.d.ts +18 -0
- package/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
- package/lib/Signal/Group/sender-key-name.js +48 -0
- package/lib/Signal/Group/sender-key-name.js.map +1 -0
- package/lib/Signal/Group/sender-key-record.d.ts +31 -0
- package/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
- package/lib/Signal/Group/sender-key-record.js +41 -0
- package/lib/Signal/Group/sender-key-record.js.map +1 -0
- package/lib/Signal/Group/sender-key-state.d.ts +39 -0
- package/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
- package/lib/Signal/Group/sender-key-state.js +84 -0
- package/lib/Signal/Group/sender-key-state.js.map +1 -0
- package/lib/Signal/Group/sender-message-key.d.ts +12 -0
- package/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
- package/lib/Signal/{WASignalGroup/sender_message_key.js → Group/sender-message-key.js} +26 -39
- package/lib/Signal/Group/sender-message-key.js.map +1 -0
- package/lib/Signal/libsignal.d.ts +5 -8
- package/lib/Signal/libsignal.d.ts.map +1 -0
- package/lib/Signal/libsignal.js +342 -391
- package/lib/Signal/libsignal.js.map +1 -0
- package/lib/Signal/lid-mapping.d.ts +23 -28
- package/lib/Signal/lid-mapping.d.ts.map +1 -0
- package/lib/Signal/lid-mapping.js +171 -184
- package/lib/Signal/lid-mapping.js.map +1 -0
- package/lib/Socket/Client/index.d.ts +3 -2
- package/lib/Socket/Client/index.d.ts.map +1 -0
- package/lib/Socket/Client/index.js +3 -22
- package/lib/Socket/Client/index.js.map +1 -0
- package/lib/Socket/Client/types.d.ts +15 -15
- package/lib/Socket/Client/types.d.ts.map +1 -0
- package/lib/Socket/Client/types.js +8 -15
- package/lib/Socket/Client/types.js.map +1 -0
- package/lib/Socket/Client/websocket.d.ts +12 -12
- package/lib/Socket/Client/websocket.d.ts.map +1 -0
- package/lib/Socket/Client/websocket.js +24 -36
- package/lib/Socket/Client/websocket.js.map +1 -0
- package/lib/Socket/business.d.ts +178 -177
- package/lib/Socket/business.d.ts.map +1 -0
- package/lib/Socket/business.js +81 -120
- package/lib/Socket/business.js.map +1 -0
- package/lib/Socket/chats.d.ts +93 -92
- package/lib/Socket/chats.d.ts.map +1 -0
- package/lib/Socket/chats.js +462 -618
- package/lib/Socket/chats.js.map +1 -0
- package/lib/Socket/communities.d.ts +244 -223
- package/lib/Socket/communities.d.ts.map +1 -0
- package/lib/Socket/communities.js +431 -433
- package/lib/Socket/communities.js.map +1 -0
- package/lib/Socket/groups.d.ts +118 -110
- package/lib/Socket/groups.d.ts.map +1 -0
- package/lib/Socket/groups.js +148 -181
- package/lib/Socket/groups.js.map +1 -0
- package/lib/Socket/index.d.ts +222 -182
- package/lib/Socket/index.d.ts.map +1 -0
- package/lib/Socket/index.js +12 -18
- package/lib/Socket/index.js.map +1 -0
- package/lib/Socket/messages-recv.d.ts +165 -166
- package/lib/Socket/messages-recv.d.ts.map +1 -0
- package/lib/Socket/messages-recv.js +753 -1031
- package/lib/Socket/messages-recv.js.map +1 -0
- package/lib/Socket/messages-send.d.ts +161 -157
- package/lib/Socket/messages-send.d.ts.map +1 -0
- package/lib/Socket/messages-send.js +564 -1396
- package/lib/Socket/messages-send.js.map +1 -0
- package/lib/Socket/mex.d.ts +3 -2
- package/lib/Socket/mex.d.ts.map +1 -0
- package/lib/Socket/mex.js +42 -47
- package/lib/Socket/mex.js.map +1 -0
- package/lib/Socket/newsletter.d.ts +139 -137
- package/lib/Socket/newsletter.d.ts.map +1 -0
- package/lib/Socket/newsletter.js +181 -295
- package/lib/Socket/newsletter.js.map +1 -0
- package/lib/Socket/socket.d.ts +42 -36
- package/lib/Socket/socket.d.ts.map +1 -0
- package/lib/Socket/socket.js +487 -557
- package/lib/Socket/socket.js.map +1 -0
- package/lib/Types/Auth.d.ts +87 -97
- package/lib/Types/Auth.d.ts.map +1 -0
- package/lib/Types/Auth.js +2 -3
- package/lib/Types/Auth.js.map +1 -0
- package/lib/Types/Bussines.d.ts +25 -0
- package/lib/Types/Bussines.d.ts.map +1 -0
- package/lib/Types/Bussines.js +2 -3
- package/lib/Types/Bussines.js.map +1 -0
- package/lib/Types/Call.d.ts +13 -13
- package/lib/Types/Call.d.ts.map +1 -0
- package/lib/Types/Call.js +2 -3
- package/lib/Types/Call.js.map +1 -0
- package/lib/Types/Chat.d.ts +77 -97
- package/lib/Types/Chat.d.ts.map +1 -0
- package/lib/Types/Chat.js +8 -9
- package/lib/Types/Chat.js.map +1 -0
- package/lib/Types/Contact.d.ts +10 -9
- package/lib/Types/Contact.d.ts.map +1 -0
- package/lib/Types/Contact.js +2 -3
- package/lib/Types/Contact.js.map +1 -0
- package/lib/Types/Events.d.ts +151 -175
- package/lib/Types/Events.d.ts.map +1 -0
- package/lib/Types/Events.js +2 -3
- package/lib/Types/Events.js.map +1 -0
- package/lib/Types/GroupMetadata.d.ts +49 -48
- package/lib/Types/GroupMetadata.d.ts.map +1 -0
- package/lib/Types/GroupMetadata.js +2 -3
- package/lib/Types/GroupMetadata.js.map +1 -0
- package/lib/Types/Label.d.ts +13 -14
- package/lib/Types/Label.d.ts.map +1 -0
- package/lib/Types/Label.js +24 -30
- package/lib/Types/Label.js.map +1 -0
- package/lib/Types/LabelAssociation.d.ts +15 -20
- package/lib/Types/LabelAssociation.d.ts.map +1 -0
- package/lib/Types/LabelAssociation.js +6 -12
- package/lib/Types/LabelAssociation.js.map +1 -0
- package/lib/Types/Message.d.ts +231 -412
- package/lib/Types/Message.d.ts.map +1 -0
- package/lib/Types/Message.js +11 -19
- package/lib/Types/Message.js.map +1 -0
- package/lib/Types/Newsletter.d.ts +130 -104
- package/lib/Types/Newsletter.d.ts.map +1 -0
- package/lib/Types/Newsletter.js +31 -40
- package/lib/Types/Newsletter.js.map +1 -0
- package/lib/Types/Product.d.ts +58 -71
- package/lib/Types/Product.d.ts.map +1 -0
- package/lib/Types/Product.js +2 -3
- package/lib/Types/Product.js.map +1 -0
- package/lib/Types/Signal.d.ts +60 -82
- package/lib/Types/Signal.d.ts.map +1 -0
- package/lib/Types/Signal.js +2 -3
- package/lib/Types/Signal.js.map +1 -0
- package/lib/Types/Socket.d.ts +73 -81
- package/lib/Types/Socket.d.ts.map +1 -0
- package/lib/Types/Socket.js +3 -3
- package/lib/Types/Socket.js.map +1 -0
- package/lib/Types/State.d.ts +17 -19
- package/lib/Types/State.d.ts.map +1 -0
- package/lib/Types/State.js +13 -14
- package/lib/Types/State.js.map +1 -0
- package/lib/Types/USync.d.ts +8 -8
- package/lib/Types/USync.d.ts.map +1 -0
- package/lib/Types/USync.js +2 -3
- package/lib/Types/USync.js.map +1 -0
- package/lib/Types/index.d.ts +47 -62
- package/lib/Types/index.d.ts.map +1 -0
- package/lib/Types/index.js +26 -50
- package/lib/Types/index.js.map +1 -0
- package/lib/Utils/auth-utils.d.ts +19 -21
- package/lib/Utils/auth-utils.d.ts.map +1 -0
- package/lib/Utils/auth-utils.js +257 -528
- package/lib/Utils/auth-utils.js.map +1 -0
- package/lib/Utils/baileys-event-stream.d.ts +17 -18
- package/lib/Utils/baileys-event-stream.d.ts.map +1 -0
- package/lib/Utils/baileys-event-stream.js +56 -70
- package/lib/Utils/baileys-event-stream.js.map +1 -0
- package/lib/Utils/browser-utils.d.ts +4 -0
- package/lib/Utils/browser-utils.d.ts.map +1 -0
- package/lib/Utils/browser-utils.js +28 -0
- package/lib/Utils/browser-utils.js.map +1 -0
- package/lib/Utils/business.d.ts +23 -29
- package/lib/Utils/business.d.ts.map +1 -0
- package/lib/Utils/business.js +231 -255
- package/lib/Utils/business.js.map +1 -0
- package/lib/Utils/chat-utils.d.ts +70 -82
- package/lib/Utils/chat-utils.d.ts.map +1 -0
- package/lib/Utils/chat-utils.js +763 -809
- package/lib/Utils/chat-utils.js.map +1 -0
- package/lib/Utils/crypto.d.ts +41 -56
- package/lib/Utils/crypto.d.ts.map +1 -0
- package/lib/Utils/crypto.js +142 -189
- package/lib/Utils/crypto.js.map +1 -0
- package/lib/Utils/decode-wa-message.d.ts +48 -53
- package/lib/Utils/decode-wa-message.d.ts.map +1 -0
- package/lib/Utils/decode-wa-message.js +279 -323
- package/lib/Utils/decode-wa-message.js.map +1 -0
- package/lib/Utils/event-buffer.d.ts +34 -39
- package/lib/Utils/event-buffer.d.ts.map +1 -0
- package/lib/Utils/event-buffer.js +548 -595
- package/lib/Utils/event-buffer.js.map +1 -0
- package/lib/Utils/generics.d.ts +90 -131
- package/lib/Utils/generics.d.ts.map +1 -0
- package/lib/Utils/generics.js +381 -630
- package/lib/Utils/generics.js.map +1 -0
- package/lib/Utils/history.d.ts +19 -23
- package/lib/Utils/history.d.ts.map +1 -0
- package/lib/Utils/history.js +84 -104
- package/lib/Utils/history.js.map +1 -0
- package/lib/Utils/index.d.ts +20 -20
- package/lib/Utils/index.d.ts.map +1 -0
- package/lib/Utils/index.js +19 -40
- package/lib/Utils/index.js.map +1 -0
- package/lib/Utils/link-preview.d.ts +21 -23
- package/lib/Utils/link-preview.d.ts.map +1 -0
- package/lib/Utils/link-preview.js +85 -120
- package/lib/Utils/link-preview.js.map +1 -0
- package/lib/Utils/logger.d.ts +12 -13
- package/lib/Utils/logger.d.ts.map +1 -0
- package/lib/Utils/logger.js +3 -7
- package/lib/Utils/logger.js.map +1 -0
- package/lib/Utils/lt-hash.d.ts +13 -14
- package/lib/Utils/lt-hash.d.ts.map +1 -0
- package/lib/Utils/lt-hash.js +48 -58
- package/lib/Utils/lt-hash.js.map +1 -0
- package/lib/Utils/make-mutex.d.ts +8 -9
- package/lib/Utils/make-mutex.d.ts.map +1 -0
- package/lib/Utils/make-mutex.js +40 -49
- package/lib/Utils/make-mutex.js.map +1 -0
- package/lib/Utils/message-retry-manager.d.ts +82 -88
- package/lib/Utils/message-retry-manager.d.ts.map +1 -0
- package/lib/Utils/message-retry-manager.js +149 -160
- package/lib/Utils/message-retry-manager.js.map +1 -0
- package/lib/Utils/messages-media.d.ts +114 -135
- package/lib/Utils/messages-media.d.ts.map +1 -0
- package/lib/Utils/messages-media.js +663 -869
- package/lib/Utils/messages-media.js.map +1 -0
- package/lib/Utils/messages.d.ts +76 -105
- package/lib/Utils/messages.d.ts.map +1 -0
- package/lib/Utils/messages.js +820 -1745
- package/lib/Utils/messages.js.map +1 -0
- package/lib/Utils/noise-handler.d.ts +20 -21
- package/lib/Utils/noise-handler.d.ts.map +1 -0
- package/lib/Utils/noise-handler.js +147 -165
- package/lib/Utils/noise-handler.js.map +1 -0
- package/lib/Utils/pre-key-manager.d.ts +28 -0
- package/lib/Utils/pre-key-manager.d.ts.map +1 -0
- package/lib/Utils/pre-key-manager.js +106 -0
- package/lib/Utils/pre-key-manager.js.map +1 -0
- package/lib/Utils/process-message.d.ts +42 -49
- package/lib/Utils/process-message.d.ts.map +1 -0
- package/lib/Utils/process-message.js +413 -427
- package/lib/Utils/process-message.js.map +1 -0
- package/lib/Utils/signal.d.ts +34 -42
- package/lib/Utils/signal.d.ts.map +1 -0
- package/lib/Utils/signal.js +159 -166
- package/lib/Utils/signal.js.map +1 -0
- package/lib/Utils/use-multi-file-auth-state.d.ts +13 -18
- package/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
- package/lib/Utils/use-multi-file-auth-state.js +121 -238
- package/lib/Utils/use-multi-file-auth-state.js.map +1 -0
- package/lib/Utils/validate-connection.d.ts +11 -13
- package/lib/Utils/validate-connection.d.ts.map +1 -0
- package/lib/Utils/validate-connection.js +195 -220
- package/lib/Utils/validate-connection.js.map +1 -0
- package/lib/WABinary/constants.d.ts +28 -30
- package/lib/WABinary/constants.d.ts.map +1 -0
- package/lib/WABinary/constants.js +1301 -1316
- package/lib/WABinary/constants.js.map +1 -0
- package/lib/WABinary/decode.d.ts +7 -9
- package/lib/WABinary/decode.d.ts.map +1 -0
- package/lib/WABinary/decode.js +238 -288
- package/lib/WABinary/decode.js.map +1 -0
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.d.ts.map +1 -0
- package/lib/WABinary/encode.js +216 -265
- package/lib/WABinary/encode.js.map +1 -0
- package/lib/WABinary/generic-utils.d.ts +15 -28
- package/lib/WABinary/generic-utils.d.ts.map +1 -0
- package/lib/WABinary/generic-utils.js +102 -142
- package/lib/WABinary/generic-utils.js.map +1 -0
- package/lib/WABinary/index.d.ts +6 -5
- package/lib/WABinary/index.d.ts.map +1 -0
- package/lib/WABinary/index.js +6 -25
- package/lib/WABinary/index.js.map +1 -0
- package/lib/WABinary/jid-utils.d.ts +48 -58
- package/lib/WABinary/jid-utils.d.ts.map +1 -0
- package/lib/WABinary/jid-utils.js +96 -104
- package/lib/WABinary/jid-utils.js.map +1 -0
- package/lib/WABinary/types.d.ts +19 -22
- package/lib/WABinary/types.d.ts.map +1 -0
- package/lib/WABinary/types.js +2 -3
- package/lib/WABinary/types.js.map +1 -0
- package/lib/WAM/BinaryInfo.d.ts +9 -16
- package/lib/WAM/BinaryInfo.d.ts.map +1 -0
- package/lib/WAM/BinaryInfo.js +10 -17
- package/lib/WAM/BinaryInfo.js.map +1 -0
- package/lib/WAM/constants.d.ts +40 -47
- package/lib/WAM/constants.d.ts.map +1 -0
- package/lib/WAM/constants.js +22853 -15371
- package/lib/WAM/constants.js.map +1 -0
- package/lib/WAM/encode.d.ts +3 -3
- package/lib/WAM/encode.d.ts.map +1 -0
- package/lib/WAM/encode.js +150 -164
- package/lib/WAM/encode.js.map +1 -0
- package/lib/WAM/index.d.ts +4 -3
- package/lib/WAM/index.d.ts.map +1 -0
- package/lib/WAM/index.js +4 -23
- package/lib/WAM/index.js.map +1 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -9
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +12 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +19 -22
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +18 -26
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +11 -12
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -20
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +11 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +16 -24
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +26 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +51 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +10 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +29 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
- package/lib/WAUSync/Protocols/index.d.ts +5 -6
- package/lib/WAUSync/Protocols/index.d.ts.map +1 -0
- package/lib/WAUSync/Protocols/index.js +5 -26
- package/lib/WAUSync/Protocols/index.js.map +1 -0
- package/lib/WAUSync/USyncQuery.d.ts +26 -28
- package/lib/WAUSync/USyncQuery.d.ts.map +1 -0
- package/lib/WAUSync/USyncQuery.js +64 -62
- package/lib/WAUSync/USyncQuery.js.map +1 -0
- package/lib/WAUSync/USyncUser.d.ts +11 -10
- package/lib/WAUSync/USyncUser.d.ts.map +1 -0
- package/lib/WAUSync/USyncUser.js +12 -19
- package/lib/WAUSync/USyncUser.js.map +1 -0
- package/lib/WAUSync/index.d.ts +4 -3
- package/lib/WAUSync/index.d.ts.map +1 -0
- package/lib/WAUSync/index.js +4 -23
- package/lib/WAUSync/index.js.map +1 -0
- package/lib/index.d.ts +12 -13
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +11 -33
- package/lib/index.js.map +1 -0
- package/package.json +99 -96
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/WASignalGroup/GroupProtocol.js +0 -1909
- package/lib/Signal/WASignalGroup/ciphertext-message.d.ts +0 -9
- package/lib/Signal/WASignalGroup/ciphertext-message.js +0 -19
- package/lib/Signal/WASignalGroup/ciphertext_message.js +0 -16
- package/lib/Signal/WASignalGroup/generate-proto.sh +0 -1
- package/lib/Signal/WASignalGroup/group-session-builder.js +0 -72
- package/lib/Signal/WASignalGroup/group.proto +0 -42
- package/lib/Signal/WASignalGroup/group_cipher.d.ts +0 -19
- package/lib/Signal/WASignalGroup/group_session_builder.js +0 -46
- package/lib/Signal/WASignalGroup/index.d.ts +0 -11
- package/lib/Signal/WASignalGroup/index.js +0 -61
- package/lib/Signal/WASignalGroup/keyhelper.d.ts +0 -16
- package/lib/Signal/WASignalGroup/keyhelper.js +0 -66
- package/lib/Signal/WASignalGroup/protobufs.js +0 -3
- package/lib/Signal/WASignalGroup/queue_job.js +0 -69
- package/lib/Signal/WASignalGroup/readme.md +0 -6
- package/lib/Signal/WASignalGroup/sender-chain-key.d.ts +0 -14
- package/lib/Signal/WASignalGroup/sender-chain-key.js +0 -47
- package/lib/Signal/WASignalGroup/sender-key-distribution-message.d.ts +0 -17
- package/lib/Signal/WASignalGroup/sender-key-distribution-message.js +0 -71
- package/lib/Signal/WASignalGroup/sender-key-message.d.ts +0 -19
- package/lib/Signal/WASignalGroup/sender-key-message.js +0 -73
- package/lib/Signal/WASignalGroup/sender-key-name.d.ts +0 -19
- package/lib/Signal/WASignalGroup/sender-key-name.js +0 -59
- package/lib/Signal/WASignalGroup/sender-key-record.d.ts +0 -32
- package/lib/Signal/WASignalGroup/sender-key-record.js +0 -58
- package/lib/Signal/WASignalGroup/sender-key-state.d.ts +0 -44
- package/lib/Signal/WASignalGroup/sender-key-state.js +0 -147
- package/lib/Signal/WASignalGroup/sender-message-key.d.ts +0 -11
- package/lib/Signal/WASignalGroup/sender-message-key.js +0 -33
- package/lib/Signal/WASignalGroup/sender_chain_key.js +0 -50
- package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +0 -78
- package/lib/Signal/WASignalGroup/sender_key_message.js +0 -92
- package/lib/Signal/WASignalGroup/sender_key_name.js +0 -70
- package/lib/Signal/WASignalGroup/sender_key_record.js +0 -56
- package/lib/Signal/WASignalGroup/sender_key_state.js +0 -129
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -15
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -12
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/usync.d.ts +0 -37
- package/lib/Socket/usync.js +0 -83
- package/lib/Store/index.d.ts +0 -4
- package/lib/Store/index.js +0 -24
- package/lib/Store/make-cache-manager-store.d.ts +0 -14
- package/lib/Store/make-cache-manager-store.js +0 -90
- package/lib/Store/make-in-memory-store.d.ts +0 -123
- package/lib/Store/make-in-memory-store.js +0 -429
- package/lib/Store/make-ordered-dictionary.d.ts +0 -12
- package/lib/Store/make-ordered-dictionary.js +0 -86
- package/lib/Store/object-repository.d.ts +0 -10
- package/lib/Store/object-repository.js +0 -31
- package/lib/Types/Bussiness.d.ts +0 -28
- package/lib/Types/MexUpdates.d.ts +0 -9
- package/lib/Types/MexUpdates.js +0 -18
- package/lib/Utils/use-mongo-file-auth-state.d.ts +0 -6
- package/lib/Utils/use-mongo-file-auth-state.js +0 -84
- package/lib/Utils/use-single-file-auth-state.d.ts +0 -13
- package/lib/Utils/use-single-file-auth-state.js +0 -80
- package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +0 -28
- package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +0 -69
- package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +0 -10
- package/lib/WAUSync/Protocols/USyncLIDProtocol.js +0 -38
package/lib/Utils/generics.js
CHANGED
|
@@ -1,630 +1,381 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
const
|
|
36
|
-
const
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
'
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
const
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
const
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
const
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
return
|
|
343
|
-
};
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
})
|
|
383
|
-
}
|
|
384
|
-
|
|
385
|
-
/**
|
|
386
|
-
* utility that fetches latest baileys version from the master branch.
|
|
387
|
-
* Use to ensure your WA connection is always on the latest version
|
|
388
|
-
*/
|
|
389
|
-
const fetchLatestBaileysVersion = async (options = {}) => {
|
|
390
|
-
const URL = 'https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/baileys-version.json'
|
|
391
|
-
try {
|
|
392
|
-
const result = await axios_1.default.get(URL, {
|
|
393
|
-
...options,
|
|
394
|
-
responseType: 'json'
|
|
395
|
-
})
|
|
396
|
-
return {
|
|
397
|
-
version: result.data.version,
|
|
398
|
-
isLatest: true
|
|
399
|
-
}
|
|
400
|
-
}
|
|
401
|
-
catch (error) {
|
|
402
|
-
return {
|
|
403
|
-
version: baileys_version_json_1.version,
|
|
404
|
-
isLatest: false,
|
|
405
|
-
error
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
|
|
410
|
-
/**
|
|
411
|
-
* A utility that fetches the latest web version of whatsapp.
|
|
412
|
-
* Use to ensure your WA connection is always on the latest version
|
|
413
|
-
*/
|
|
414
|
-
const fetchLatestWaWebVersion = async (options) => {
|
|
415
|
-
try {
|
|
416
|
-
const { data } = await axios_1.default.get('https://web.whatsapp.com/sw.js', {
|
|
417
|
-
...options,
|
|
418
|
-
responseType: 'json'
|
|
419
|
-
})
|
|
420
|
-
const regex = /\\?"client_revision\\?":\s*(\d+)/
|
|
421
|
-
const match = data.match(regex)
|
|
422
|
-
if (!match?.match[1]) {
|
|
423
|
-
return {
|
|
424
|
-
version: baileys_version_json_1.version,
|
|
425
|
-
isLatest: false,
|
|
426
|
-
error: {
|
|
427
|
-
message: 'Could not find client revision in the fetched content'
|
|
428
|
-
}
|
|
429
|
-
}
|
|
430
|
-
}
|
|
431
|
-
const clientRevision = match[1]
|
|
432
|
-
return {
|
|
433
|
-
version: [2, 3000, +clientRevision],
|
|
434
|
-
isLatest: true
|
|
435
|
-
}
|
|
436
|
-
}
|
|
437
|
-
catch (error) {
|
|
438
|
-
return {
|
|
439
|
-
version: baileys_version_json_1.version,
|
|
440
|
-
isLatest: false,
|
|
441
|
-
error
|
|
442
|
-
}
|
|
443
|
-
}
|
|
444
|
-
}
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
/** unique message tag prefix for MD clients */
|
|
448
|
-
const generateMdTagPrefix = () => {
|
|
449
|
-
const bytes = crypto_1.randomBytes(4)
|
|
450
|
-
return `${bytes.readUInt16BE()}.${bytes.readUInt16BE(2)}-`
|
|
451
|
-
}
|
|
452
|
-
|
|
453
|
-
const STATUS_MAP = {
|
|
454
|
-
'sender': WAProto_1.proto.WebMessageInfo.Status.SERVER_ACK,
|
|
455
|
-
'played': WAProto_1.proto.WebMessageInfo.Status.PLAYED,
|
|
456
|
-
'read': WAProto_1.proto.WebMessageInfo.Status.READ,
|
|
457
|
-
'read-self': WAProto_1.proto.WebMessageInfo.Status.READ
|
|
458
|
-
}
|
|
459
|
-
|
|
460
|
-
/**
|
|
461
|
-
* Given a type of receipt, returns what the new status of the message should be
|
|
462
|
-
* @param type type from receipt
|
|
463
|
-
*/
|
|
464
|
-
const getStatusFromReceiptType = (type) => {
|
|
465
|
-
const status = STATUS_MAP[type]
|
|
466
|
-
if (typeof type === 'undefined') {
|
|
467
|
-
return WAProto_1.proto.WebMessageInfo.Status.DELIVERY_ACK
|
|
468
|
-
}
|
|
469
|
-
return status
|
|
470
|
-
}
|
|
471
|
-
|
|
472
|
-
const CODE_MAP = {
|
|
473
|
-
conflict: Types_1.DisconnectReason.connectionReplaced
|
|
474
|
-
}
|
|
475
|
-
|
|
476
|
-
/**
|
|
477
|
-
* Stream errors generally provide a reason, map that to a baileys DisconnectReason
|
|
478
|
-
* @param reason the string reason given, eg. "conflict"
|
|
479
|
-
*/
|
|
480
|
-
const getErrorCodeFromStreamError = (node) => {
|
|
481
|
-
const [reasonNode] = WABinary_1.getAllBinaryNodeChildren(node)
|
|
482
|
-
let reason = reasonNode?.tag || 'unknown'
|
|
483
|
-
const statusCode = +(node.attrs.code || CODE_MAP[reason] || Types_1.DisconnectReason.badSession)
|
|
484
|
-
if (statusCode === Types_1.DisconnectReason.restartRequired) {
|
|
485
|
-
reason = 'restart required'
|
|
486
|
-
}
|
|
487
|
-
return {
|
|
488
|
-
reason,
|
|
489
|
-
statusCode
|
|
490
|
-
}
|
|
491
|
-
}
|
|
492
|
-
|
|
493
|
-
const getCallStatusFromNode = ({ tag, attrs }) => {
|
|
494
|
-
let status
|
|
495
|
-
switch (tag) {
|
|
496
|
-
case 'offer':
|
|
497
|
-
case 'offer_notice':
|
|
498
|
-
status = 'offer'
|
|
499
|
-
break
|
|
500
|
-
case 'terminate':
|
|
501
|
-
if (attrs.reason === 'timeout') {
|
|
502
|
-
status = 'timeout'
|
|
503
|
-
}
|
|
504
|
-
else {
|
|
505
|
-
//fired when accepted/rejected/timeout/caller hangs up
|
|
506
|
-
status = 'terminate'
|
|
507
|
-
}
|
|
508
|
-
break
|
|
509
|
-
case 'reject':
|
|
510
|
-
status = 'reject'
|
|
511
|
-
break
|
|
512
|
-
case 'accept':
|
|
513
|
-
status = 'accept'
|
|
514
|
-
break
|
|
515
|
-
default:
|
|
516
|
-
status = 'ringing'
|
|
517
|
-
break
|
|
518
|
-
}
|
|
519
|
-
return status
|
|
520
|
-
}
|
|
521
|
-
|
|
522
|
-
const getCodeFromWSError = (error) => {
|
|
523
|
-
let statusCode = 500
|
|
524
|
-
if (error?.message?.includes('Unexpected server response: ')) {
|
|
525
|
-
const code = +(error?.message.slice('Unexpected server response: '.length))
|
|
526
|
-
if (!Number.isNaN(code) && code >= 400) {
|
|
527
|
-
statusCode = code
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
else if (error?.code?.startsWith('E') || error?.message?.includes('time out')) {
|
|
531
|
-
statusCode = 408
|
|
532
|
-
}
|
|
533
|
-
return statusCode
|
|
534
|
-
}
|
|
535
|
-
|
|
536
|
-
/**
|
|
537
|
-
* Is the given platform WA business
|
|
538
|
-
* @param platform AuthenticationCreds.platform
|
|
539
|
-
*/
|
|
540
|
-
const isWABusinessPlatform = (platform) => {
|
|
541
|
-
return platform === 'smbi' || platform === 'smba'
|
|
542
|
-
}
|
|
543
|
-
|
|
544
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
545
|
-
function trimUndefined(obj) {
|
|
546
|
-
for (const key in obj) {
|
|
547
|
-
if (typeof obj[key] === 'undefined') {
|
|
548
|
-
delete obj[key]
|
|
549
|
-
}
|
|
550
|
-
}
|
|
551
|
-
return obj
|
|
552
|
-
}
|
|
553
|
-
|
|
554
|
-
function bytesToCrockford(buffer) {
|
|
555
|
-
let value = 0
|
|
556
|
-
let bitCount = 0
|
|
557
|
-
const crockford = []
|
|
558
|
-
for (const element of buffer) {
|
|
559
|
-
value = (value << 8) | (element & 0xff)
|
|
560
|
-
bitCount += 8
|
|
561
|
-
while (bitCount >= 5) {
|
|
562
|
-
crockford.push('123456789ABCDEFGHJKLMNPQRSTVWXYZ'.charAt((value >>> (bitCount - 5)) & 31))
|
|
563
|
-
bitCount -= 5
|
|
564
|
-
}
|
|
565
|
-
}
|
|
566
|
-
if (bitCount > 0) {
|
|
567
|
-
crockford.push('123456789ABCDEFGHJKLMNPQRSTVWXYZ'.charAt((value << (5 - bitCount)) & 31))
|
|
568
|
-
}
|
|
569
|
-
return crockford.join('')
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
const toUnicodeEscape = (text) => {
|
|
573
|
-
return text.split("").map(char => "\\u" + char.charCodeAt(0).toString(16).padStart(4, "0")).join("")
|
|
574
|
-
}
|
|
575
|
-
|
|
576
|
-
const fromUnicodeEscape = (escapedText) => {
|
|
577
|
-
return escapedText.replace(/\\u[\dA-Fa-f]{4}/g, match => String.fromCharCode(parseInt(match.slice(2), 16)))
|
|
578
|
-
}
|
|
579
|
-
|
|
580
|
-
const asciiEncode = (text) => {
|
|
581
|
-
var encoded = text.split("").map(c => c.charCodeAt(0))
|
|
582
|
-
return encoded
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
const asciiDecode = (...codes) => {
|
|
586
|
-
var codeArray = Array.isArray(codes[0]) ? codes[0] : codes
|
|
587
|
-
return codeArray.map(c => String.fromCharCode(c)).join("")
|
|
588
|
-
}
|
|
589
|
-
|
|
590
|
-
module.exports = {
|
|
591
|
-
Browsers,
|
|
592
|
-
BufferJSON,
|
|
593
|
-
getPlatformId,
|
|
594
|
-
getKeyAuthor,
|
|
595
|
-
writeRandomPadMax16,
|
|
596
|
-
unpadRandomMax16,
|
|
597
|
-
encodeWAMessage,
|
|
598
|
-
encodeNewsletterMessage,
|
|
599
|
-
generateRegistrationId,
|
|
600
|
-
encodeBigEndian,
|
|
601
|
-
toNumber,
|
|
602
|
-
unixTimestampSeconds,
|
|
603
|
-
debouncedTimeout,
|
|
604
|
-
delay,
|
|
605
|
-
delayCancellable,
|
|
606
|
-
promiseTimeout,
|
|
607
|
-
generateMessageID,
|
|
608
|
-
generateParticipantHashV2,
|
|
609
|
-
generateMessageIDV2,
|
|
610
|
-
generateAndroidMessageID,
|
|
611
|
-
generateIOSMessageID,
|
|
612
|
-
generateDesktopMessageID,
|
|
613
|
-
bindWaitForEvent,
|
|
614
|
-
bindWaitForConnectionUpdate,
|
|
615
|
-
printQRIfNecessaryListener,
|
|
616
|
-
fetchLatestBaileysVersion,
|
|
617
|
-
fetchLatestWaWebVersion,
|
|
618
|
-
generateMdTagPrefix,
|
|
619
|
-
getStatusFromReceiptType,
|
|
620
|
-
getErrorCodeFromStreamError,
|
|
621
|
-
getCallStatusFromNode,
|
|
622
|
-
getCodeFromWSError,
|
|
623
|
-
isWABusinessPlatform,
|
|
624
|
-
trimUndefined,
|
|
625
|
-
bytesToCrockford,
|
|
626
|
-
toUnicodeEscape,
|
|
627
|
-
fromUnicodeEscape,
|
|
628
|
-
asciiEncode,
|
|
629
|
-
asciiDecode
|
|
630
|
-
}
|
|
1
|
+
import { Boom } from '@hapi/boom';
|
|
2
|
+
import { createHash, randomBytes } from 'crypto';
|
|
3
|
+
import { proto } from '../../WAProto/index.js';
|
|
4
|
+
const baileysVersion = [2, 3000, 1027934701];
|
|
5
|
+
import { DisconnectReason } from '../Types/index.js';
|
|
6
|
+
import { getAllBinaryNodeChildren, jidDecode } from '../WABinary/index.js';
|
|
7
|
+
import { sha256 } from './crypto.js';
|
|
8
|
+
export const BufferJSON = {
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
10
|
+
replacer: (k, value) => {
|
|
11
|
+
if (Buffer.isBuffer(value) || value instanceof Uint8Array || value?.type === 'Buffer') {
|
|
12
|
+
return { type: 'Buffer', data: Buffer.from(value?.data || value).toString('base64') };
|
|
13
|
+
}
|
|
14
|
+
return value;
|
|
15
|
+
},
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
17
|
+
reviver: (_, value) => {
|
|
18
|
+
if (typeof value === 'object' && value !== null && value.type === 'Buffer' && typeof value.data === 'string') {
|
|
19
|
+
return Buffer.from(value.data, 'base64');
|
|
20
|
+
}
|
|
21
|
+
if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
|
|
22
|
+
const keys = Object.keys(value);
|
|
23
|
+
if (keys.length > 0 && keys.every(k => !isNaN(parseInt(k, 10)))) {
|
|
24
|
+
const values = Object.values(value);
|
|
25
|
+
if (values.every(v => typeof v === 'number')) {
|
|
26
|
+
return Buffer.from(values);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
return value;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
export const getKeyAuthor = (key, meId = 'me') => (key?.fromMe ? meId : key?.participant || key?.remoteJid) || '';
|
|
34
|
+
export const writeRandomPadMax16 = (msg) => {
|
|
35
|
+
const pad = randomBytes(1);
|
|
36
|
+
const padLength = (pad[0] & 0x0f) + 1;
|
|
37
|
+
return Buffer.concat([msg, Buffer.alloc(padLength, padLength)]);
|
|
38
|
+
};
|
|
39
|
+
export const unpadRandomMax16 = (e) => {
|
|
40
|
+
const t = new Uint8Array(e);
|
|
41
|
+
if (0 === t.length) {
|
|
42
|
+
throw new Error('unpadPkcs7 given empty bytes');
|
|
43
|
+
}
|
|
44
|
+
var r = t[t.length - 1];
|
|
45
|
+
if (r > t.length) {
|
|
46
|
+
throw new Error(`unpad given ${t.length} bytes, but pad is ${r}`);
|
|
47
|
+
}
|
|
48
|
+
return new Uint8Array(t.buffer, t.byteOffset, t.length - r);
|
|
49
|
+
};
|
|
50
|
+
// code is inspired by whatsmeow
|
|
51
|
+
export const generateParticipantHashV2 = (participants) => {
|
|
52
|
+
participants.sort();
|
|
53
|
+
const sha256Hash = sha256(Buffer.from(participants.join(''))).toString('base64');
|
|
54
|
+
return '2:' + sha256Hash.slice(0, 6);
|
|
55
|
+
};
|
|
56
|
+
export const encodeWAMessage = (message) => writeRandomPadMax16(proto.Message.encode(message).finish());
|
|
57
|
+
export const generateRegistrationId = () => {
|
|
58
|
+
return Uint16Array.from(randomBytes(2))[0] & 16383;
|
|
59
|
+
};
|
|
60
|
+
export const encodeBigEndian = (e, t = 4) => {
|
|
61
|
+
let r = e;
|
|
62
|
+
const a = new Uint8Array(t);
|
|
63
|
+
for (let i = t - 1; i >= 0; i--) {
|
|
64
|
+
a[i] = 255 & r;
|
|
65
|
+
r >>>= 8;
|
|
66
|
+
}
|
|
67
|
+
return a;
|
|
68
|
+
};
|
|
69
|
+
export const toNumber = (t) => typeof t === 'object' && t ? ('toNumber' in t ? t.toNumber() : t.low) : t || 0;
|
|
70
|
+
/** unix timestamp of a date in seconds */
|
|
71
|
+
export const unixTimestampSeconds = (date = new Date()) => Math.floor(date.getTime() / 1000);
|
|
72
|
+
export const debouncedTimeout = (intervalMs = 1000, task) => {
|
|
73
|
+
let timeout;
|
|
74
|
+
return {
|
|
75
|
+
start: (newIntervalMs, newTask) => {
|
|
76
|
+
task = newTask || task;
|
|
77
|
+
intervalMs = newIntervalMs || intervalMs;
|
|
78
|
+
timeout && clearTimeout(timeout);
|
|
79
|
+
timeout = setTimeout(() => task?.(), intervalMs);
|
|
80
|
+
},
|
|
81
|
+
cancel: () => {
|
|
82
|
+
timeout && clearTimeout(timeout);
|
|
83
|
+
timeout = undefined;
|
|
84
|
+
},
|
|
85
|
+
setTask: (newTask) => (task = newTask),
|
|
86
|
+
setInterval: (newInterval) => (intervalMs = newInterval)
|
|
87
|
+
};
|
|
88
|
+
};
|
|
89
|
+
export const delay = (ms) => delayCancellable(ms).delay;
|
|
90
|
+
export const delayCancellable = (ms) => {
|
|
91
|
+
const stack = new Error().stack;
|
|
92
|
+
let timeout;
|
|
93
|
+
let reject;
|
|
94
|
+
const delay = new Promise((resolve, _reject) => {
|
|
95
|
+
timeout = setTimeout(resolve, ms);
|
|
96
|
+
reject = _reject;
|
|
97
|
+
});
|
|
98
|
+
const cancel = () => {
|
|
99
|
+
clearTimeout(timeout);
|
|
100
|
+
reject(new Boom('Cancelled', {
|
|
101
|
+
statusCode: 500,
|
|
102
|
+
data: {
|
|
103
|
+
stack
|
|
104
|
+
}
|
|
105
|
+
}));
|
|
106
|
+
};
|
|
107
|
+
return { delay, cancel };
|
|
108
|
+
};
|
|
109
|
+
export async function promiseTimeout(ms, promise) {
|
|
110
|
+
if (!ms) {
|
|
111
|
+
return new Promise(promise);
|
|
112
|
+
}
|
|
113
|
+
const stack = new Error().stack;
|
|
114
|
+
// Create a promise that rejects in <ms> milliseconds
|
|
115
|
+
const { delay, cancel } = delayCancellable(ms);
|
|
116
|
+
const p = new Promise((resolve, reject) => {
|
|
117
|
+
delay
|
|
118
|
+
.then(() => reject(new Boom('Timed Out', {
|
|
119
|
+
statusCode: DisconnectReason.timedOut,
|
|
120
|
+
data: {
|
|
121
|
+
stack
|
|
122
|
+
}
|
|
123
|
+
})))
|
|
124
|
+
.catch(err => reject(err));
|
|
125
|
+
promise(resolve, reject);
|
|
126
|
+
}).finally(cancel);
|
|
127
|
+
return p;
|
|
128
|
+
}
|
|
129
|
+
// inspired from whatsmeow code
|
|
130
|
+
// https://github.com/tulir/whatsmeow/blob/64bc969fbe78d31ae0dd443b8d4c80a5d026d07a/send.go#L42
|
|
131
|
+
export const generateMessageIDV2 = (userId) => {
|
|
132
|
+
const data = Buffer.alloc(8 + 20 + 16);
|
|
133
|
+
data.writeBigUInt64BE(BigInt(Math.floor(Date.now() / 1000)));
|
|
134
|
+
if (userId) {
|
|
135
|
+
const id = jidDecode(userId);
|
|
136
|
+
if (id?.user) {
|
|
137
|
+
data.write(id.user, 8);
|
|
138
|
+
data.write('@c.us', 8 + id.user.length);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
const random = randomBytes(16);
|
|
142
|
+
random.copy(data, 28);
|
|
143
|
+
const hash = createHash('sha256').update(data).digest();
|
|
144
|
+
return '3EB0' + hash.toString('hex').toUpperCase().substring(0, 18);
|
|
145
|
+
};
|
|
146
|
+
// generate a random ID to attach to a message
|
|
147
|
+
export const generateMessageID = () => '3EB0' + randomBytes(18).toString('hex').toUpperCase();
|
|
148
|
+
export function bindWaitForEvent(ev, event) {
|
|
149
|
+
return async (check, timeoutMs) => {
|
|
150
|
+
let listener;
|
|
151
|
+
let closeListener;
|
|
152
|
+
await promiseTimeout(timeoutMs, (resolve, reject) => {
|
|
153
|
+
closeListener = ({ connection, lastDisconnect }) => {
|
|
154
|
+
if (connection === 'close') {
|
|
155
|
+
reject(lastDisconnect?.error || new Boom('Connection Closed', { statusCode: DisconnectReason.connectionClosed }));
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
ev.on('connection.update', closeListener);
|
|
159
|
+
listener = async (update) => {
|
|
160
|
+
if (await check(update)) {
|
|
161
|
+
resolve();
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
ev.on(event, listener);
|
|
165
|
+
}).finally(() => {
|
|
166
|
+
ev.off(event, listener);
|
|
167
|
+
ev.off('connection.update', closeListener);
|
|
168
|
+
});
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
export const bindWaitForConnectionUpdate = (ev) => bindWaitForEvent(ev, 'connection.update');
|
|
172
|
+
/**
|
|
173
|
+
* utility that fetches latest baileys version from the master branch.
|
|
174
|
+
* Use to ensure your WA connection is always on the latest version
|
|
175
|
+
*/
|
|
176
|
+
export const fetchLatestBaileysVersion = async (options = {}) => {
|
|
177
|
+
const URL = 'https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/index.ts';
|
|
178
|
+
try {
|
|
179
|
+
const response = await fetch(URL, {
|
|
180
|
+
dispatcher: options.dispatcher,
|
|
181
|
+
method: 'GET',
|
|
182
|
+
headers: options.headers
|
|
183
|
+
});
|
|
184
|
+
if (!response.ok) {
|
|
185
|
+
throw new Boom(`Failed to fetch latest Baileys version: ${response.statusText}`, { statusCode: response.status });
|
|
186
|
+
}
|
|
187
|
+
const text = await response.text();
|
|
188
|
+
// Extract version from line 7 (const version = [...])
|
|
189
|
+
const lines = text.split('\n');
|
|
190
|
+
const versionLine = lines[6]; // Line 7 (0-indexed)
|
|
191
|
+
const versionMatch = versionLine.match(/const version = \[(\d+),\s*(\d+),\s*(\d+)\]/);
|
|
192
|
+
if (versionMatch) {
|
|
193
|
+
const version = [parseInt(versionMatch[1]), parseInt(versionMatch[2]), parseInt(versionMatch[3])];
|
|
194
|
+
return {
|
|
195
|
+
version,
|
|
196
|
+
isLatest: true
|
|
197
|
+
};
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
throw new Error('Could not parse version from Defaults/index.ts');
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
return {
|
|
205
|
+
version: baileysVersion,
|
|
206
|
+
isLatest: false,
|
|
207
|
+
error
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
};
|
|
211
|
+
/**
|
|
212
|
+
* A utility that fetches the latest web version of whatsapp.
|
|
213
|
+
* Use to ensure your WA connection is always on the latest version
|
|
214
|
+
*/
|
|
215
|
+
export const fetchLatestWaWebVersion = async (options = {}) => {
|
|
216
|
+
try {
|
|
217
|
+
// Absolute minimal headers required to bypass anti-bot detection
|
|
218
|
+
const defaultHeaders = {
|
|
219
|
+
'sec-fetch-site': 'none',
|
|
220
|
+
'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36'
|
|
221
|
+
};
|
|
222
|
+
const headers = { ...defaultHeaders, ...options.headers };
|
|
223
|
+
const response = await fetch('https://web.whatsapp.com/sw.js', {
|
|
224
|
+
...options,
|
|
225
|
+
method: 'GET',
|
|
226
|
+
headers
|
|
227
|
+
});
|
|
228
|
+
if (!response.ok) {
|
|
229
|
+
throw new Boom(`Failed to fetch sw.js: ${response.statusText}`, { statusCode: response.status });
|
|
230
|
+
}
|
|
231
|
+
const data = await response.text();
|
|
232
|
+
const regex = /\\?"client_revision\\?":\s*(\d+)/;
|
|
233
|
+
const match = data.match(regex);
|
|
234
|
+
if (!match?.[1]) {
|
|
235
|
+
return {
|
|
236
|
+
version: baileysVersion,
|
|
237
|
+
isLatest: false,
|
|
238
|
+
error: {
|
|
239
|
+
message: 'Could not find client revision in the fetched content'
|
|
240
|
+
}
|
|
241
|
+
};
|
|
242
|
+
}
|
|
243
|
+
const clientRevision = match[1];
|
|
244
|
+
return {
|
|
245
|
+
version: [2, 3000, +clientRevision],
|
|
246
|
+
isLatest: true
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
catch (error) {
|
|
250
|
+
return {
|
|
251
|
+
version: baileysVersion,
|
|
252
|
+
isLatest: false,
|
|
253
|
+
error
|
|
254
|
+
};
|
|
255
|
+
}
|
|
256
|
+
};
|
|
257
|
+
/** unique message tag prefix for MD clients */
|
|
258
|
+
export const generateMdTagPrefix = () => {
|
|
259
|
+
const bytes = randomBytes(4);
|
|
260
|
+
return `${bytes.readUInt16BE()}.${bytes.readUInt16BE(2)}-`;
|
|
261
|
+
};
|
|
262
|
+
const STATUS_MAP = {
|
|
263
|
+
sender: proto.WebMessageInfo.Status.SERVER_ACK,
|
|
264
|
+
played: proto.WebMessageInfo.Status.PLAYED,
|
|
265
|
+
read: proto.WebMessageInfo.Status.READ,
|
|
266
|
+
'read-self': proto.WebMessageInfo.Status.READ
|
|
267
|
+
};
|
|
268
|
+
/**
|
|
269
|
+
* Given a type of receipt, returns what the new status of the message should be
|
|
270
|
+
* @param type type from receipt
|
|
271
|
+
*/
|
|
272
|
+
export const getStatusFromReceiptType = (type) => {
|
|
273
|
+
const status = STATUS_MAP[type];
|
|
274
|
+
if (typeof type === 'undefined') {
|
|
275
|
+
return proto.WebMessageInfo.Status.DELIVERY_ACK;
|
|
276
|
+
}
|
|
277
|
+
return status;
|
|
278
|
+
};
|
|
279
|
+
const CODE_MAP = {
|
|
280
|
+
conflict: DisconnectReason.connectionReplaced
|
|
281
|
+
};
|
|
282
|
+
/**
|
|
283
|
+
* Stream errors generally provide a reason, map that to a baileys DisconnectReason
|
|
284
|
+
* @param reason the string reason given, eg. "conflict"
|
|
285
|
+
*/
|
|
286
|
+
export const getErrorCodeFromStreamError = (node) => {
|
|
287
|
+
const [reasonNode] = getAllBinaryNodeChildren(node);
|
|
288
|
+
let reason = reasonNode?.tag || 'unknown';
|
|
289
|
+
const statusCode = +(node.attrs.code || CODE_MAP[reason] || DisconnectReason.badSession);
|
|
290
|
+
if (statusCode === DisconnectReason.restartRequired) {
|
|
291
|
+
reason = 'restart required';
|
|
292
|
+
}
|
|
293
|
+
return {
|
|
294
|
+
reason,
|
|
295
|
+
statusCode
|
|
296
|
+
};
|
|
297
|
+
};
|
|
298
|
+
export const getCallStatusFromNode = ({ tag, attrs }) => {
|
|
299
|
+
let status;
|
|
300
|
+
switch (tag) {
|
|
301
|
+
case 'offer':
|
|
302
|
+
case 'offer_notice':
|
|
303
|
+
status = 'offer';
|
|
304
|
+
break;
|
|
305
|
+
case 'terminate':
|
|
306
|
+
if (attrs.reason === 'timeout') {
|
|
307
|
+
status = 'timeout';
|
|
308
|
+
}
|
|
309
|
+
else {
|
|
310
|
+
//fired when accepted/rejected/timeout/caller hangs up
|
|
311
|
+
status = 'terminate';
|
|
312
|
+
}
|
|
313
|
+
break;
|
|
314
|
+
case 'reject':
|
|
315
|
+
status = 'reject';
|
|
316
|
+
break;
|
|
317
|
+
case 'accept':
|
|
318
|
+
status = 'accept';
|
|
319
|
+
break;
|
|
320
|
+
default:
|
|
321
|
+
status = 'ringing';
|
|
322
|
+
break;
|
|
323
|
+
}
|
|
324
|
+
return status;
|
|
325
|
+
};
|
|
326
|
+
const UNEXPECTED_SERVER_CODE_TEXT = 'Unexpected server response: ';
|
|
327
|
+
export const getCodeFromWSError = (error) => {
|
|
328
|
+
let statusCode = 500;
|
|
329
|
+
if (error?.message?.includes(UNEXPECTED_SERVER_CODE_TEXT)) {
|
|
330
|
+
const code = +error?.message.slice(UNEXPECTED_SERVER_CODE_TEXT.length);
|
|
331
|
+
if (!Number.isNaN(code) && code >= 400) {
|
|
332
|
+
statusCode = code;
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
else if (
|
|
336
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
337
|
+
error?.code?.startsWith('E') ||
|
|
338
|
+
error?.message?.includes('timed out')) {
|
|
339
|
+
// handle ETIMEOUT, ENOTFOUND etc
|
|
340
|
+
statusCode = 408;
|
|
341
|
+
}
|
|
342
|
+
return statusCode;
|
|
343
|
+
};
|
|
344
|
+
/**
|
|
345
|
+
* Is the given platform WA business
|
|
346
|
+
* @param platform AuthenticationCreds.platform
|
|
347
|
+
*/
|
|
348
|
+
export const isWABusinessPlatform = (platform) => {
|
|
349
|
+
return platform === 'smbi' || platform === 'smba';
|
|
350
|
+
};
|
|
351
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
352
|
+
export function trimUndefined(obj) {
|
|
353
|
+
for (const key in obj) {
|
|
354
|
+
if (typeof obj[key] === 'undefined') {
|
|
355
|
+
delete obj[key];
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
return obj;
|
|
359
|
+
}
|
|
360
|
+
const CROCKFORD_CHARACTERS = '123456789ABCDEFGHJKLMNPQRSTVWXYZ';
|
|
361
|
+
export function bytesToCrockford(buffer) {
|
|
362
|
+
let value = 0;
|
|
363
|
+
let bitCount = 0;
|
|
364
|
+
const crockford = [];
|
|
365
|
+
for (const element of buffer) {
|
|
366
|
+
value = (value << 8) | (element & 0xff);
|
|
367
|
+
bitCount += 8;
|
|
368
|
+
while (bitCount >= 5) {
|
|
369
|
+
crockford.push(CROCKFORD_CHARACTERS.charAt((value >>> (bitCount - 5)) & 31));
|
|
370
|
+
bitCount -= 5;
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
if (bitCount > 0) {
|
|
374
|
+
crockford.push(CROCKFORD_CHARACTERS.charAt((value << (5 - bitCount)) & 31));
|
|
375
|
+
}
|
|
376
|
+
return crockford.join('');
|
|
377
|
+
}
|
|
378
|
+
export function encodeNewsletterMessage(message) {
|
|
379
|
+
return proto.Message.encode(message).finish();
|
|
380
|
+
}
|
|
381
|
+
//# sourceMappingURL=generics.js.map
|