@berrysdk/transport 0.1.6
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/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/package.json +58 -0
- package/vendor/WAProto/GenerateStatics.sh +3 -0
- package/vendor/WAProto/WAProto.proto +5479 -0
- package/vendor/WAProto/fix-imports.js +85 -0
- package/vendor/WAProto/index.d.ts +14017 -0
- package/vendor/WAProto/index.js +97691 -0
- package/vendor/lib/Defaults/index.d.ts +75 -0
- package/vendor/lib/Defaults/index.d.ts.map +1 -0
- package/vendor/lib/Defaults/index.js +129 -0
- package/vendor/lib/Defaults/index.js.map +1 -0
- package/vendor/lib/Signal/Group/ciphertext-message.d.ts +10 -0
- package/vendor/lib/Signal/Group/ciphertext-message.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/ciphertext-message.js +12 -0
- package/vendor/lib/Signal/Group/ciphertext-message.js.map +1 -0
- package/vendor/lib/Signal/Group/group-session-builder.d.ts +15 -0
- package/vendor/lib/Signal/Group/group-session-builder.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/group-session-builder.js +30 -0
- package/vendor/lib/Signal/Group/group-session-builder.js.map +1 -0
- package/vendor/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/vendor/lib/Signal/Group/group_cipher.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/group_cipher.js +82 -0
- package/vendor/lib/Signal/Group/group_cipher.js.map +1 -0
- package/vendor/lib/Signal/Group/index.d.ts +12 -0
- package/vendor/lib/Signal/Group/index.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/index.js +12 -0
- package/vendor/lib/Signal/Group/index.js.map +1 -0
- package/vendor/lib/Signal/Group/keyhelper.d.ts +11 -0
- package/vendor/lib/Signal/Group/keyhelper.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/keyhelper.js +18 -0
- package/vendor/lib/Signal/Group/keyhelper.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-chain-key.d.ts +14 -0
- package/vendor/lib/Signal/Group/sender-chain-key.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-chain-key.js +26 -0
- package/vendor/lib/Signal/Group/sender-chain-key.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-distribution-message.d.ts +17 -0
- package/vendor/lib/Signal/Group/sender-key-distribution-message.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-distribution-message.js +63 -0
- package/vendor/lib/Signal/Group/sender-key-distribution-message.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-message.d.ts +19 -0
- package/vendor/lib/Signal/Group/sender-key-message.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-message.js +66 -0
- package/vendor/lib/Signal/Group/sender-key-message.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-name.d.ts +18 -0
- package/vendor/lib/Signal/Group/sender-key-name.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-name.js +48 -0
- package/vendor/lib/Signal/Group/sender-key-name.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-record.d.ts +31 -0
- package/vendor/lib/Signal/Group/sender-key-record.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-record.js +41 -0
- package/vendor/lib/Signal/Group/sender-key-record.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-state.d.ts +39 -0
- package/vendor/lib/Signal/Group/sender-key-state.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-key-state.js +84 -0
- package/vendor/lib/Signal/Group/sender-key-state.js.map +1 -0
- package/vendor/lib/Signal/Group/sender-message-key.d.ts +12 -0
- package/vendor/lib/Signal/Group/sender-message-key.d.ts.map +1 -0
- package/vendor/lib/Signal/Group/sender-message-key.js +26 -0
- package/vendor/lib/Signal/Group/sender-message-key.js.map +1 -0
- package/vendor/lib/Signal/libsignal.d.ts +5 -0
- package/vendor/lib/Signal/libsignal.d.ts.map +1 -0
- package/vendor/lib/Signal/libsignal.js +431 -0
- package/vendor/lib/Signal/libsignal.js.map +1 -0
- package/vendor/lib/Signal/lid-mapping.d.ts +23 -0
- package/vendor/lib/Signal/lid-mapping.d.ts.map +1 -0
- package/vendor/lib/Signal/lid-mapping.js +277 -0
- package/vendor/lib/Signal/lid-mapping.js.map +1 -0
- package/vendor/lib/Socket/Client/index.d.ts +3 -0
- package/vendor/lib/Socket/Client/index.d.ts.map +1 -0
- package/vendor/lib/Socket/Client/index.js +3 -0
- package/vendor/lib/Socket/Client/index.js.map +1 -0
- package/vendor/lib/Socket/Client/types.d.ts +16 -0
- package/vendor/lib/Socket/Client/types.d.ts.map +1 -0
- package/vendor/lib/Socket/Client/types.js +11 -0
- package/vendor/lib/Socket/Client/types.js.map +1 -0
- package/vendor/lib/Socket/Client/websocket.d.ts +13 -0
- package/vendor/lib/Socket/Client/websocket.d.ts.map +1 -0
- package/vendor/lib/Socket/Client/websocket.js +54 -0
- package/vendor/lib/Socket/Client/websocket.js.map +1 -0
- package/vendor/lib/Socket/business.d.ts +217 -0
- package/vendor/lib/Socket/business.d.ts.map +1 -0
- package/vendor/lib/Socket/business.js +379 -0
- package/vendor/lib/Socket/business.js.map +1 -0
- package/vendor/lib/Socket/chats.d.ts +124 -0
- package/vendor/lib/Socket/chats.d.ts.map +1 -0
- package/vendor/lib/Socket/chats.js +1192 -0
- package/vendor/lib/Socket/chats.js.map +1 -0
- package/vendor/lib/Socket/communities.d.ts +273 -0
- package/vendor/lib/Socket/communities.d.ts.map +1 -0
- package/vendor/lib/Socket/communities.js +431 -0
- package/vendor/lib/Socket/communities.js.map +1 -0
- package/vendor/lib/Socket/groups.d.ts +161 -0
- package/vendor/lib/Socket/groups.d.ts.map +1 -0
- package/vendor/lib/Socket/groups.js +347 -0
- package/vendor/lib/Socket/groups.js.map +1 -0
- package/vendor/lib/Socket/index.d.ts +260 -0
- package/vendor/lib/Socket/index.d.ts.map +1 -0
- package/vendor/lib/Socket/index.js +12 -0
- package/vendor/lib/Socket/index.js.map +1 -0
- package/vendor/lib/Socket/messages-recv.d.ts +203 -0
- package/vendor/lib/Socket/messages-recv.d.ts.map +1 -0
- package/vendor/lib/Socket/messages-recv.js +1772 -0
- package/vendor/lib/Socket/messages-recv.js.map +1 -0
- package/vendor/lib/Socket/messages-send.d.ts +199 -0
- package/vendor/lib/Socket/messages-send.d.ts.map +1 -0
- package/vendor/lib/Socket/messages-send.js +1181 -0
- package/vendor/lib/Socket/messages-send.js.map +1 -0
- package/vendor/lib/Socket/mex.d.ts +3 -0
- package/vendor/lib/Socket/mex.d.ts.map +1 -0
- package/vendor/lib/Socket/mex.js +42 -0
- package/vendor/lib/Socket/mex.js.map +1 -0
- package/vendor/lib/Socket/newsletter.d.ts +170 -0
- package/vendor/lib/Socket/newsletter.d.ts.map +1 -0
- package/vendor/lib/Socket/newsletter.js +181 -0
- package/vendor/lib/Socket/newsletter.js.map +1 -0
- package/vendor/lib/Socket/socket.d.ts +59 -0
- package/vendor/lib/Socket/socket.d.ts.map +1 -0
- package/vendor/lib/Socket/socket.js +967 -0
- package/vendor/lib/Socket/socket.js.map +1 -0
- package/vendor/lib/Types/Auth.d.ts +117 -0
- package/vendor/lib/Types/Auth.d.ts.map +1 -0
- package/vendor/lib/Types/Auth.js +2 -0
- package/vendor/lib/Types/Auth.js.map +1 -0
- package/vendor/lib/Types/Bussines.d.ts +25 -0
- package/vendor/lib/Types/Bussines.d.ts.map +1 -0
- package/vendor/lib/Types/Bussines.js +2 -0
- package/vendor/lib/Types/Bussines.js.map +1 -0
- package/vendor/lib/Types/Call.d.ts +15 -0
- package/vendor/lib/Types/Call.d.ts.map +1 -0
- package/vendor/lib/Types/Call.js +2 -0
- package/vendor/lib/Types/Call.js.map +1 -0
- package/vendor/lib/Types/Chat.d.ts +123 -0
- package/vendor/lib/Types/Chat.d.ts.map +1 -0
- package/vendor/lib/Types/Chat.js +8 -0
- package/vendor/lib/Types/Chat.js.map +1 -0
- package/vendor/lib/Types/Contact.d.ts +26 -0
- package/vendor/lib/Types/Contact.d.ts.map +1 -0
- package/vendor/lib/Types/Contact.js +2 -0
- package/vendor/lib/Types/Contact.js.map +1 -0
- package/vendor/lib/Types/Events.d.ts +256 -0
- package/vendor/lib/Types/Events.d.ts.map +1 -0
- package/vendor/lib/Types/Events.js +2 -0
- package/vendor/lib/Types/Events.js.map +1 -0
- package/vendor/lib/Types/GroupMetadata.d.ts +71 -0
- package/vendor/lib/Types/GroupMetadata.d.ts.map +1 -0
- package/vendor/lib/Types/GroupMetadata.js +2 -0
- package/vendor/lib/Types/GroupMetadata.js.map +1 -0
- package/vendor/lib/Types/Label.d.ts +47 -0
- package/vendor/lib/Types/Label.d.ts.map +1 -0
- package/vendor/lib/Types/Label.js +25 -0
- package/vendor/lib/Types/Label.js.map +1 -0
- package/vendor/lib/Types/LabelAssociation.d.ts +30 -0
- package/vendor/lib/Types/LabelAssociation.d.ts.map +1 -0
- package/vendor/lib/Types/LabelAssociation.js +7 -0
- package/vendor/lib/Types/LabelAssociation.js.map +1 -0
- package/vendor/lib/Types/Message.d.ts +322 -0
- package/vendor/lib/Types/Message.d.ts.map +1 -0
- package/vendor/lib/Types/Message.js +11 -0
- package/vendor/lib/Types/Message.js.map +1 -0
- package/vendor/lib/Types/Mex.d.ts +141 -0
- package/vendor/lib/Types/Mex.d.ts.map +1 -0
- package/vendor/lib/Types/Mex.js +37 -0
- package/vendor/lib/Types/Mex.js.map +1 -0
- package/vendor/lib/Types/Product.d.ts +79 -0
- package/vendor/lib/Types/Product.d.ts.map +1 -0
- package/vendor/lib/Types/Product.js +2 -0
- package/vendor/lib/Types/Product.js.map +1 -0
- package/vendor/lib/Types/Signal.d.ts +87 -0
- package/vendor/lib/Types/Signal.d.ts.map +1 -0
- package/vendor/lib/Types/Signal.js +2 -0
- package/vendor/lib/Types/Signal.js.map +1 -0
- package/vendor/lib/Types/Socket.d.ts +136 -0
- package/vendor/lib/Types/Socket.d.ts.map +1 -0
- package/vendor/lib/Types/Socket.js +3 -0
- package/vendor/lib/Types/Socket.js.map +1 -0
- package/vendor/lib/Types/State.d.ts +97 -0
- package/vendor/lib/Types/State.d.ts.map +1 -0
- package/vendor/lib/Types/State.js +56 -0
- package/vendor/lib/Types/State.js.map +1 -0
- package/vendor/lib/Types/USync.d.ts +26 -0
- package/vendor/lib/Types/USync.d.ts.map +1 -0
- package/vendor/lib/Types/USync.js +2 -0
- package/vendor/lib/Types/USync.js.map +1 -0
- package/vendor/lib/Types/index.d.ts +65 -0
- package/vendor/lib/Types/index.d.ts.map +1 -0
- package/vendor/lib/Types/index.js +26 -0
- package/vendor/lib/Types/index.js.map +1 -0
- package/vendor/lib/Utils/auth-utils.d.ts +24 -0
- package/vendor/lib/Utils/auth-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/auth-utils.js +302 -0
- package/vendor/lib/Utils/auth-utils.js.map +1 -0
- package/vendor/lib/Utils/browser-utils.d.ts +4 -0
- package/vendor/lib/Utils/browser-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/browser-utils.js +28 -0
- package/vendor/lib/Utils/browser-utils.js.map +1 -0
- package/vendor/lib/Utils/business.d.ts +23 -0
- package/vendor/lib/Utils/business.d.ts.map +1 -0
- package/vendor/lib/Utils/business.js +231 -0
- package/vendor/lib/Utils/business.js.map +1 -0
- package/vendor/lib/Utils/chat-utils.d.ts +100 -0
- package/vendor/lib/Utils/chat-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/chat-utils.js +872 -0
- package/vendor/lib/Utils/chat-utils.js.map +1 -0
- package/vendor/lib/Utils/companion-reg-client-utils.d.ts +17 -0
- package/vendor/lib/Utils/companion-reg-client-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/companion-reg-client-utils.js +35 -0
- package/vendor/lib/Utils/companion-reg-client-utils.js.map +1 -0
- package/vendor/lib/Utils/crypto.d.ts +37 -0
- package/vendor/lib/Utils/crypto.d.ts.map +1 -0
- package/vendor/lib/Utils/crypto.js +118 -0
- package/vendor/lib/Utils/crypto.js.map +1 -0
- package/vendor/lib/Utils/decode-wa-message.d.ts +66 -0
- package/vendor/lib/Utils/decode-wa-message.d.ts.map +1 -0
- package/vendor/lib/Utils/decode-wa-message.js +311 -0
- package/vendor/lib/Utils/decode-wa-message.js.map +1 -0
- package/vendor/lib/Utils/event-buffer.d.ts +36 -0
- package/vendor/lib/Utils/event-buffer.d.ts.map +1 -0
- package/vendor/lib/Utils/event-buffer.js +622 -0
- package/vendor/lib/Utils/event-buffer.js.map +1 -0
- package/vendor/lib/Utils/generics.d.ts +91 -0
- package/vendor/lib/Utils/generics.d.ts.map +1 -0
- package/vendor/lib/Utils/generics.js +393 -0
- package/vendor/lib/Utils/generics.js.map +1 -0
- package/vendor/lib/Utils/history.d.ts +24 -0
- package/vendor/lib/Utils/history.d.ts.map +1 -0
- package/vendor/lib/Utils/history.js +134 -0
- package/vendor/lib/Utils/history.js.map +1 -0
- package/vendor/lib/Utils/identity-change-handler.d.ts +44 -0
- package/vendor/lib/Utils/identity-change-handler.d.ts.map +1 -0
- package/vendor/lib/Utils/identity-change-handler.js +50 -0
- package/vendor/lib/Utils/identity-change-handler.js.map +1 -0
- package/vendor/lib/Utils/index.d.ts +22 -0
- package/vendor/lib/Utils/index.d.ts.map +1 -0
- package/vendor/lib/Utils/index.js +22 -0
- package/vendor/lib/Utils/index.js.map +1 -0
- package/vendor/lib/Utils/link-preview.d.ts +21 -0
- package/vendor/lib/Utils/link-preview.d.ts.map +1 -0
- package/vendor/lib/Utils/link-preview.js +85 -0
- package/vendor/lib/Utils/link-preview.js.map +1 -0
- package/vendor/lib/Utils/logger.d.ts +12 -0
- package/vendor/lib/Utils/logger.d.ts.map +1 -0
- package/vendor/lib/Utils/logger.js +3 -0
- package/vendor/lib/Utils/logger.js.map +1 -0
- package/vendor/lib/Utils/lt-hash.d.ts +8 -0
- package/vendor/lib/Utils/lt-hash.d.ts.map +1 -0
- package/vendor/lib/Utils/lt-hash.js +8 -0
- package/vendor/lib/Utils/lt-hash.js.map +1 -0
- package/vendor/lib/Utils/make-mutex.d.ts +9 -0
- package/vendor/lib/Utils/make-mutex.d.ts.map +1 -0
- package/vendor/lib/Utils/make-mutex.js +33 -0
- package/vendor/lib/Utils/make-mutex.js.map +1 -0
- package/vendor/lib/Utils/message-retry-manager.d.ts +115 -0
- package/vendor/lib/Utils/message-retry-manager.d.ts.map +1 -0
- package/vendor/lib/Utils/message-retry-manager.js +265 -0
- package/vendor/lib/Utils/message-retry-manager.js.map +1 -0
- package/vendor/lib/Utils/messages-media.d.ts +133 -0
- package/vendor/lib/Utils/messages-media.d.ts.map +1 -0
- package/vendor/lib/Utils/messages-media.js +786 -0
- package/vendor/lib/Utils/messages-media.js.map +1 -0
- package/vendor/lib/Utils/messages.d.ts +91 -0
- package/vendor/lib/Utils/messages.d.ts.map +1 -0
- package/vendor/lib/Utils/messages.js +893 -0
- package/vendor/lib/Utils/messages.js.map +1 -0
- package/vendor/lib/Utils/noise-handler.d.ts +20 -0
- package/vendor/lib/Utils/noise-handler.d.ts.map +1 -0
- package/vendor/lib/Utils/noise-handler.js +201 -0
- package/vendor/lib/Utils/noise-handler.js.map +1 -0
- package/vendor/lib/Utils/offline-node-processor.d.ts +17 -0
- package/vendor/lib/Utils/offline-node-processor.d.ts.map +1 -0
- package/vendor/lib/Utils/offline-node-processor.js +40 -0
- package/vendor/lib/Utils/offline-node-processor.js.map +1 -0
- package/vendor/lib/Utils/pre-key-manager.d.ts +28 -0
- package/vendor/lib/Utils/pre-key-manager.d.ts.map +1 -0
- package/vendor/lib/Utils/pre-key-manager.js +106 -0
- package/vendor/lib/Utils/pre-key-manager.js.map +1 -0
- package/vendor/lib/Utils/process-message.d.ts +60 -0
- package/vendor/lib/Utils/process-message.d.ts.map +1 -0
- package/vendor/lib/Utils/process-message.js +597 -0
- package/vendor/lib/Utils/process-message.js.map +1 -0
- package/vendor/lib/Utils/reporting-utils.d.ts +11 -0
- package/vendor/lib/Utils/reporting-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/reporting-utils.js +258 -0
- package/vendor/lib/Utils/reporting-utils.js.map +1 -0
- package/vendor/lib/Utils/signal.d.ts +47 -0
- package/vendor/lib/Utils/signal.d.ts.map +1 -0
- package/vendor/lib/Utils/signal.js +201 -0
- package/vendor/lib/Utils/signal.js.map +1 -0
- package/vendor/lib/Utils/stanza-ack.d.ts +11 -0
- package/vendor/lib/Utils/stanza-ack.d.ts.map +1 -0
- package/vendor/lib/Utils/stanza-ack.js +38 -0
- package/vendor/lib/Utils/stanza-ack.js.map +1 -0
- package/vendor/lib/Utils/sync-action-utils.d.ts +19 -0
- package/vendor/lib/Utils/sync-action-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/sync-action-utils.js +49 -0
- package/vendor/lib/Utils/sync-action-utils.js.map +1 -0
- package/vendor/lib/Utils/tc-token-utils.d.ts +37 -0
- package/vendor/lib/Utils/tc-token-utils.d.ts.map +1 -0
- package/vendor/lib/Utils/tc-token-utils.js +163 -0
- package/vendor/lib/Utils/tc-token-utils.js.map +1 -0
- package/vendor/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
- package/vendor/lib/Utils/use-multi-file-auth-state.d.ts.map +1 -0
- package/vendor/lib/Utils/use-multi-file-auth-state.js +121 -0
- package/vendor/lib/Utils/use-multi-file-auth-state.js.map +1 -0
- package/vendor/lib/Utils/validate-connection.d.ts +11 -0
- package/vendor/lib/Utils/validate-connection.d.ts.map +1 -0
- package/vendor/lib/Utils/validate-connection.js +203 -0
- package/vendor/lib/Utils/validate-connection.js.map +1 -0
- package/vendor/lib/WABinary/constants.d.ts +28 -0
- package/vendor/lib/WABinary/constants.d.ts.map +1 -0
- package/vendor/lib/WABinary/constants.js +1301 -0
- package/vendor/lib/WABinary/constants.js.map +1 -0
- package/vendor/lib/WABinary/decode.d.ts +7 -0
- package/vendor/lib/WABinary/decode.d.ts.map +1 -0
- package/vendor/lib/WABinary/decode.js +262 -0
- package/vendor/lib/WABinary/decode.js.map +1 -0
- package/vendor/lib/WABinary/encode.d.ts +3 -0
- package/vendor/lib/WABinary/encode.d.ts.map +1 -0
- package/vendor/lib/WABinary/encode.js +220 -0
- package/vendor/lib/WABinary/encode.js.map +1 -0
- package/vendor/lib/WABinary/generic-utils.d.ts +15 -0
- package/vendor/lib/WABinary/generic-utils.d.ts.map +1 -0
- package/vendor/lib/WABinary/generic-utils.js +113 -0
- package/vendor/lib/WABinary/generic-utils.js.map +1 -0
- package/vendor/lib/WABinary/index.d.ts +6 -0
- package/vendor/lib/WABinary/index.d.ts.map +1 -0
- package/vendor/lib/WABinary/index.js +6 -0
- package/vendor/lib/WABinary/index.js.map +1 -0
- package/vendor/lib/WABinary/jid-utils.d.ts +48 -0
- package/vendor/lib/WABinary/jid-utils.d.ts.map +1 -0
- package/vendor/lib/WABinary/jid-utils.js +96 -0
- package/vendor/lib/WABinary/jid-utils.js.map +1 -0
- package/vendor/lib/WABinary/types.d.ts +19 -0
- package/vendor/lib/WABinary/types.d.ts.map +1 -0
- package/vendor/lib/WABinary/types.js +2 -0
- package/vendor/lib/WABinary/types.js.map +1 -0
- package/vendor/lib/WAM/BinaryInfo.d.ts +9 -0
- package/vendor/lib/WAM/BinaryInfo.d.ts.map +1 -0
- package/vendor/lib/WAM/BinaryInfo.js +10 -0
- package/vendor/lib/WAM/BinaryInfo.js.map +1 -0
- package/vendor/lib/WAM/constants.d.ts +40 -0
- package/vendor/lib/WAM/constants.d.ts.map +1 -0
- package/vendor/lib/WAM/constants.js +22853 -0
- package/vendor/lib/WAM/constants.js.map +1 -0
- package/vendor/lib/WAM/encode.d.ts +3 -0
- package/vendor/lib/WAM/encode.d.ts.map +1 -0
- package/vendor/lib/WAM/encode.js +150 -0
- package/vendor/lib/WAM/encode.js.map +1 -0
- package/vendor/lib/WAM/index.d.ts +4 -0
- package/vendor/lib/WAM/index.d.ts.map +1 -0
- package/vendor/lib/WAM/index.js +4 -0
- package/vendor/lib/WAM/index.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +10 -0
- package/vendor/lib/WAUSync/Protocols/USyncContactProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncContactProtocol.js +52 -0
- package/vendor/lib/WAUSync/Protocols/USyncContactProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +23 -0
- package/vendor/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncDeviceProtocol.js +54 -0
- package/vendor/lib/WAUSync/Protocols/USyncDeviceProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +13 -0
- package/vendor/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -0
- package/vendor/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +13 -0
- package/vendor/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncStatusProtocol.js +38 -0
- package/vendor/lib/WAUSync/Protocols/USyncStatusProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +10 -0
- package/vendor/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/USyncUsernameProtocol.js +25 -0
- package/vendor/lib/WAUSync/Protocols/USyncUsernameProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +26 -0
- package/vendor/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +51 -0
- package/vendor/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +10 -0
- package/vendor/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/UsyncLIDProtocol.js +29 -0
- package/vendor/lib/WAUSync/Protocols/UsyncLIDProtocol.js.map +1 -0
- package/vendor/lib/WAUSync/Protocols/index.d.ts +6 -0
- package/vendor/lib/WAUSync/Protocols/index.d.ts.map +1 -0
- package/vendor/lib/WAUSync/Protocols/index.js +6 -0
- package/vendor/lib/WAUSync/Protocols/index.js.map +1 -0
- package/vendor/lib/WAUSync/USyncQuery.d.ts +30 -0
- package/vendor/lib/WAUSync/USyncQuery.d.ts.map +1 -0
- package/vendor/lib/WAUSync/USyncQuery.js +98 -0
- package/vendor/lib/WAUSync/USyncQuery.js.map +1 -0
- package/vendor/lib/WAUSync/USyncUser.d.ts +17 -0
- package/vendor/lib/WAUSync/USyncUser.d.ts.map +1 -0
- package/vendor/lib/WAUSync/USyncUser.js +31 -0
- package/vendor/lib/WAUSync/USyncUser.js.map +1 -0
- package/vendor/lib/WAUSync/index.d.ts +4 -0
- package/vendor/lib/WAUSync/index.d.ts.map +1 -0
- package/vendor/lib/WAUSync/index.js +4 -0
- package/vendor/lib/WAUSync/index.js.map +1 -0
- package/vendor/lib/index.d.ts +12 -0
- package/vendor/lib/index.d.ts.map +1 -0
- package/vendor/lib/index.js +11 -0
- package/vendor/lib/index.js.map +1 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { proto } from '../../WAProto/index.js';
|
|
2
|
+
import { isLidUser, isPnUser } from '../WABinary/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* Process contactAction and return events to emit.
|
|
5
|
+
* Pure function - no side effects.
|
|
6
|
+
*/
|
|
7
|
+
export const processContactAction = (action, id, logger) => {
|
|
8
|
+
const results = [];
|
|
9
|
+
if (!id) {
|
|
10
|
+
logger?.warn({ hasFullName: !!action.fullName, hasLidJid: !!action.lidJid, hasPnJid: !!action.pnJid }, 'contactAction sync: missing id in index');
|
|
11
|
+
return results;
|
|
12
|
+
}
|
|
13
|
+
const lidJid = action.lidJid;
|
|
14
|
+
const idIsPn = isPnUser(id);
|
|
15
|
+
// PN is in index[1], not in contactAction.pnJid which is usually null
|
|
16
|
+
const phoneNumber = idIsPn ? id : action.pnJid || undefined;
|
|
17
|
+
// Always emit contacts.upsert
|
|
18
|
+
results.push({
|
|
19
|
+
event: 'contacts.upsert',
|
|
20
|
+
data: [
|
|
21
|
+
{
|
|
22
|
+
id,
|
|
23
|
+
name: action.fullName || action.firstName || action.username || undefined,
|
|
24
|
+
username: action.username || undefined,
|
|
25
|
+
lid: lidJid || undefined,
|
|
26
|
+
phoneNumber
|
|
27
|
+
}
|
|
28
|
+
]
|
|
29
|
+
});
|
|
30
|
+
// Emit lid-mapping.update if we have valid LID-PN pair
|
|
31
|
+
if (lidJid && isLidUser(lidJid) && idIsPn) {
|
|
32
|
+
results.push({
|
|
33
|
+
event: 'lid-mapping.update',
|
|
34
|
+
data: { lid: lidJid, pn: id }
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
return results;
|
|
38
|
+
};
|
|
39
|
+
export const emitSyncActionResults = (ev, results) => {
|
|
40
|
+
for (const result of results) {
|
|
41
|
+
if (result.event === 'contacts.upsert') {
|
|
42
|
+
ev.emit('contacts.upsert', result.data);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
ev.emit('lid-mapping.update', result.data);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=sync-action-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-action-utils.js","sourceRoot":"","sources":["../../src/Utils/sync-action-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAA;AAE9C,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AAejD;;;GAGG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAG,CACnC,MAA4C,EAC5C,EAAsB,EACtB,MAAgB,EACK,EAAE;IACvB,MAAM,OAAO,GAAuB,EAAE,CAAA;IAEtC,IAAI,CAAC,EAAE,EAAE,CAAC;QACT,MAAM,EAAE,IAAI,CACX,EAAE,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,EACxF,yCAAyC,CACzC,CAAA;QACD,OAAO,OAAO,CAAA;IACf,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAA;IAC5B,MAAM,MAAM,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAC3B,sEAAsE;IACtE,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,SAAS,CAAA;IAE3D,8BAA8B;IAC9B,OAAO,CAAC,IAAI,CAAC;QACZ,KAAK,EAAE,iBAAiB;QACxB,IAAI,EAAE;YACL;gBACC,EAAE;gBACF,IAAI,EAAE,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,QAAQ,IAAI,SAAS;gBACzE,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,SAAS;gBACtC,GAAG,EAAE,MAAM,IAAI,SAAS;gBACxB,WAAW;aACX;SACD;KACD,CAAC,CAAA;IAEF,uDAAuD;IACvD,IAAI,MAAM,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC;YACZ,KAAK,EAAE,oBAAoB;YAC3B,IAAI,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE;SAC7B,CAAC,CAAA;IACH,CAAC;IAED,OAAO,OAAO,CAAA;AACf,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EAAuB,EAAE,OAA2B,EAAQ,EAAE;IACnG,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;QAC9B,IAAI,MAAM,CAAC,KAAK,KAAK,iBAAiB,EAAE,CAAC;YACxC,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,MAAM,CAAC,IAAI,CAAC,CAAA;QACxC,CAAC;aAAM,CAAC;YACP,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,IAAI,CAAC,CAAA;QAC3C,CAAC;IACF,CAAC;AACF,CAAC,CAAA"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { SignalKeyStoreWithTransaction } from '../Types/index.js';
|
|
2
|
+
import type { BinaryNode } from '../WABinary/index.js';
|
|
3
|
+
/** Sentinel key under `tctoken` store holding a JSON array of tracked storage JIDs for cross-session pruning. */
|
|
4
|
+
export declare const TC_TOKEN_INDEX_KEY = "__index";
|
|
5
|
+
/** Read the persisted tctoken JID index and return its entries (never contains the sentinel key itself). */
|
|
6
|
+
export declare function readTcTokenIndex(keys: SignalKeyStoreWithTransaction): Promise<string[]>;
|
|
7
|
+
/** Build a SignalDataSet fragment that writes the merged index (persisted ∪ added) under the sentinel key. */
|
|
8
|
+
export declare function buildMergedTcTokenIndexWrite(keys: SignalKeyStoreWithTransaction, addedJids: Iterable<string>): Promise<{
|
|
9
|
+
[TC_TOKEN_INDEX_KEY]: {
|
|
10
|
+
token: Buffer;
|
|
11
|
+
};
|
|
12
|
+
}>;
|
|
13
|
+
export declare function isTcTokenExpired(timestamp: number | string | null | undefined): boolean;
|
|
14
|
+
export declare function shouldSendNewTcToken(senderTimestamp: number | undefined): boolean;
|
|
15
|
+
/** Resolve JID to LID for tctoken storage (WA Web stores under LID) */
|
|
16
|
+
export declare function resolveTcTokenJid(jid: string, getLIDForPN: (pn: string) => Promise<string | null>): Promise<string>;
|
|
17
|
+
/** Resolve target JID for issuing privacy token based on AB prop 14303 */
|
|
18
|
+
export declare function resolveIssuanceJid(jid: string, issueToLid: boolean, getLIDForPN: (pn: string) => Promise<string | null>, getPNForLID?: (lid: string) => Promise<string | null>): Promise<string>;
|
|
19
|
+
type TcTokenParams = {
|
|
20
|
+
jid: string;
|
|
21
|
+
baseContent?: BinaryNode[];
|
|
22
|
+
authState: {
|
|
23
|
+
keys: SignalKeyStoreWithTransaction;
|
|
24
|
+
};
|
|
25
|
+
getLIDForPN: (pn: string) => Promise<string | null>;
|
|
26
|
+
};
|
|
27
|
+
export declare function buildTcTokenFromJid({ authState, jid, baseContent, getLIDForPN }: TcTokenParams): Promise<BinaryNode[] | undefined>;
|
|
28
|
+
type StoreTcTokensParams = {
|
|
29
|
+
result: BinaryNode;
|
|
30
|
+
fallbackJid: string;
|
|
31
|
+
keys: SignalKeyStoreWithTransaction;
|
|
32
|
+
getLIDForPN: (pn: string) => Promise<string | null>;
|
|
33
|
+
onNewJidStored?: (jid: string) => void;
|
|
34
|
+
};
|
|
35
|
+
export declare function storeTcTokensFromIqResult({ result, fallbackJid, keys, getLIDForPN, onNewJidStored }: StoreTcTokensParams): Promise<void>;
|
|
36
|
+
export {};
|
|
37
|
+
//# sourceMappingURL=tc-token-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tc-token-utils.d.ts","sourceRoot":"","sources":["../../src/Utils/tc-token-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,UAAU,CAAA;AAC7D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAkC7C,iHAAiH;AACjH,eAAO,MAAM,kBAAkB,YAAY,CAAA;AAE3C,4GAA4G;AAC5G,wBAAsB,gBAAgB,CAAC,IAAI,EAAE,6BAA6B,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAW7F;AAED,8GAA8G;AAC9G,wBAAsB,4BAA4B,CACjD,IAAI,EAAE,6BAA6B,EACnC,SAAS,EAAE,QAAQ,CAAC,MAAM,CAAC,GACzB,OAAO,CAAC;IAAE,CAAC,kBAAkB,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC,CAUtD;AAGD,wBAAgB,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS,GAAG,OAAO,CASvF;AAED,wBAAgB,oBAAoB,CAAC,eAAe,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,CAMjF;AAED,uEAAuE;AACvE,wBAAsB,iBAAiB,CACtC,GAAG,EAAE,MAAM,EACX,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,GACjD,OAAO,CAAC,MAAM,CAAC,CAIjB;AAED,0EAA0E;AAC1E,wBAAsB,kBAAkB,CACvC,GAAG,EAAE,MAAM,EACX,UAAU,EAAE,OAAO,EACnB,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,EACnD,WAAW,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,GACnD,OAAO,CAAC,MAAM,CAAC,CAcjB;AAED,KAAK,aAAa,GAAG;IACpB,GAAG,EAAE,MAAM,CAAA;IACX,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,SAAS,EAAE;QACV,IAAI,EAAE,6BAA6B,CAAA;KACnC,CAAA;IACD,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;CACnD,CAAA;AAED,wBAAsB,mBAAmB,CAAC,EACzC,SAAS,EACT,GAAG,EACH,WAAgB,EAChB,WAAW,EACX,EAAE,aAAa,GAAG,OAAO,CAAC,UAAU,EAAE,GAAG,SAAS,CAAC,CAgCnD;AAED,KAAK,mBAAmB,GAAG;IAC1B,MAAM,EAAE,UAAU,CAAA;IAClB,WAAW,EAAE,MAAM,CAAA;IACnB,IAAI,EAAE,6BAA6B,CAAA;IACnC,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IACnD,cAAc,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAA;CACtC,CAAA;AAED,wBAAsB,yBAAyB,CAAC,EAC/C,MAAM,EACN,WAAW,EACX,IAAI,EACJ,WAAW,EACX,cAAc,EACd,EAAE,mBAAmB,iBAkCrB"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { getBinaryNodeChild, getBinaryNodeChildren, isHostedLidUser, isHostedPnUser, isJidMetaAI, isLidUser, isPnUser, jidNormalizedUser } from '../WABinary/index.js';
|
|
2
|
+
// Same phone-number pattern as WABinary's isJidBot, applied against the user
|
|
3
|
+
// part so the check is invariant to @c.us ↔ @s.whatsapp.net normalization.
|
|
4
|
+
const BOT_PHONE_REGEX = /^1313555\d{4}$|^131655500\d{2}$/;
|
|
5
|
+
/**
|
|
6
|
+
* Mirrors WA Web's `Wid.isRegularUser()` (user ∧ ¬PSA ∧ ¬Bot). Used to gate tctoken
|
|
7
|
+
* storage against malformed notifications — WA Web filters server-side but we
|
|
8
|
+
* defend here for parity with `WAWebSetTcTokenChatAction.handleIncomingTcToken`.
|
|
9
|
+
* Works for both pre- and post-normalized JIDs (`@c.us` vs `@s.whatsapp.net`).
|
|
10
|
+
*/
|
|
11
|
+
function isRegularUser(jid) {
|
|
12
|
+
if (!jid)
|
|
13
|
+
return false;
|
|
14
|
+
const user = jid.split('@')[0] ?? '';
|
|
15
|
+
if (user === '0')
|
|
16
|
+
return false; // PSA
|
|
17
|
+
if (BOT_PHONE_REGEX.test(user))
|
|
18
|
+
return false; // Bot by phone pattern
|
|
19
|
+
if (isJidMetaAI(jid))
|
|
20
|
+
return false; // MetaAI (@bot server)
|
|
21
|
+
return !!(isPnUser(jid) || isLidUser(jid) || isHostedPnUser(jid) || isHostedLidUser(jid) || jid.endsWith('@c.us'));
|
|
22
|
+
}
|
|
23
|
+
const TC_TOKEN_BUCKET_DURATION = 604800; // 7 days
|
|
24
|
+
const TC_TOKEN_NUM_BUCKETS = 4; // ~28-day rolling window
|
|
25
|
+
/** Sentinel key under `tctoken` store holding a JSON array of tracked storage JIDs for cross-session pruning. */
|
|
26
|
+
export const TC_TOKEN_INDEX_KEY = '__index';
|
|
27
|
+
/** Read the persisted tctoken JID index and return its entries (never contains the sentinel key itself). */
|
|
28
|
+
export async function readTcTokenIndex(keys) {
|
|
29
|
+
const data = await keys.get('tctoken', [TC_TOKEN_INDEX_KEY]);
|
|
30
|
+
const entry = data[TC_TOKEN_INDEX_KEY];
|
|
31
|
+
if (!entry?.token?.length)
|
|
32
|
+
return [];
|
|
33
|
+
try {
|
|
34
|
+
const parsed = JSON.parse(Buffer.from(entry.token).toString());
|
|
35
|
+
if (!Array.isArray(parsed))
|
|
36
|
+
return [];
|
|
37
|
+
return parsed.filter((j) => typeof j === 'string' && j.length > 0 && j !== TC_TOKEN_INDEX_KEY);
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return [];
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/** Build a SignalDataSet fragment that writes the merged index (persisted ∪ added) under the sentinel key. */
|
|
44
|
+
export async function buildMergedTcTokenIndexWrite(keys, addedJids) {
|
|
45
|
+
const persisted = await readTcTokenIndex(keys);
|
|
46
|
+
const merged = new Set(persisted);
|
|
47
|
+
for (const jid of addedJids) {
|
|
48
|
+
if (jid && jid !== TC_TOKEN_INDEX_KEY)
|
|
49
|
+
merged.add(jid);
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
[TC_TOKEN_INDEX_KEY]: { token: Buffer.from(JSON.stringify([...merged])) }
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
// WA Web has separate sender/receiver AB props for these but they're identical today
|
|
56
|
+
export function isTcTokenExpired(timestamp) {
|
|
57
|
+
if (timestamp === null || timestamp === undefined)
|
|
58
|
+
return true;
|
|
59
|
+
const ts = typeof timestamp === 'string' ? parseInt(timestamp) : timestamp;
|
|
60
|
+
if (isNaN(ts))
|
|
61
|
+
return true;
|
|
62
|
+
const now = Math.floor(Date.now() / 1000);
|
|
63
|
+
const currentBucket = Math.floor(now / TC_TOKEN_BUCKET_DURATION);
|
|
64
|
+
const cutoffBucket = currentBucket - (TC_TOKEN_NUM_BUCKETS - 1);
|
|
65
|
+
const cutoffTimestamp = cutoffBucket * TC_TOKEN_BUCKET_DURATION;
|
|
66
|
+
return ts < cutoffTimestamp;
|
|
67
|
+
}
|
|
68
|
+
export function shouldSendNewTcToken(senderTimestamp) {
|
|
69
|
+
if (senderTimestamp === undefined)
|
|
70
|
+
return true;
|
|
71
|
+
const now = Math.floor(Date.now() / 1000);
|
|
72
|
+
const currentBucket = Math.floor(now / TC_TOKEN_BUCKET_DURATION);
|
|
73
|
+
const senderBucket = Math.floor(senderTimestamp / TC_TOKEN_BUCKET_DURATION);
|
|
74
|
+
return currentBucket > senderBucket;
|
|
75
|
+
}
|
|
76
|
+
/** Resolve JID to LID for tctoken storage (WA Web stores under LID) */
|
|
77
|
+
export async function resolveTcTokenJid(jid, getLIDForPN) {
|
|
78
|
+
if (isLidUser(jid))
|
|
79
|
+
return jid;
|
|
80
|
+
const lid = await getLIDForPN(jid);
|
|
81
|
+
return lid ?? jid;
|
|
82
|
+
}
|
|
83
|
+
/** Resolve target JID for issuing privacy token based on AB prop 14303 */
|
|
84
|
+
export async function resolveIssuanceJid(jid, issueToLid, getLIDForPN, getPNForLID) {
|
|
85
|
+
if (issueToLid) {
|
|
86
|
+
if (isLidUser(jid))
|
|
87
|
+
return jid;
|
|
88
|
+
const lid = await getLIDForPN(jid);
|
|
89
|
+
return lid ?? jid;
|
|
90
|
+
}
|
|
91
|
+
if (!isLidUser(jid))
|
|
92
|
+
return jid;
|
|
93
|
+
if (getPNForLID) {
|
|
94
|
+
const pn = await getPNForLID(jid);
|
|
95
|
+
return pn ?? jid;
|
|
96
|
+
}
|
|
97
|
+
return jid;
|
|
98
|
+
}
|
|
99
|
+
export async function buildTcTokenFromJid({ authState, jid, baseContent = [], getLIDForPN }) {
|
|
100
|
+
try {
|
|
101
|
+
const storageJid = await resolveTcTokenJid(jid, getLIDForPN);
|
|
102
|
+
const tcTokenData = await authState.keys.get('tctoken', [storageJid]);
|
|
103
|
+
const entry = tcTokenData?.[storageJid];
|
|
104
|
+
const tcTokenBuffer = entry?.token;
|
|
105
|
+
if (!tcTokenBuffer?.length || isTcTokenExpired(entry?.timestamp)) {
|
|
106
|
+
if (tcTokenBuffer) {
|
|
107
|
+
// Preserve senderTimestamp so shouldSendNewTcToken() keeps its dedupe state
|
|
108
|
+
// after we drop the unusable peer token. Only wipe the record entirely when
|
|
109
|
+
// there's nothing worth keeping.
|
|
110
|
+
const cleared = entry?.senderTimestamp !== undefined
|
|
111
|
+
? { token: Buffer.alloc(0), senderTimestamp: entry.senderTimestamp }
|
|
112
|
+
: null;
|
|
113
|
+
await authState.keys.set({ tctoken: { [storageJid]: cleared } });
|
|
114
|
+
}
|
|
115
|
+
return baseContent.length > 0 ? baseContent : undefined;
|
|
116
|
+
}
|
|
117
|
+
baseContent.push({
|
|
118
|
+
tag: 'tctoken',
|
|
119
|
+
attrs: {},
|
|
120
|
+
content: tcTokenBuffer
|
|
121
|
+
});
|
|
122
|
+
return baseContent;
|
|
123
|
+
}
|
|
124
|
+
catch (error) {
|
|
125
|
+
return baseContent.length > 0 ? baseContent : undefined;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
export async function storeTcTokensFromIqResult({ result, fallbackJid, keys, getLIDForPN, onNewJidStored }) {
|
|
129
|
+
const tokensNode = getBinaryNodeChild(result, 'tokens');
|
|
130
|
+
if (!tokensNode)
|
|
131
|
+
return;
|
|
132
|
+
const tokenNodes = getBinaryNodeChildren(tokensNode, 'token');
|
|
133
|
+
for (const tokenNode of tokenNodes) {
|
|
134
|
+
if (tokenNode.attrs.type !== 'trusted_contact' || !(tokenNode.content instanceof Uint8Array)) {
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
// In notifications tokenNode.attrs.jid is your own device JID, not the sender's
|
|
138
|
+
const rawJid = jidNormalizedUser(fallbackJid || tokenNode.attrs.jid);
|
|
139
|
+
if (!isRegularUser(rawJid))
|
|
140
|
+
continue;
|
|
141
|
+
const storageJid = await resolveTcTokenJid(rawJid, getLIDForPN);
|
|
142
|
+
const existingTcData = await keys.get('tctoken', [storageJid]);
|
|
143
|
+
const existingEntry = existingTcData[storageJid];
|
|
144
|
+
const existingTs = existingEntry?.timestamp ? Number(existingEntry.timestamp) : 0;
|
|
145
|
+
const incomingTs = tokenNode.attrs.t ? Number(tokenNode.attrs.t) : 0;
|
|
146
|
+
// timestamp-less tokens would be immediately expired
|
|
147
|
+
if (!incomingTs)
|
|
148
|
+
continue;
|
|
149
|
+
if (existingTs > 0 && existingTs > incomingTs)
|
|
150
|
+
continue;
|
|
151
|
+
await keys.set({
|
|
152
|
+
tctoken: {
|
|
153
|
+
[storageJid]: {
|
|
154
|
+
...existingEntry,
|
|
155
|
+
token: Buffer.from(tokenNode.content),
|
|
156
|
+
timestamp: tokenNode.attrs.t
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
onNewJidStored?.(storageJid);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=tc-token-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tc-token-utils.js","sourceRoot":"","sources":["../../src/Utils/tc-token-utils.ts"],"names":[],"mappings":"AAEA,OAAO,EACN,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,cAAc,EACd,WAAW,EACX,SAAS,EACT,QAAQ,EACR,iBAAiB,EACjB,MAAM,aAAa,CAAA;AAEpB,6EAA6E;AAC7E,2EAA2E;AAC3E,MAAM,eAAe,GAAG,iCAAiC,CAAA;AAEzD;;;;;GAKG;AACH,SAAS,aAAa,CAAC,GAAuB;IAC7C,IAAI,CAAC,GAAG;QAAE,OAAO,KAAK,CAAA;IACtB,MAAM,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAA;IACpC,IAAI,IAAI,KAAK,GAAG;QAAE,OAAO,KAAK,CAAA,CAAC,MAAM;IACrC,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;QAAE,OAAO,KAAK,CAAA,CAAC,uBAAuB;IACpE,IAAI,WAAW,CAAC,GAAG,CAAC;QAAE,OAAO,KAAK,CAAA,CAAC,uBAAuB;IAC1D,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,IAAI,cAAc,CAAC,GAAG,CAAC,IAAI,eAAe,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAA;AACnH,CAAC;AAED,MAAM,wBAAwB,GAAG,MAAM,CAAA,CAAC,SAAS;AACjD,MAAM,oBAAoB,GAAG,CAAC,CAAA,CAAC,yBAAyB;AAExD,iHAAiH;AACjH,MAAM,CAAC,MAAM,kBAAkB,GAAG,SAAS,CAAA;AAE3C,4GAA4G;AAC5G,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAAmC;IACzE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAA;IAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAA;IACtC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM;QAAE,OAAO,EAAE,CAAA;IACpC,IAAI,CAAC;QACJ,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAA;QAC9D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YAAE,OAAO,EAAE,CAAA;QACrC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAe,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,KAAK,kBAAkB,CAAC,CAAA;IAC5G,CAAC;IAAC,MAAM,CAAC;QACR,OAAO,EAAE,CAAA;IACV,CAAC;AACF,CAAC;AAED,8GAA8G;AAC9G,MAAM,CAAC,KAAK,UAAU,4BAA4B,CACjD,IAAmC,EACnC,SAA2B;IAE3B,MAAM,SAAS,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAA;IAC9C,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,SAAS,CAAC,CAAA;IACjC,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;QAC7B,IAAI,GAAG,IAAI,GAAG,KAAK,kBAAkB;YAAE,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IACvD,CAAC;IAED,OAAO;QACN,CAAC,kBAAkB,CAAC,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE;KACzE,CAAA;AACF,CAAC;AAED,qFAAqF;AACrF,MAAM,UAAU,gBAAgB,CAAC,SAA6C;IAC7E,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,SAAS;QAAE,OAAO,IAAI,CAAA;IAC9D,MAAM,EAAE,GAAG,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAC1E,IAAI,KAAK,CAAC,EAAE,CAAC;QAAE,OAAO,IAAI,CAAA;IAC1B,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAA;IACzC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,wBAAwB,CAAC,CAAA;IAChE,MAAM,YAAY,GAAG,aAAa,GAAG,CAAC,oBAAoB,GAAG,CAAC,CAAC,CAAA;IAC/D,MAAM,eAAe,GAAG,YAAY,GAAG,wBAAwB,CAAA;IAC/D,OAAO,EAAE,GAAG,eAAe,CAAA;AAC5B,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,eAAmC;IACvE,IAAI,eAAe,KAAK,SAAS;QAAE,OAAO,IAAI,CAAA;IAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAA;IACzC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,wBAAwB,CAAC,CAAA;IAChE,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,wBAAwB,CAAC,CAAA;IAC3E,OAAO,aAAa,GAAG,YAAY,CAAA;AACpC,CAAC;AAED,uEAAuE;AACvE,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACtC,GAAW,EACX,WAAmD;IAEnD,IAAI,SAAS,CAAC,GAAG,CAAC;QAAE,OAAO,GAAG,CAAA;IAC9B,MAAM,GAAG,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,CAAA;IAClC,OAAO,GAAG,IAAI,GAAG,CAAA;AAClB,CAAC;AAED,0EAA0E;AAC1E,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACvC,GAAW,EACX,UAAmB,EACnB,WAAmD,EACnD,WAAqD;IAErD,IAAI,UAAU,EAAE,CAAC;QAChB,IAAI,SAAS,CAAC,GAAG,CAAC;YAAE,OAAO,GAAG,CAAA;QAC9B,MAAM,GAAG,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,CAAA;QAClC,OAAO,GAAG,IAAI,GAAG,CAAA;IAClB,CAAC;IAED,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;QAAE,OAAO,GAAG,CAAA;IAC/B,IAAI,WAAW,EAAE,CAAC;QACjB,MAAM,EAAE,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,CAAA;QACjC,OAAO,EAAE,IAAI,GAAG,CAAA;IACjB,CAAC;IAED,OAAO,GAAG,CAAA;AACX,CAAC;AAWD,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,EACzC,SAAS,EACT,GAAG,EACH,WAAW,GAAG,EAAE,EAChB,WAAW,EACI;IACf,IAAI,CAAC;QACJ,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,GAAG,EAAE,WAAW,CAAC,CAAA;QAC5D,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;QACrE,MAAM,KAAK,GAAG,WAAW,EAAE,CAAC,UAAU,CAAC,CAAA;QACvC,MAAM,aAAa,GAAG,KAAK,EAAE,KAAK,CAAA;QAElC,IAAI,CAAC,aAAa,EAAE,MAAM,IAAI,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,CAAC;YAClE,IAAI,aAAa,EAAE,CAAC;gBACnB,4EAA4E;gBAC5E,4EAA4E;gBAC5E,iCAAiC;gBACjC,MAAM,OAAO,GACZ,KAAK,EAAE,eAAe,KAAK,SAAS;oBACnC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,eAAe,EAAE;oBACpE,CAAC,CAAC,IAAI,CAAA;gBACR,MAAM,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,CAAA;YACjE,CAAC;YAED,OAAO,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAA;QACxD,CAAC;QAED,WAAW,CAAC,IAAI,CAAC;YAChB,GAAG,EAAE,SAAS;YACd,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,aAAa;SACtB,CAAC,CAAA;QAEF,OAAO,WAAW,CAAA;IACnB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAChB,OAAO,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAA;IACxD,CAAC;AACF,CAAC;AAUD,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAAC,EAC/C,MAAM,EACN,WAAW,EACX,IAAI,EACJ,WAAW,EACX,cAAc,EACO;IACrB,MAAM,UAAU,GAAG,kBAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;IACvD,IAAI,CAAC,UAAU;QAAE,OAAM;IAEvB,MAAM,UAAU,GAAG,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAA;IAC7D,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACpC,IAAI,SAAS,CAAC,KAAK,CAAC,IAAI,KAAK,iBAAiB,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,YAAY,UAAU,CAAC,EAAE,CAAC;YAC9F,SAAQ;QACT,CAAC;QAED,gFAAgF;QAChF,MAAM,MAAM,GAAG,iBAAiB,CAAC,WAAW,IAAI,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACpE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YAAE,SAAQ;QACpC,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAA;QAC/D,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;QAC9D,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,CAAA;QAEhD,MAAM,UAAU,GAAG,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACjF,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACpE,qDAAqD;QACrD,IAAI,CAAC,UAAU;YAAE,SAAQ;QACzB,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,UAAU;YAAE,SAAQ;QAEvD,MAAM,IAAI,CAAC,GAAG,CAAC;YACd,OAAO,EAAE;gBACR,CAAC,UAAU,CAAC,EAAE;oBACb,GAAG,aAAa;oBAChB,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;oBACrC,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;iBAC5B;aACD;SACD,CAAC,CAAA;QACF,cAAc,EAAE,CAAC,UAAU,CAAC,CAAA;IAC7B,CAAC;AACF,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AuthenticationState } from '../Types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* stores the full authentication state in a single folder.
|
|
4
|
+
* Far more efficient than singlefileauthstate
|
|
5
|
+
*
|
|
6
|
+
* Again, I wouldn't endorse this for any production level use other than perhaps a bot.
|
|
7
|
+
* Would recommend writing an auth state for use with a proper SQL or No-SQL DB
|
|
8
|
+
* */
|
|
9
|
+
export declare const useMultiFileAuthState: (folder: string) => Promise<{
|
|
10
|
+
state: AuthenticationState;
|
|
11
|
+
saveCreds: () => Promise<void>;
|
|
12
|
+
}>;
|
|
13
|
+
//# sourceMappingURL=use-multi-file-auth-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-multi-file-auth-state.d.ts","sourceRoot":"","sources":["../../src/Utils/use-multi-file-auth-state.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAuB,mBAAmB,EAAqB,MAAM,UAAU,CAAA;AAqB3F;;;;;;KAMK;AACL,eAAO,MAAM,qBAAqB,GACjC,QAAQ,MAAM,KACZ,OAAO,CAAC;IAAE,KAAK,EAAE,mBAAmB,CAAC;IAAC,SAAS,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAAE,CAqGxE,CAAA"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { Mutex } from 'async-mutex';
|
|
2
|
+
import { mkdir, readFile, stat, unlink, writeFile } from 'fs/promises';
|
|
3
|
+
import { join } from 'path';
|
|
4
|
+
import { proto } from '../../WAProto/index.js';
|
|
5
|
+
import { initAuthCreds } from './auth-utils.js';
|
|
6
|
+
import { BufferJSON } from './generics.js';
|
|
7
|
+
// We need to lock files due to the fact that we are using async functions to read and write files
|
|
8
|
+
// https://github.com/WhiskeySockets/Baileys/issues/794
|
|
9
|
+
// https://github.com/nodejs/node/issues/26338
|
|
10
|
+
// Use a Map to store mutexes for each file path
|
|
11
|
+
const fileLocks = new Map();
|
|
12
|
+
// Get or create a mutex for a specific file path
|
|
13
|
+
const getFileLock = (path) => {
|
|
14
|
+
let mutex = fileLocks.get(path);
|
|
15
|
+
if (!mutex) {
|
|
16
|
+
mutex = new Mutex();
|
|
17
|
+
fileLocks.set(path, mutex);
|
|
18
|
+
}
|
|
19
|
+
return mutex;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* stores the full authentication state in a single folder.
|
|
23
|
+
* Far more efficient than singlefileauthstate
|
|
24
|
+
*
|
|
25
|
+
* Again, I wouldn't endorse this for any production level use other than perhaps a bot.
|
|
26
|
+
* Would recommend writing an auth state for use with a proper SQL or No-SQL DB
|
|
27
|
+
* */
|
|
28
|
+
export const useMultiFileAuthState = async (folder) => {
|
|
29
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
30
|
+
const writeData = async (data, file) => {
|
|
31
|
+
const filePath = join(folder, fixFileName(file));
|
|
32
|
+
const mutex = getFileLock(filePath);
|
|
33
|
+
return mutex.acquire().then(async (release) => {
|
|
34
|
+
try {
|
|
35
|
+
await writeFile(filePath, JSON.stringify(data, BufferJSON.replacer));
|
|
36
|
+
}
|
|
37
|
+
finally {
|
|
38
|
+
release();
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
const readData = async (file) => {
|
|
43
|
+
try {
|
|
44
|
+
const filePath = join(folder, fixFileName(file));
|
|
45
|
+
const mutex = getFileLock(filePath);
|
|
46
|
+
return await mutex.acquire().then(async (release) => {
|
|
47
|
+
try {
|
|
48
|
+
const data = await readFile(filePath, { encoding: 'utf-8' });
|
|
49
|
+
return JSON.parse(data, BufferJSON.reviver);
|
|
50
|
+
}
|
|
51
|
+
finally {
|
|
52
|
+
release();
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
const removeData = async (file) => {
|
|
61
|
+
try {
|
|
62
|
+
const filePath = join(folder, fixFileName(file));
|
|
63
|
+
const mutex = getFileLock(filePath);
|
|
64
|
+
return mutex.acquire().then(async (release) => {
|
|
65
|
+
try {
|
|
66
|
+
await unlink(filePath);
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
}
|
|
70
|
+
finally {
|
|
71
|
+
release();
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
catch { }
|
|
76
|
+
};
|
|
77
|
+
const folderInfo = await stat(folder).catch(() => { });
|
|
78
|
+
if (folderInfo) {
|
|
79
|
+
if (!folderInfo.isDirectory()) {
|
|
80
|
+
throw new Error(`found something that is not a directory at ${folder}, either delete it or specify a different location`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
await mkdir(folder, { recursive: true });
|
|
85
|
+
}
|
|
86
|
+
const fixFileName = (file) => file?.replace(/\//g, '__')?.replace(/:/g, '-');
|
|
87
|
+
const creds = (await readData('creds.json')) || initAuthCreds();
|
|
88
|
+
return {
|
|
89
|
+
state: {
|
|
90
|
+
creds,
|
|
91
|
+
keys: {
|
|
92
|
+
get: async (type, ids) => {
|
|
93
|
+
const data = {};
|
|
94
|
+
await Promise.all(ids.map(async (id) => {
|
|
95
|
+
let value = await readData(`${type}-${id}.json`);
|
|
96
|
+
if (type === 'app-state-sync-key' && value) {
|
|
97
|
+
value = proto.Message.AppStateSyncKeyData.fromObject(value);
|
|
98
|
+
}
|
|
99
|
+
data[id] = value;
|
|
100
|
+
}));
|
|
101
|
+
return data;
|
|
102
|
+
},
|
|
103
|
+
set: async (data) => {
|
|
104
|
+
const tasks = [];
|
|
105
|
+
for (const category in data) {
|
|
106
|
+
for (const id in data[category]) {
|
|
107
|
+
const value = data[category][id];
|
|
108
|
+
const file = `${category}-${id}.json`;
|
|
109
|
+
tasks.push(value ? writeData(value, file) : removeData(file));
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
await Promise.all(tasks);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
saveCreds: async () => {
|
|
117
|
+
return writeData(creds, 'creds.json');
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
};
|
|
121
|
+
//# sourceMappingURL=use-multi-file-auth-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-multi-file-auth-state.js","sourceRoot":"","sources":["../../src/Utils/use-multi-file-auth-state.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { proto } from '../../WAProto/index.js';
|
|
2
|
+
import type { AuthenticationCreds, SignalCreds, SocketConfig } from '../Types/index.js';
|
|
3
|
+
import { type BinaryNode } from '../WABinary/index.js';
|
|
4
|
+
export declare const generateLoginNode: (userJid: string, config: SocketConfig) => proto.IClientPayload;
|
|
5
|
+
export declare const generateRegistrationNode: ({ registrationId, signedPreKey, signedIdentityKey }: SignalCreds, config: SocketConfig) => proto.ClientPayload;
|
|
6
|
+
export declare const configureSuccessfulPairing: (stanza: BinaryNode, { advSecretKey, signedIdentityKey, signalIdentities }: Pick<AuthenticationCreds, "advSecretKey" | "signedIdentityKey" | "signalIdentities">) => {
|
|
7
|
+
creds: Partial<AuthenticationCreds>;
|
|
8
|
+
reply: BinaryNode;
|
|
9
|
+
};
|
|
10
|
+
export declare const encodeSignedDeviceIdentity: (account: proto.IADVSignedDeviceIdentity, includeSignatureKey: boolean) => Uint8Array<ArrayBufferLike>;
|
|
11
|
+
//# sourceMappingURL=validate-connection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-connection.d.ts","sourceRoot":"","sources":["../../src/Utils/validate-connection.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAA;AAO9C,OAAO,KAAK,EAAE,mBAAmB,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAC9E,OAAO,EAAE,KAAK,UAAU,EAAiD,MAAM,aAAa,CAAA;AA2D5F,eAAO,MAAM,iBAAiB,GAAI,SAAS,MAAM,EAAE,QAAQ,YAAY,KAAG,KAAK,CAAC,cAY/E,CAAA;AAUD,eAAO,MAAM,wBAAwB,GACpC,qDAAqD,WAAW,EAChE,QAAQ,YAAY,wBAuDpB,CAAA;AAED,eAAO,MAAM,0BAA0B,GACtC,QAAQ,UAAU,EAClB,uDAIG,IAAI,CAAC,mBAAmB,EAAE,cAAc,GAAG,mBAAmB,GAAG,kBAAkB,CAAC;;;CAyFvF,CAAA;AAED,eAAO,MAAM,0BAA0B,GAAI,SAAS,KAAK,CAAC,wBAAwB,EAAE,qBAAqB,OAAO,gCAS/G,CAAA"}
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
import { Boom } from '@hapi/boom';
|
|
2
|
+
import { createHash } from 'crypto';
|
|
3
|
+
import { proto } from '../../WAProto/index.js';
|
|
4
|
+
import { KEY_BUNDLE_TYPE, WA_ADV_ACCOUNT_SIG_PREFIX, WA_ADV_DEVICE_SIG_PREFIX, WA_ADV_HOSTED_ACCOUNT_SIG_PREFIX } from '../Defaults/index.js';
|
|
5
|
+
import { getBinaryNodeChild, jidDecode, S_WHATSAPP_NET } from '../WABinary/index.js';
|
|
6
|
+
import { Curve, hmacSign } from './crypto.js';
|
|
7
|
+
import { encodeBigEndian } from './generics.js';
|
|
8
|
+
import { createSignalIdentity } from './signal.js';
|
|
9
|
+
const getUserAgent = (config) => {
|
|
10
|
+
return {
|
|
11
|
+
appVersion: {
|
|
12
|
+
primary: config.version[0],
|
|
13
|
+
secondary: config.version[1],
|
|
14
|
+
tertiary: config.version[2]
|
|
15
|
+
},
|
|
16
|
+
platform: proto.ClientPayload.UserAgent.Platform.WEB,
|
|
17
|
+
releaseChannel: proto.ClientPayload.UserAgent.ReleaseChannel.RELEASE,
|
|
18
|
+
osVersion: '0.1',
|
|
19
|
+
device: 'Desktop',
|
|
20
|
+
osBuildNumber: '0.1',
|
|
21
|
+
localeLanguageIso6391: 'en',
|
|
22
|
+
mnc: '000',
|
|
23
|
+
mcc: '000',
|
|
24
|
+
localeCountryIso31661Alpha2: config.countryCode
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
const PLATFORM_MAP = {
|
|
28
|
+
'Mac OS': proto.ClientPayload.WebInfo.WebSubPlatform.DARWIN,
|
|
29
|
+
Windows: proto.ClientPayload.WebInfo.WebSubPlatform.WIN32
|
|
30
|
+
};
|
|
31
|
+
const getWebInfo = (config) => {
|
|
32
|
+
let webSubPlatform = proto.ClientPayload.WebInfo.WebSubPlatform.WEB_BROWSER;
|
|
33
|
+
if (config.syncFullHistory &&
|
|
34
|
+
PLATFORM_MAP[config.browser[0]] &&
|
|
35
|
+
config.browser[1] === 'Desktop') {
|
|
36
|
+
webSubPlatform = PLATFORM_MAP[config.browser[0]];
|
|
37
|
+
}
|
|
38
|
+
return { webSubPlatform };
|
|
39
|
+
};
|
|
40
|
+
const getClientPayload = (config) => {
|
|
41
|
+
const payload = {
|
|
42
|
+
connectType: proto.ClientPayload.ConnectType.WIFI_UNKNOWN,
|
|
43
|
+
connectReason: proto.ClientPayload.ConnectReason.USER_ACTIVATED,
|
|
44
|
+
userAgent: getUserAgent(config)
|
|
45
|
+
};
|
|
46
|
+
payload.webInfo = getWebInfo(config);
|
|
47
|
+
if (config.pushName) {
|
|
48
|
+
payload.pushName = config.pushName;
|
|
49
|
+
}
|
|
50
|
+
return payload;
|
|
51
|
+
};
|
|
52
|
+
export const generateLoginNode = (userJid, config) => {
|
|
53
|
+
const { user, device } = jidDecode(userJid);
|
|
54
|
+
const payload = {
|
|
55
|
+
...getClientPayload(config),
|
|
56
|
+
passive: true,
|
|
57
|
+
pull: true,
|
|
58
|
+
username: +user,
|
|
59
|
+
device: device,
|
|
60
|
+
// TODO: investigate (hard set as false atm)
|
|
61
|
+
lidDbMigrated: false
|
|
62
|
+
};
|
|
63
|
+
return proto.ClientPayload.fromObject(payload);
|
|
64
|
+
};
|
|
65
|
+
const getPlatformType = (platform) => {
|
|
66
|
+
const platformType = platform.toUpperCase();
|
|
67
|
+
return (proto.DeviceProps.PlatformType[platformType] ||
|
|
68
|
+
proto.DeviceProps.PlatformType.CHROME);
|
|
69
|
+
};
|
|
70
|
+
export const generateRegistrationNode = ({ registrationId, signedPreKey, signedIdentityKey }, config) => {
|
|
71
|
+
// the app version needs to be md5 hashed
|
|
72
|
+
// and passed in
|
|
73
|
+
const appVersionBuf = createHash('md5')
|
|
74
|
+
.update(config.version.join('.')) // join as string
|
|
75
|
+
.digest();
|
|
76
|
+
const companion = {
|
|
77
|
+
os: config.browser[0],
|
|
78
|
+
platformType: getPlatformType(config.browser[1]),
|
|
79
|
+
requireFullSync: config.syncFullHistory,
|
|
80
|
+
historySyncConfig: {
|
|
81
|
+
storageQuotaMb: 10240,
|
|
82
|
+
inlineInitialPayloadInE2EeMsg: true,
|
|
83
|
+
recentSyncDaysLimit: undefined,
|
|
84
|
+
supportCallLogHistory: false,
|
|
85
|
+
supportBotUserAgentChatHistory: true,
|
|
86
|
+
supportCagReactionsAndPolls: true,
|
|
87
|
+
supportBizHostedMsg: true,
|
|
88
|
+
supportRecentSyncChunkMessageCountTuning: true,
|
|
89
|
+
supportHostedGroupMsg: true,
|
|
90
|
+
supportFbidBotChatHistory: true,
|
|
91
|
+
supportAddOnHistorySyncMigration: undefined,
|
|
92
|
+
supportMessageAssociation: true,
|
|
93
|
+
supportGroupHistory: false,
|
|
94
|
+
onDemandReady: undefined,
|
|
95
|
+
supportGuestChat: undefined
|
|
96
|
+
},
|
|
97
|
+
version: {
|
|
98
|
+
primary: 10,
|
|
99
|
+
secondary: 15,
|
|
100
|
+
tertiary: 7
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
const companionProto = proto.DeviceProps.encode(companion).finish();
|
|
104
|
+
const registerPayload = {
|
|
105
|
+
...getClientPayload(config),
|
|
106
|
+
passive: false,
|
|
107
|
+
pull: false,
|
|
108
|
+
devicePairingData: {
|
|
109
|
+
buildHash: appVersionBuf,
|
|
110
|
+
deviceProps: companionProto,
|
|
111
|
+
eRegid: encodeBigEndian(registrationId),
|
|
112
|
+
eKeytype: KEY_BUNDLE_TYPE,
|
|
113
|
+
eIdent: signedIdentityKey.public,
|
|
114
|
+
eSkeyId: encodeBigEndian(signedPreKey.keyId, 3),
|
|
115
|
+
eSkeyVal: signedPreKey.keyPair.public,
|
|
116
|
+
eSkeySig: signedPreKey.signature
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
return proto.ClientPayload.fromObject(registerPayload);
|
|
120
|
+
};
|
|
121
|
+
export const configureSuccessfulPairing = (stanza, { advSecretKey, signedIdentityKey, signalIdentities }) => {
|
|
122
|
+
const msgId = stanza.attrs.id;
|
|
123
|
+
const pairSuccessNode = getBinaryNodeChild(stanza, 'pair-success');
|
|
124
|
+
const deviceIdentityNode = getBinaryNodeChild(pairSuccessNode, 'device-identity');
|
|
125
|
+
const platformNode = getBinaryNodeChild(pairSuccessNode, 'platform');
|
|
126
|
+
const deviceNode = getBinaryNodeChild(pairSuccessNode, 'device');
|
|
127
|
+
const businessNode = getBinaryNodeChild(pairSuccessNode, 'biz');
|
|
128
|
+
if (!deviceIdentityNode || !deviceNode) {
|
|
129
|
+
throw new Boom('Missing device-identity or device in pair success node', { data: stanza });
|
|
130
|
+
}
|
|
131
|
+
const bizName = businessNode?.attrs.name;
|
|
132
|
+
const jid = deviceNode.attrs.jid;
|
|
133
|
+
const lid = deviceNode.attrs.lid;
|
|
134
|
+
const { details, hmac, accountType } = proto.ADVSignedDeviceIdentityHMAC.decode(deviceIdentityNode.content);
|
|
135
|
+
let hmacPrefix = Buffer.from([]);
|
|
136
|
+
if (accountType !== undefined && accountType === proto.ADVEncryptionType.HOSTED) {
|
|
137
|
+
hmacPrefix = WA_ADV_HOSTED_ACCOUNT_SIG_PREFIX;
|
|
138
|
+
}
|
|
139
|
+
const advSign = hmacSign(Buffer.concat([hmacPrefix, details]), Buffer.from(advSecretKey, 'base64'));
|
|
140
|
+
if (Buffer.compare(hmac, advSign) !== 0) {
|
|
141
|
+
throw new Boom('Invalid account signature');
|
|
142
|
+
}
|
|
143
|
+
const account = proto.ADVSignedDeviceIdentity.decode(details);
|
|
144
|
+
const { accountSignatureKey, accountSignature, details: deviceDetails } = account;
|
|
145
|
+
const deviceIdentity = proto.ADVDeviceIdentity.decode(deviceDetails);
|
|
146
|
+
const accountSignaturePrefix = deviceIdentity.deviceType === proto.ADVEncryptionType.HOSTED
|
|
147
|
+
? WA_ADV_HOSTED_ACCOUNT_SIG_PREFIX
|
|
148
|
+
: WA_ADV_ACCOUNT_SIG_PREFIX;
|
|
149
|
+
const accountMsg = Buffer.concat([accountSignaturePrefix, deviceDetails, signedIdentityKey.public]);
|
|
150
|
+
if (!Curve.verify(accountSignatureKey, accountMsg, accountSignature)) {
|
|
151
|
+
throw new Boom('Failed to verify account signature');
|
|
152
|
+
}
|
|
153
|
+
const deviceMsg = Buffer.concat([
|
|
154
|
+
WA_ADV_DEVICE_SIG_PREFIX,
|
|
155
|
+
deviceDetails,
|
|
156
|
+
signedIdentityKey.public,
|
|
157
|
+
accountSignatureKey
|
|
158
|
+
]);
|
|
159
|
+
account.deviceSignature = Curve.sign(signedIdentityKey.private, deviceMsg);
|
|
160
|
+
const identity = createSignalIdentity(lid, accountSignatureKey);
|
|
161
|
+
const accountEnc = encodeSignedDeviceIdentity(account, false);
|
|
162
|
+
const reply = {
|
|
163
|
+
tag: 'iq',
|
|
164
|
+
attrs: {
|
|
165
|
+
to: S_WHATSAPP_NET,
|
|
166
|
+
type: 'result',
|
|
167
|
+
id: msgId
|
|
168
|
+
},
|
|
169
|
+
content: [
|
|
170
|
+
{
|
|
171
|
+
tag: 'pair-device-sign',
|
|
172
|
+
attrs: {},
|
|
173
|
+
content: [
|
|
174
|
+
{
|
|
175
|
+
tag: 'device-identity',
|
|
176
|
+
attrs: { 'key-index': deviceIdentity.keyIndex.toString() },
|
|
177
|
+
content: accountEnc
|
|
178
|
+
}
|
|
179
|
+
]
|
|
180
|
+
}
|
|
181
|
+
]
|
|
182
|
+
};
|
|
183
|
+
const authUpdate = {
|
|
184
|
+
account,
|
|
185
|
+
me: { id: jid, name: bizName, lid },
|
|
186
|
+
signalIdentities: [...(signalIdentities || []), identity],
|
|
187
|
+
platform: platformNode?.attrs.name
|
|
188
|
+
};
|
|
189
|
+
return {
|
|
190
|
+
creds: authUpdate,
|
|
191
|
+
reply
|
|
192
|
+
};
|
|
193
|
+
};
|
|
194
|
+
export const encodeSignedDeviceIdentity = (account, includeSignatureKey) => {
|
|
195
|
+
account = { ...account };
|
|
196
|
+
// set to null if we are not to include the signature key
|
|
197
|
+
// or if we are including the signature key but it is empty
|
|
198
|
+
if (!includeSignatureKey || !account.accountSignatureKey?.length) {
|
|
199
|
+
account.accountSignatureKey = null;
|
|
200
|
+
}
|
|
201
|
+
return proto.ADVSignedDeviceIdentity.encode(account).finish();
|
|
202
|
+
};
|
|
203
|
+
//# sourceMappingURL=validate-connection.js.map
|