@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
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export declare class CiphertextMessage {
|
|
2
|
-
readonly UNSUPPORTED_VERSION: number
|
|
3
|
-
readonly CURRENT_VERSION: number
|
|
4
|
-
readonly WHISPER_TYPE: number
|
|
5
|
-
readonly PREKEY_TYPE: number
|
|
6
|
-
readonly SENDERKEY_TYPE: number
|
|
7
|
-
readonly SENDERKEY_DISTRIBUTION_TYPE: number
|
|
8
|
-
readonly ENCRYPTED_MESSAGE_OVERHEAD: number
|
|
9
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
4
|
-
|
|
5
|
-
class CiphertextMessage {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.UNSUPPORTED_VERSION = 1
|
|
8
|
-
this.CURRENT_VERSION = 3
|
|
9
|
-
this.WHISPER_TYPE = 2
|
|
10
|
-
this.PREKEY_TYPE = 3
|
|
11
|
-
this.SENDERKEY_TYPE = 4
|
|
12
|
-
this.SENDERKEY_DISTRIBUTION_TYPE = 5
|
|
13
|
-
this.ENCRYPTED_MESSAGE_OVERHEAD = 53
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
module.exports = {
|
|
18
|
-
CiphertextMessage
|
|
19
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
class CiphertextMessage {
|
|
2
|
-
UNSUPPORTED_VERSION = 1;
|
|
3
|
-
|
|
4
|
-
CURRENT_VERSION = 3;
|
|
5
|
-
|
|
6
|
-
WHISPER_TYPE = 2;
|
|
7
|
-
|
|
8
|
-
PREKEY_TYPE = 3;
|
|
9
|
-
|
|
10
|
-
SENDERKEY_TYPE = 4;
|
|
11
|
-
|
|
12
|
-
SENDERKEY_DISTRIBUTION_TYPE = 5;
|
|
13
|
-
|
|
14
|
-
ENCRYPTED_MESSAGE_OVERHEAD = 53;
|
|
15
|
-
}
|
|
16
|
-
module.exports = CiphertextMessage;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
yarn pbjs -t static-module -w commonjs -o ./WASignalGroup/GroupProtocol.js ./WASignalGroup/group.proto
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
-
if (k2 === undefined) k2 = k
|
|
5
|
-
var desc = Object.getOwnPropertyDescriptor(m, k)
|
|
6
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
-
desc = { enumerable: true, get: function() { return m[k] } }
|
|
8
|
-
}
|
|
9
|
-
Object.defineProperty(o, k2, desc)
|
|
10
|
-
}) : (function(o, m, k, k2) {
|
|
11
|
-
if (k2 === undefined) k2 = k
|
|
12
|
-
o[k2] = m[k]
|
|
13
|
-
}))
|
|
14
|
-
|
|
15
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
16
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v })
|
|
17
|
-
}) : function(o, v) {
|
|
18
|
-
o["default"] = v
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
-
var ownKeys = function(o) {
|
|
23
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
-
var ar = []
|
|
25
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k
|
|
26
|
-
return ar
|
|
27
|
-
}
|
|
28
|
-
return ownKeys(o)
|
|
29
|
-
}
|
|
30
|
-
return function (mod) {
|
|
31
|
-
if (mod && mod.__esModule) return mod
|
|
32
|
-
var result = {}
|
|
33
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i])
|
|
34
|
-
__setModuleDefault(result, mod)
|
|
35
|
-
return result
|
|
36
|
-
}
|
|
37
|
-
})()
|
|
38
|
-
|
|
39
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
40
|
-
|
|
41
|
-
const keyhelper = __importStar(require("./keyhelper"))
|
|
42
|
-
const sender_key_distribution_message_1 = require("./sender-key-distribution-message")
|
|
43
|
-
|
|
44
|
-
class GroupSessionBuilder {
|
|
45
|
-
constructor(senderKeyStore) {
|
|
46
|
-
this.senderKeyStore = senderKeyStore
|
|
47
|
-
}
|
|
48
|
-
async process(senderKeyName, senderKeyDistributionMessage) {
|
|
49
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
|
|
50
|
-
senderKeyRecord.addSenderKeyState(senderKeyDistributionMessage.getId(), senderKeyDistributionMessage.getIteration(), senderKeyDistributionMessage.getChainKey(), senderKeyDistributionMessage.getSignatureKey())
|
|
51
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
|
|
52
|
-
}
|
|
53
|
-
async create(senderKeyName) {
|
|
54
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
|
|
55
|
-
if (senderKeyRecord.isEmpty()) {
|
|
56
|
-
const keyId = keyhelper.generateSenderKeyId()
|
|
57
|
-
const senderKey = keyhelper.generateSenderKey()
|
|
58
|
-
const signingKey = keyhelper.generateSenderSigningKey()
|
|
59
|
-
senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey)
|
|
60
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
|
|
61
|
-
}
|
|
62
|
-
const state = senderKeyRecord.getSenderKeyState()
|
|
63
|
-
if (!state) {
|
|
64
|
-
throw new Error('No session state available')
|
|
65
|
-
}
|
|
66
|
-
return new sender_key_distribution_message_1.SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic())
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
module.exports = {
|
|
71
|
-
GroupSessionBuilder
|
|
72
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
package groupproto;
|
|
2
|
-
|
|
3
|
-
message SenderKeyMessage {
|
|
4
|
-
optional uint32 id = 1;
|
|
5
|
-
optional uint32 iteration = 2;
|
|
6
|
-
optional bytes ciphertext = 3;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
message SenderKeyDistributionMessage {
|
|
10
|
-
optional uint32 id = 1;
|
|
11
|
-
optional uint32 iteration = 2;
|
|
12
|
-
optional bytes chainKey = 3;
|
|
13
|
-
optional bytes signingKey = 4;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
message SenderChainKey {
|
|
17
|
-
optional uint32 iteration = 1;
|
|
18
|
-
optional bytes seed = 2;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
message SenderMessageKey {
|
|
22
|
-
optional uint32 iteration = 1;
|
|
23
|
-
optional bytes seed = 2;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
message SenderSigningKey {
|
|
27
|
-
optional bytes public = 1;
|
|
28
|
-
optional bytes private = 2;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
message SenderKeyStateStructure {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
optional uint32 senderKeyId = 1;
|
|
35
|
-
optional SenderChainKey senderChainKey = 2;
|
|
36
|
-
optional SenderSigningKey senderSigningKey = 3;
|
|
37
|
-
repeated SenderMessageKey senderMessageKeys = 4;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
message SenderKeyRecordStructure {
|
|
41
|
-
repeated SenderKeyStateStructure senderKeyStates = 1;
|
|
42
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { SenderKeyName } from './sender-key-name'
|
|
2
|
-
import { SenderKeyRecord } from './sender-key-record'
|
|
3
|
-
|
|
4
|
-
export interface SenderKeyStore {
|
|
5
|
-
loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>
|
|
6
|
-
storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export declare class GroupCipher {
|
|
10
|
-
private readonly senderKeyStore
|
|
11
|
-
private readonly senderKeyName
|
|
12
|
-
constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName)
|
|
13
|
-
private queueJob
|
|
14
|
-
encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>
|
|
15
|
-
decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>
|
|
16
|
-
private getSenderKey
|
|
17
|
-
private getPlainText
|
|
18
|
-
private getCipherText
|
|
19
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
//const utils = require('../../common/utils');
|
|
2
|
-
const SenderKeyDistributionMessage = require('./sender_key_distribution_message');
|
|
3
|
-
|
|
4
|
-
const keyhelper = require("./keyhelper");
|
|
5
|
-
class GroupSessionBuilder {
|
|
6
|
-
constructor(senderKeyStore) {
|
|
7
|
-
this.senderKeyStore = senderKeyStore;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
async process(senderKeyName, senderKeyDistributionMessage) {
|
|
11
|
-
//console.log('GroupSessionBuilder process', senderKeyName, senderKeyDistributionMessage);
|
|
12
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
13
|
-
senderKeyRecord.addSenderKeyState(
|
|
14
|
-
senderKeyDistributionMessage.getId(),
|
|
15
|
-
senderKeyDistributionMessage.getIteration(),
|
|
16
|
-
senderKeyDistributionMessage.getChainKey(),
|
|
17
|
-
senderKeyDistributionMessage.getSignatureKey()
|
|
18
|
-
);
|
|
19
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// [{"senderKeyId":1742199468,"senderChainKey":{"iteration":0,"seed":"yxMY9VFQcXEP34olRAcGCtsgx1XoKsHfDIh+1ea4HAQ="},"senderSigningKey":{"public":""}}]
|
|
23
|
-
async create(senderKeyName) {
|
|
24
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
25
|
-
//console.log('GroupSessionBuilder create session', senderKeyName, senderKeyRecord);
|
|
26
|
-
|
|
27
|
-
if (senderKeyRecord.isEmpty()) {
|
|
28
|
-
const keyId = keyhelper.generateSenderKeyId();
|
|
29
|
-
const senderKey = keyhelper.generateSenderKey();
|
|
30
|
-
const signingKey = keyhelper.generateSenderSigningKey();
|
|
31
|
-
|
|
32
|
-
senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey);
|
|
33
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
const state = senderKeyRecord.getSenderKeyState();
|
|
37
|
-
|
|
38
|
-
return new SenderKeyDistributionMessage(
|
|
39
|
-
state.getKeyId(),
|
|
40
|
-
state.getSenderChainKey().getIteration(),
|
|
41
|
-
state.getSenderChainKey().getSeed(),
|
|
42
|
-
state.getSigningKeyPublic()
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
module.exports = GroupSessionBuilder;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export { GroupSessionBuilder } from './group-session-builder'
|
|
2
|
-
export { SenderKeyDistributionMessage } from './sender-key-distribution-message'
|
|
3
|
-
export { SenderKeyRecord } from './sender-key-record'
|
|
4
|
-
export { SenderKeyName } from './sender-key-name'
|
|
5
|
-
export { GroupCipher } from './group_cipher'
|
|
6
|
-
export { SenderKeyState } from './sender-key-state'
|
|
7
|
-
export { SenderKeyMessage } from './sender-key-message'
|
|
8
|
-
export { SenderMessageKey } from './sender-message-key'
|
|
9
|
-
export { SenderChainKey } from './sender-chain-key'
|
|
10
|
-
export { CiphertextMessage } from './ciphertext-message'
|
|
11
|
-
export * as keyhelper from './keyhelper'
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
-
if (k2 === undefined) k2 = k
|
|
5
|
-
var desc = Object.getOwnPropertyDescriptor(m, k)
|
|
6
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
-
desc = { enumerable: true, get: function() { return m[k] } }
|
|
8
|
-
}
|
|
9
|
-
Object.defineProperty(o, k2, desc)
|
|
10
|
-
}) : (function(o, m, k, k2) {
|
|
11
|
-
if (k2 === undefined) k2 = k
|
|
12
|
-
o[k2] = m[k]
|
|
13
|
-
}))
|
|
14
|
-
|
|
15
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
16
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v })
|
|
17
|
-
}) : function(o, v) {
|
|
18
|
-
o["default"] = v
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
-
var ownKeys = function(o) {
|
|
23
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
-
var ar = []
|
|
25
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k
|
|
26
|
-
return ar
|
|
27
|
-
}
|
|
28
|
-
return ownKeys(o)
|
|
29
|
-
}
|
|
30
|
-
return function (mod) {
|
|
31
|
-
if (mod && mod.__esModule) return mod
|
|
32
|
-
var result = {}
|
|
33
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i])
|
|
34
|
-
__setModuleDefault(result, mod)
|
|
35
|
-
return result
|
|
36
|
-
}
|
|
37
|
-
})()
|
|
38
|
-
|
|
39
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
40
|
-
exports.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0
|
|
41
|
-
var group_session_builder_1 = require("./group-session-builder")
|
|
42
|
-
Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder } })
|
|
43
|
-
var sender_key_distribution_message_1 = require("./sender-key-distribution-message")
|
|
44
|
-
Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage } })
|
|
45
|
-
var sender_key_record_1 = require("./sender-key-record")
|
|
46
|
-
Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord } })
|
|
47
|
-
var sender_key_name_1 = require("./sender-key-name")
|
|
48
|
-
Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName } })
|
|
49
|
-
var group_cipher_1 = require("./group_cipher")
|
|
50
|
-
Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher } })
|
|
51
|
-
var sender_key_state_1 = require("./sender-key-state")
|
|
52
|
-
Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState } })
|
|
53
|
-
var sender_key_message_1 = require("./sender-key-message")
|
|
54
|
-
Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage } })
|
|
55
|
-
var sender_message_key_1 = require("./sender-message-key")
|
|
56
|
-
Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey } })
|
|
57
|
-
var sender_chain_key_1 = require("./sender-chain-key")
|
|
58
|
-
Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey } })
|
|
59
|
-
var ciphertext_message_1 = require("./ciphertext-message")
|
|
60
|
-
Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage } })
|
|
61
|
-
exports.keyhelper = __importStar(require("./keyhelper"))
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { generateKeyPair } from '@neelegirl/libsignal/src/curve'
|
|
2
|
-
|
|
3
|
-
type KeyPairType = ReturnType<typeof generateKeyPair>
|
|
4
|
-
|
|
5
|
-
export declare function generateSenderKey(): Buffer
|
|
6
|
-
|
|
7
|
-
export declare function generateSenderKeyId(): number
|
|
8
|
-
|
|
9
|
-
export interface SigningKeyPair {
|
|
10
|
-
public: Buffer
|
|
11
|
-
private: Buffer
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair
|
|
15
|
-
|
|
16
|
-
export {}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
-
if (k2 === undefined) k2 = k
|
|
5
|
-
var desc = Object.getOwnPropertyDescriptor(m, k)
|
|
6
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
-
desc = { enumerable: true, get: function() { return m[k] } }
|
|
8
|
-
}
|
|
9
|
-
Object.defineProperty(o, k2, desc)
|
|
10
|
-
}) : (function(o, m, k, k2) {
|
|
11
|
-
if (k2 === undefined) k2 = k
|
|
12
|
-
o[k2] = m[k]
|
|
13
|
-
}))
|
|
14
|
-
|
|
15
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
16
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v })
|
|
17
|
-
}) : function(o, v) {
|
|
18
|
-
o["default"] = v
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
-
var ownKeys = function(o) {
|
|
23
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
-
var ar = []
|
|
25
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k
|
|
26
|
-
return ar
|
|
27
|
-
}
|
|
28
|
-
return ownKeys(o)
|
|
29
|
-
}
|
|
30
|
-
return function (mod) {
|
|
31
|
-
if (mod && mod.__esModule) return mod
|
|
32
|
-
var result = {}
|
|
33
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i])
|
|
34
|
-
__setModuleDefault(result, mod)
|
|
35
|
-
return result
|
|
36
|
-
}
|
|
37
|
-
})()
|
|
38
|
-
|
|
39
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
40
|
-
|
|
41
|
-
const nodeCrypto = __importStar(require("crypto"))
|
|
42
|
-
const curve_1 = require("@neelegirl/libsignal/src/curve")
|
|
43
|
-
|
|
44
|
-
function generateSenderKey() {
|
|
45
|
-
return nodeCrypto.randomBytes(32)
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
function generateSenderKeyId() {
|
|
49
|
-
return nodeCrypto.randomInt(2147483647)
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
function generateSenderSigningKey(key) {
|
|
53
|
-
if (!key) {
|
|
54
|
-
key = curve_1.generateKeyPair()
|
|
55
|
-
}
|
|
56
|
-
return {
|
|
57
|
-
public: Buffer.from(key.pubKey),
|
|
58
|
-
private: Buffer.from(key.privKey)
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
module.exports = {
|
|
63
|
-
generateSenderKey,
|
|
64
|
-
generateSenderKeyId,
|
|
65
|
-
generateSenderSigningKey
|
|
66
|
-
}
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
// vim: ts=4:sw=4:expandtab
|
|
2
|
-
|
|
3
|
-
/*
|
|
4
|
-
* jobQueue manages multiple queues indexed by device to serialize
|
|
5
|
-
* session io ops on the database.
|
|
6
|
-
*/
|
|
7
|
-
'use strict';
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const _queueAsyncBuckets = new Map();
|
|
11
|
-
const _gcLimit = 10000;
|
|
12
|
-
|
|
13
|
-
async function _asyncQueueExecutor(queue, cleanup) {
|
|
14
|
-
let offt = 0;
|
|
15
|
-
while (true) {
|
|
16
|
-
let limit = Math.min(queue.length, _gcLimit); // Break up thundering hurds for GC duty.
|
|
17
|
-
for (let i = offt; i < limit; i++) {
|
|
18
|
-
const job = queue[i];
|
|
19
|
-
try {
|
|
20
|
-
job.resolve(await job.awaitable());
|
|
21
|
-
} catch (e) {
|
|
22
|
-
job.reject(e);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
if (limit < queue.length) {
|
|
26
|
-
/* Perform lazy GC of queue for faster iteration. */
|
|
27
|
-
if (limit >= _gcLimit) {
|
|
28
|
-
queue.splice(0, limit);
|
|
29
|
-
offt = 0;
|
|
30
|
-
} else {
|
|
31
|
-
offt = limit;
|
|
32
|
-
}
|
|
33
|
-
} else {
|
|
34
|
-
break;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
cleanup();
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
module.exports = function (bucket, awaitable) {
|
|
41
|
-
/* Run the async awaitable only when all other async calls registered
|
|
42
|
-
* here have completed (or thrown). The bucket argument is a hashable
|
|
43
|
-
* key representing the task queue to use. */
|
|
44
|
-
if (!awaitable.name) {
|
|
45
|
-
// Make debuging easier by adding a name to this function.
|
|
46
|
-
Object.defineProperty(awaitable, 'name', { writable: true });
|
|
47
|
-
if (typeof bucket === 'string') {
|
|
48
|
-
awaitable.name = bucket;
|
|
49
|
-
} else {
|
|
50
|
-
console.warn("Unhandled bucket type (for naming):", typeof bucket, bucket);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
let inactive;
|
|
54
|
-
if (!_queueAsyncBuckets.has(bucket)) {
|
|
55
|
-
_queueAsyncBuckets.set(bucket, []);
|
|
56
|
-
inactive = true;
|
|
57
|
-
}
|
|
58
|
-
const queue = _queueAsyncBuckets.get(bucket);
|
|
59
|
-
const job = new Promise((resolve, reject) => queue.push({
|
|
60
|
-
awaitable,
|
|
61
|
-
resolve,
|
|
62
|
-
reject
|
|
63
|
-
}));
|
|
64
|
-
if (inactive) {
|
|
65
|
-
/* An executor is not currently active; Start one now. */
|
|
66
|
-
_asyncQueueExecutor(queue, () => _queueAsyncBuckets.delete(bucket));
|
|
67
|
-
}
|
|
68
|
-
return job;
|
|
69
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
# Signal-Group
|
|
2
|
-
|
|
3
|
-
This contains the code to decrypt/encrypt WA group messages.
|
|
4
|
-
Originally from [pokearaujo/libsignal-node](https://github.com/pokearaujo/libsignal-node)
|
|
5
|
-
|
|
6
|
-
The code has been moved outside the signal package as I felt it didn't belong in ths signal package, as it isn't inherently a part of signal but of WA.
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { SenderMessageKey } from './sender-message-key'
|
|
2
|
-
|
|
3
|
-
export declare class SenderChainKey {
|
|
4
|
-
private readonly MESSAGE_KEY_SEED
|
|
5
|
-
private readonly CHAIN_KEY_SEED
|
|
6
|
-
private readonly iteration
|
|
7
|
-
private readonly chainKey
|
|
8
|
-
constructor(iteration: number, chainKey: any)
|
|
9
|
-
getIteration(): number
|
|
10
|
-
getSenderMessageKey(): SenderMessageKey
|
|
11
|
-
getNext(): SenderChainKey
|
|
12
|
-
getSeed(): Uint8Array
|
|
13
|
-
private getDerivative
|
|
14
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
4
|
-
|
|
5
|
-
const crypto_1 = require("@neelegirl/libsignal/src/crypto")
|
|
6
|
-
const sender_message_key_1 = require("./sender-message-key")
|
|
7
|
-
|
|
8
|
-
class SenderChainKey {
|
|
9
|
-
constructor(iteration, chainKey) {
|
|
10
|
-
this.MESSAGE_KEY_SEED = Buffer.from([0x01])
|
|
11
|
-
this.CHAIN_KEY_SEED = Buffer.from([0x02])
|
|
12
|
-
this.iteration = iteration
|
|
13
|
-
if (Buffer.isBuffer(chainKey)) {
|
|
14
|
-
// backported from @MartinSchere's PR
|
|
15
|
-
this.chainKey = chainKey
|
|
16
|
-
}
|
|
17
|
-
else if (chainKey instanceof Uint8Array) {
|
|
18
|
-
this.chainKey = Buffer.from(chainKey)
|
|
19
|
-
}
|
|
20
|
-
else if (chainKey && typeof chainKey === 'object') {
|
|
21
|
-
// backported from @MartinSchere (#1741)
|
|
22
|
-
this.chainKey = Buffer.from(Object.values(chainKey)) // temp fix // backported from @MartinSchere (#1741)
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
this.chainKey = Buffer.alloc(0)
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
getIteration() {
|
|
29
|
-
return this.iteration
|
|
30
|
-
}
|
|
31
|
-
getSenderMessageKey() {
|
|
32
|
-
return new sender_message_key_1.SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey))
|
|
33
|
-
}
|
|
34
|
-
getNext() {
|
|
35
|
-
return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey))
|
|
36
|
-
}
|
|
37
|
-
getSeed() {
|
|
38
|
-
return this.chainKey
|
|
39
|
-
}
|
|
40
|
-
getDerivative(seed, key) {
|
|
41
|
-
return (0, crypto_1.calculateMAC)(key, seed)
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
module.exports = {
|
|
46
|
-
SenderChainKey
|
|
47
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message'
|
|
2
|
-
|
|
3
|
-
export declare class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
4
|
-
private readonly id
|
|
5
|
-
private readonly iteration
|
|
6
|
-
private readonly chainKey
|
|
7
|
-
private readonly signatureKey
|
|
8
|
-
private readonly serialized
|
|
9
|
-
constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null)
|
|
10
|
-
private intsToByteHighAndLow
|
|
11
|
-
serialize(): Uint8Array
|
|
12
|
-
getType(): number
|
|
13
|
-
getIteration(): number
|
|
14
|
-
getChainKey(): Uint8Array
|
|
15
|
-
getSignatureKey(): Uint8Array
|
|
16
|
-
getId(): number
|
|
17
|
-
}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict"
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true })
|
|
4
|
-
|
|
5
|
-
const WAProto_1 = require("../../../WAProto")
|
|
6
|
-
const ciphertext_message_1 = require("./ciphertext-message")
|
|
7
|
-
|
|
8
|
-
class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessage {
|
|
9
|
-
constructor(id, iteration, chainKey, signatureKey, serialized) {
|
|
10
|
-
super()
|
|
11
|
-
if (serialized) {
|
|
12
|
-
try {
|
|
13
|
-
const message = serialized.slice(1)
|
|
14
|
-
const distributionMessage = WAProto_1.proto.SenderKeyDistributionMessage.decode(message).toJSON()
|
|
15
|
-
this.serialized = serialized
|
|
16
|
-
this.id = distributionMessage.id
|
|
17
|
-
this.iteration = distributionMessage.iteration
|
|
18
|
-
this.chainKey =
|
|
19
|
-
typeof distributionMessage.chainKey === 'string'
|
|
20
|
-
? Buffer.from(distributionMessage.chainKey, 'base64')
|
|
21
|
-
: distributionMessage.chainKey
|
|
22
|
-
this.signatureKey =
|
|
23
|
-
typeof distributionMessage.signingKey === 'string'
|
|
24
|
-
? Buffer.from(distributionMessage.signingKey, 'base64')
|
|
25
|
-
: distributionMessage.signingKey
|
|
26
|
-
}
|
|
27
|
-
catch (e) {
|
|
28
|
-
throw new Error(String(e))
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION)
|
|
33
|
-
this.id = id
|
|
34
|
-
this.iteration = iteration
|
|
35
|
-
this.chainKey = chainKey
|
|
36
|
-
this.signatureKey = signatureKey
|
|
37
|
-
const message = WAProto_1.proto.SenderKeyDistributionMessage.encode(WAProto_1.proto.SenderKeyDistributionMessage.create({
|
|
38
|
-
id,
|
|
39
|
-
iteration,
|
|
40
|
-
chainKey,
|
|
41
|
-
signingKey: this.signatureKey
|
|
42
|
-
})).finish()
|
|
43
|
-
this.serialized = Buffer.concat([Buffer.from([version]), message])
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
intsToByteHighAndLow(highValue, lowValue) {
|
|
47
|
-
return (((highValue << 4) | lowValue) & 0xff) % 256
|
|
48
|
-
}
|
|
49
|
-
serialize() {
|
|
50
|
-
return this.serialized
|
|
51
|
-
}
|
|
52
|
-
getType() {
|
|
53
|
-
return this.SENDERKEY_DISTRIBUTION_TYPE
|
|
54
|
-
}
|
|
55
|
-
getIteration() {
|
|
56
|
-
return this.iteration
|
|
57
|
-
}
|
|
58
|
-
getChainKey() {
|
|
59
|
-
return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey
|
|
60
|
-
}
|
|
61
|
-
getSignatureKey() {
|
|
62
|
-
return typeof this.signatureKey === 'string' ? Buffer.from(this.signatureKey, 'base64') : this.signatureKey
|
|
63
|
-
}
|
|
64
|
-
getId() {
|
|
65
|
-
return this.id
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
module.exports = {
|
|
70
|
-
SenderKeyDistributionMessage
|
|
71
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message'
|
|
2
|
-
|
|
3
|
-
export declare class SenderKeyMessage extends CiphertextMessage {
|
|
4
|
-
private readonly SIGNATURE_LENGTH
|
|
5
|
-
private readonly messageVersion
|
|
6
|
-
private readonly keyId
|
|
7
|
-
private readonly iteration
|
|
8
|
-
private readonly ciphertext
|
|
9
|
-
private readonly signature
|
|
10
|
-
private readonly serialized
|
|
11
|
-
constructor(keyId?: number | null, iteration?: number | null, ciphertext?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null)
|
|
12
|
-
getKeyId(): number
|
|
13
|
-
getIteration(): number
|
|
14
|
-
getCipherText(): Uint8Array
|
|
15
|
-
verifySignature(signatureKey: Uint8Array): void
|
|
16
|
-
private getSignature
|
|
17
|
-
serialize(): Uint8Array
|
|
18
|
-
getType(): number
|
|
19
|
-
}
|