zapo-js 0.1.1 → 0.2.0
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/README.md +20 -4
- package/dist/appstate/WaAppStateCrypto.js +19 -26
- package/dist/appstate/WaAppStateSyncClient.js +293 -181
- package/dist/appstate/WaAppStateSyncResponseParser.js +16 -5
- package/dist/appstate/constants.js +4 -3
- package/dist/appstate/{store/sqlite.js → encoding.js} +13 -8
- package/dist/appstate/index.js +8 -6
- package/dist/appstate/utils.js +9 -34
- package/dist/auth/WaAuthClient.js +43 -61
- package/dist/auth/flow/WaAuthCredentialsFlow.js +22 -15
- package/dist/auth/index.js +1 -8
- package/dist/auth/pairing/WaPairingCodeCrypto.js +6 -4
- package/dist/auth/pairing/WaPairingFlow.js +34 -26
- package/dist/auth/pairing/WaQrFlow.js +37 -24
- package/dist/client/WaClient.js +275 -324
- package/dist/client/WaClientFactory.js +500 -133
- package/dist/client/connection/WaConnectionManager.js +301 -0
- package/dist/client/connection/WaKeyShareCoordinator.js +63 -0
- package/dist/client/connection/WaReceiptQueue.js +51 -0
- package/dist/client/coordinators/WaAppStateMutationCoordinator.js +471 -0
- package/dist/client/coordinators/WaBusinessCoordinator.js +241 -0
- package/dist/client/coordinators/WaGroupCoordinator.js +30 -16
- package/dist/client/coordinators/WaIncomingNodeCoordinator.js +21 -27
- package/dist/client/coordinators/WaMessageDispatchCoordinator.js +439 -701
- package/dist/client/coordinators/WaPassiveTasksCoordinator.js +74 -31
- package/dist/client/coordinators/WaPrivacyCoordinator.js +134 -0
- package/dist/client/coordinators/WaProfileCoordinator.js +212 -0
- package/dist/client/coordinators/WaRetryCoordinator.js +242 -57
- package/dist/client/coordinators/WaStreamControlCoordinator.js +18 -11
- package/dist/client/coordinators/WaTrustedContactTokenCoordinator.js +166 -0
- package/dist/client/dirty.js +74 -48
- package/dist/client/events/chat.js +4 -3
- package/dist/client/events/devices.js +72 -0
- package/dist/client/events/group.js +62 -47
- package/dist/client/events/identity.js +22 -0
- package/dist/client/events/privacy-token.js +39 -0
- package/dist/client/history-sync.js +94 -63
- package/dist/client/incoming.js +60 -27
- package/dist/client/mailbox.js +24 -23
- package/dist/client/messages.js +107 -31
- package/dist/client/messaging/fanout.js +199 -0
- package/dist/client/messaging/key-protocol.js +130 -0
- package/dist/client/messaging/participants.js +193 -0
- package/dist/client/persistence/WriteBehindPersistence.js +129 -0
- package/dist/client/tokens/cs-token.js +50 -0
- package/dist/client/tokens/tc-token.js +25 -0
- package/dist/crypto/core/hkdf.js +3 -8
- package/dist/crypto/core/index.js +2 -5
- package/dist/crypto/core/keys.js +6 -7
- package/dist/crypto/core/nonce.js +2 -0
- package/dist/crypto/core/primitives.js +12 -23
- package/dist/crypto/core/random.js +26 -23
- package/dist/crypto/curves/Ed25519.js +7 -8
- package/dist/crypto/curves/X25519.js +38 -22
- package/dist/crypto/index.js +1 -3
- package/dist/crypto/math/constants.js +13 -36
- package/dist/crypto/math/edwards.js +171 -44
- package/dist/crypto/math/fe.js +706 -0
- package/dist/crypto/math/mod.js +10 -3
- package/dist/esm/appstate/WaAppStateCrypto.js +7 -14
- package/dist/esm/appstate/WaAppStateSyncClient.js +284 -172
- package/dist/esm/appstate/WaAppStateSyncResponseParser.js +17 -6
- package/dist/esm/appstate/constants.js +3 -2
- package/dist/esm/appstate/{store/sqlite.js → encoding.js} +13 -8
- package/dist/esm/appstate/index.js +2 -2
- package/dist/esm/appstate/utils.js +8 -30
- package/dist/esm/auth/WaAuthClient.js +43 -61
- package/dist/esm/auth/flow/WaAuthCredentialsFlow.js +22 -15
- package/dist/esm/auth/index.js +0 -3
- package/dist/esm/auth/pairing/WaPairingCodeCrypto.js +6 -4
- package/dist/esm/auth/pairing/WaPairingFlow.js +28 -20
- package/dist/esm/auth/pairing/WaQrFlow.js +37 -24
- package/dist/esm/client/WaClient.js +275 -324
- package/dist/esm/client/WaClientFactory.js +501 -134
- package/dist/esm/client/connection/WaConnectionManager.js +297 -0
- package/dist/esm/client/connection/WaKeyShareCoordinator.js +59 -0
- package/dist/esm/client/connection/WaReceiptQueue.js +47 -0
- package/dist/esm/client/coordinators/WaAppStateMutationCoordinator.js +467 -0
- package/dist/esm/client/coordinators/WaBusinessCoordinator.js +238 -0
- package/dist/esm/client/coordinators/WaGroupCoordinator.js +23 -9
- package/dist/esm/client/coordinators/WaIncomingNodeCoordinator.js +21 -27
- package/dist/esm/client/coordinators/WaMessageDispatchCoordinator.js +443 -705
- package/dist/esm/client/coordinators/WaPassiveTasksCoordinator.js +74 -31
- package/dist/esm/client/coordinators/WaPrivacyCoordinator.js +131 -0
- package/dist/esm/client/coordinators/WaProfileCoordinator.js +209 -0
- package/dist/esm/client/coordinators/WaRetryCoordinator.js +244 -59
- package/dist/esm/client/coordinators/WaStreamControlCoordinator.js +19 -12
- package/dist/esm/client/coordinators/WaTrustedContactTokenCoordinator.js +162 -0
- package/dist/esm/client/dirty.js +69 -43
- package/dist/esm/client/events/chat.js +4 -3
- package/dist/esm/client/events/devices.js +68 -0
- package/dist/esm/client/events/group.js +53 -39
- package/dist/esm/client/events/identity.js +19 -0
- package/dist/esm/client/events/privacy-token.js +36 -0
- package/dist/esm/client/history-sync.js +91 -60
- package/dist/esm/client/incoming.js +61 -28
- package/dist/esm/client/mailbox.js +24 -23
- package/dist/esm/client/messages.js +108 -32
- package/dist/esm/client/messaging/fanout.js +196 -0
- package/dist/esm/client/messaging/key-protocol.js +127 -0
- package/dist/esm/client/messaging/participants.js +190 -0
- package/dist/esm/client/persistence/WriteBehindPersistence.js +125 -0
- package/dist/esm/client/tokens/cs-token.js +46 -0
- package/dist/esm/client/tokens/tc-token.js +18 -0
- package/dist/esm/crypto/core/hkdf.js +3 -8
- package/dist/esm/crypto/core/index.js +2 -3
- package/dist/esm/crypto/core/keys.js +3 -4
- package/dist/esm/crypto/core/nonce.js +2 -0
- package/dist/esm/crypto/core/primitives.js +12 -22
- package/dist/esm/crypto/core/random.js +25 -23
- package/dist/esm/crypto/curves/Ed25519.js +4 -5
- package/dist/esm/crypto/curves/X25519.js +35 -19
- package/dist/esm/crypto/index.js +0 -1
- package/dist/esm/crypto/math/constants.js +12 -35
- package/dist/esm/crypto/math/edwards.js +174 -47
- package/dist/esm/crypto/math/fe.js +691 -0
- package/dist/esm/crypto/math/mod.js +10 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/infra/log/ConsoleLogger.js +18 -17
- package/dist/esm/infra/log/PinoLogger.js +15 -9
- package/dist/esm/infra/log/types.js +11 -1
- package/dist/esm/infra/perf/BackgroundQueue.js +478 -0
- package/dist/esm/infra/perf/BoundedTaskQueue.js +16 -18
- package/dist/esm/infra/perf/PromiseDedup.js +20 -0
- package/dist/esm/infra/perf/SharedExclusiveGate.js +109 -0
- package/dist/esm/infra/perf/StoreLock.js +77 -0
- package/dist/esm/media/WaMediaCrypto.js +96 -16
- package/dist/esm/media/WaMediaTransferClient.js +251 -91
- package/dist/esm/media/conn.js +10 -6
- package/dist/esm/media/constants.js +6 -2
- package/dist/esm/message/WaMessageClient.js +30 -32
- package/dist/esm/message/ack.js +6 -6
- package/dist/esm/message/addon-crypto.js +59 -0
- package/dist/esm/message/content.js +195 -9
- package/dist/esm/message/icdc.js +76 -0
- package/dist/esm/message/incoming.js +129 -122
- package/dist/esm/message/index.js +2 -0
- package/dist/esm/message/phash.js +3 -1
- package/dist/esm/message/reporting-token.js +425 -0
- package/dist/esm/message/use-case-secret.js +49 -0
- package/dist/esm/protocol/appstate.js +27 -0
- package/dist/esm/protocol/browser.js +10 -18
- package/dist/esm/protocol/constants.js +6 -3
- package/dist/esm/protocol/defaults.js +6 -0
- package/dist/esm/protocol/index.js +2 -11
- package/dist/esm/protocol/jid.js +133 -52
- package/dist/esm/protocol/media.js +3 -3
- package/dist/esm/protocol/message.js +61 -1
- package/dist/esm/protocol/nodes.js +4 -0
- package/dist/esm/protocol/notification.js +3 -1
- package/dist/esm/protocol/privacy-token.js +17 -0
- package/dist/esm/protocol/privacy.js +55 -0
- package/dist/esm/protocol/stream.js +26 -1
- package/dist/esm/protocol/usync.js +11 -0
- package/dist/esm/retry/codec.js +216 -0
- package/dist/esm/retry/constants.js +1 -1
- package/dist/esm/retry/index.js +3 -2
- package/dist/esm/retry/parse.js +88 -86
- package/dist/esm/retry/replay.js +54 -51
- package/dist/esm/retry/tracker.js +94 -0
- package/dist/esm/signal/api/SignalDeviceSyncApi.js +276 -92
- package/dist/esm/signal/api/SignalDigestSyncApi.js +17 -8
- package/dist/esm/signal/api/SignalIdentitySyncApi.js +67 -37
- package/dist/esm/signal/api/SignalMissingPreKeysSyncApi.js +86 -67
- package/dist/esm/signal/api/SignalRotateKeyApi.js +4 -2
- package/dist/esm/signal/api/SignalSessionSyncApi.js +36 -34
- package/dist/esm/signal/api/result-map.js +10 -0
- package/dist/esm/signal/constants.js +0 -4
- package/dist/esm/signal/crypto/WaAdvSignature.js +13 -9
- package/dist/esm/signal/{store/sqlite.js → encoding.js} +93 -60
- package/dist/esm/signal/group/SenderKeyChain.js +28 -23
- package/dist/esm/signal/group/SenderKeyCodec.js +5 -6
- package/dist/esm/signal/group/SenderKeyManager.js +144 -115
- package/dist/esm/signal/index.js +2 -0
- package/dist/esm/signal/registration/keygen.js +6 -2
- package/dist/esm/signal/registration/utils.js +1 -0
- package/dist/esm/signal/session/SignalProtocol.js +164 -53
- package/dist/esm/signal/session/SignalRatchet.js +24 -15
- package/dist/esm/signal/session/SignalSession.js +14 -9
- package/dist/esm/signal/session/resolver.js +221 -0
- package/dist/esm/store/contracts/privacy-token.store.js +1 -0
- package/dist/esm/store/createStore.js +100 -188
- package/dist/esm/store/index.js +1 -10
- package/dist/esm/store/locks/appstate.lock.js +26 -0
- package/dist/esm/store/locks/auth.lock.js +15 -0
- package/dist/esm/store/locks/contact.lock.js +20 -0
- package/dist/esm/store/locks/device-list.lock.js +20 -0
- package/dist/esm/store/locks/message.lock.js +21 -0
- package/dist/esm/store/locks/participants.lock.js +20 -0
- package/dist/esm/store/locks/privacy-token.lock.js +18 -0
- package/dist/esm/store/locks/retry.lock.js +29 -0
- package/dist/esm/store/locks/sender-key.lock.js +52 -0
- package/dist/esm/store/locks/signal.lock.js +63 -0
- package/dist/esm/store/locks/thread.lock.js +21 -0
- package/dist/esm/store/noop.store.js +4 -7
- package/dist/esm/store/providers/memory/appstate.store.js +38 -16
- package/dist/esm/store/providers/memory/contact.store.js +5 -0
- package/dist/esm/store/providers/memory/device-list.store.js +12 -34
- package/dist/esm/store/providers/memory/message.store.js +11 -5
- package/dist/esm/store/providers/memory/participants.store.js +1 -8
- package/dist/esm/store/providers/memory/privacy-token.store.js +43 -0
- package/dist/esm/store/providers/memory/retry.store.js +77 -2
- package/dist/esm/store/providers/memory/sender-key.store.js +11 -8
- package/dist/esm/store/providers/memory/signal.store.js +47 -18
- package/dist/esm/store/providers/memory/thread.store.js +5 -0
- package/dist/esm/transport/WaComms.js +28 -24
- package/dist/esm/transport/WaWebSocket.js +115 -18
- package/dist/esm/transport/binary/constants.js +0 -30
- package/dist/esm/transport/binary/decoder.js +8 -8
- package/dist/esm/transport/binary/encoder.js +10 -9
- package/dist/esm/transport/binary/index.js +0 -1
- package/dist/esm/transport/index.js +1 -0
- package/dist/esm/transport/keepalive/WaKeepAlive.js +2 -8
- package/dist/esm/transport/node/WaNodeOrchestrator.js +25 -21
- package/dist/esm/transport/node/WaNodeTransport.js +0 -3
- package/dist/esm/transport/node/builders/{accountSync.js → account-sync.js} +16 -36
- package/dist/esm/transport/node/builders/business.js +129 -0
- package/dist/esm/transport/node/builders/global.js +370 -0
- package/dist/esm/transport/node/builders/index.js +7 -3
- package/dist/esm/transport/node/builders/message.js +63 -230
- package/dist/esm/transport/node/builders/pairing.js +2 -27
- package/dist/esm/transport/node/builders/privacy-token.js +41 -0
- package/dist/esm/transport/node/builders/privacy.js +48 -0
- package/dist/esm/transport/node/builders/profile.js +70 -0
- package/dist/esm/transport/node/builders/retry.js +10 -22
- package/dist/esm/transport/node/builders/usync.js +45 -0
- package/dist/esm/transport/node/helpers.js +125 -5
- package/dist/esm/transport/node/usync.js +5 -0
- package/dist/esm/transport/node/xml.js +35 -14
- package/dist/esm/transport/noise/WaClientPayload.js +10 -10
- package/dist/esm/transport/noise/WaFrameCodec.js +48 -33
- package/dist/esm/transport/noise/WaNoiseCert.js +4 -7
- package/dist/esm/transport/noise/WaNoiseSession.js +77 -29
- package/dist/esm/transport/noise/WaNoiseSocket.js +8 -4
- package/dist/esm/transport/proxy.js +27 -0
- package/dist/esm/transport/stream/parse.js +17 -48
- package/dist/esm/util/bytes.js +67 -45
- package/dist/esm/util/coercion.js +6 -14
- package/dist/esm/util/index.js +5 -0
- package/dist/esm/util/primitives.js +40 -14
- package/dist/index.js +7 -1
- package/dist/infra/log/ConsoleLogger.js +18 -17
- package/dist/infra/log/PinoLogger.js +15 -9
- package/dist/infra/log/types.js +12 -0
- package/dist/infra/perf/BackgroundQueue.js +482 -0
- package/dist/infra/perf/BoundedTaskQueue.js +16 -18
- package/dist/infra/perf/PromiseDedup.js +24 -0
- package/dist/infra/perf/SharedExclusiveGate.js +113 -0
- package/dist/infra/perf/StoreLock.js +81 -0
- package/dist/media/WaMediaCrypto.js +95 -15
- package/dist/media/WaMediaTransferClient.js +284 -91
- package/dist/media/conn.js +10 -6
- package/dist/media/constants.js +6 -2
- package/dist/message/WaMessageClient.js +31 -33
- package/dist/message/ack.js +6 -6
- package/dist/message/addon-crypto.js +65 -0
- package/dist/message/content.js +198 -9
- package/dist/message/icdc.js +81 -0
- package/dist/message/incoming.js +127 -120
- package/dist/message/index.js +2 -0
- package/dist/message/phash.js +3 -1
- package/dist/message/reporting-token.js +429 -0
- package/dist/message/use-case-secret.js +55 -0
- package/dist/protocol/appstate.js +28 -1
- package/dist/protocol/browser.js +10 -18
- package/dist/protocol/constants.js +26 -1
- package/dist/protocol/defaults.js +6 -0
- package/dist/protocol/index.js +23 -42
- package/dist/protocol/jid.js +140 -52
- package/dist/protocol/media.js +3 -3
- package/dist/protocol/message.js +62 -2
- package/dist/protocol/nodes.js +4 -0
- package/dist/protocol/notification.js +3 -1
- package/dist/protocol/privacy-token.js +20 -0
- package/dist/protocol/privacy.js +58 -0
- package/dist/protocol/stream.js +27 -2
- package/dist/protocol/usync.js +14 -0
- package/dist/retry/codec.js +220 -0
- package/dist/retry/constants.js +1 -1
- package/dist/retry/index.js +7 -5
- package/dist/retry/parse.js +88 -85
- package/dist/retry/replay.js +52 -49
- package/dist/retry/tracker.js +97 -0
- package/dist/signal/api/SignalDeviceSyncApi.js +273 -89
- package/dist/signal/api/SignalDigestSyncApi.js +17 -8
- package/dist/signal/api/SignalIdentitySyncApi.js +66 -36
- package/dist/signal/api/SignalMissingPreKeysSyncApi.js +82 -63
- package/dist/signal/api/SignalRotateKeyApi.js +4 -2
- package/dist/signal/api/SignalSessionSyncApi.js +36 -34
- package/dist/signal/api/result-map.js +13 -0
- package/dist/signal/constants.js +1 -5
- package/dist/signal/crypto/WaAdvSignature.js +11 -7
- package/dist/signal/{store/sqlite.js → encoding.js} +94 -61
- package/dist/signal/group/SenderKeyChain.js +27 -22
- package/dist/signal/group/SenderKeyCodec.js +5 -6
- package/dist/signal/group/SenderKeyManager.js +144 -115
- package/dist/signal/index.js +15 -1
- package/dist/signal/registration/keygen.js +6 -2
- package/dist/signal/registration/utils.js +1 -0
- package/dist/signal/session/SignalProtocol.js +164 -53
- package/dist/signal/session/SignalRatchet.js +24 -15
- package/dist/signal/session/SignalSession.js +14 -9
- package/dist/signal/session/resolver.js +224 -0
- package/dist/store/contracts/privacy-token.store.js +2 -0
- package/dist/store/createStore.js +100 -188
- package/dist/store/index.js +15 -33
- package/dist/store/locks/appstate.lock.js +29 -0
- package/dist/store/locks/auth.lock.js +18 -0
- package/dist/store/locks/contact.lock.js +23 -0
- package/dist/store/locks/device-list.lock.js +23 -0
- package/dist/store/locks/message.lock.js +24 -0
- package/dist/store/locks/participants.lock.js +23 -0
- package/dist/store/locks/privacy-token.lock.js +21 -0
- package/dist/store/locks/retry.lock.js +32 -0
- package/dist/store/locks/sender-key.lock.js +55 -0
- package/dist/store/locks/signal.lock.js +66 -0
- package/dist/store/locks/thread.lock.js +24 -0
- package/dist/store/noop.store.js +4 -7
- package/dist/store/providers/memory/appstate.store.js +36 -14
- package/dist/store/providers/memory/contact.store.js +5 -0
- package/dist/store/providers/memory/device-list.store.js +12 -34
- package/dist/store/providers/memory/message.store.js +11 -5
- package/dist/store/providers/memory/participants.store.js +1 -8
- package/dist/store/providers/memory/privacy-token.store.js +47 -0
- package/dist/store/providers/memory/retry.store.js +77 -2
- package/dist/store/providers/memory/sender-key.store.js +14 -11
- package/dist/store/providers/memory/signal.store.js +54 -25
- package/dist/store/providers/memory/thread.store.js +5 -0
- package/dist/transport/WaComms.js +30 -26
- package/dist/transport/WaWebSocket.js +148 -18
- package/dist/transport/binary/constants.js +1 -31
- package/dist/transport/binary/decoder.js +8 -8
- package/dist/transport/binary/encoder.js +10 -9
- package/dist/transport/binary/index.js +0 -4
- package/dist/transport/index.js +7 -1
- package/dist/transport/keepalive/WaKeepAlive.js +1 -7
- package/dist/transport/node/WaNodeOrchestrator.js +25 -21
- package/dist/transport/node/WaNodeTransport.js +0 -3
- package/dist/transport/node/builders/{accountSync.js → account-sync.js} +15 -35
- package/dist/transport/node/builders/business.js +137 -0
- package/dist/transport/node/builders/global.js +375 -0
- package/dist/transport/node/builders/index.js +29 -17
- package/dist/transport/node/builders/message.js +64 -236
- package/dist/transport/node/builders/pairing.js +2 -29
- package/dist/transport/node/builders/privacy-token.js +46 -0
- package/dist/transport/node/builders/privacy.js +55 -0
- package/dist/transport/node/builders/profile.js +78 -0
- package/dist/transport/node/builders/retry.js +9 -21
- package/dist/transport/node/builders/usync.js +49 -0
- package/dist/transport/node/helpers.js +131 -4
- package/dist/transport/node/usync.js +8 -0
- package/dist/transport/node/xml.js +35 -14
- package/dist/transport/noise/WaClientPayload.js +13 -13
- package/dist/transport/noise/WaFrameCodec.js +47 -32
- package/dist/transport/noise/WaNoiseCert.js +5 -8
- package/dist/transport/noise/WaNoiseSession.js +77 -29
- package/dist/transport/noise/WaNoiseSocket.js +8 -4
- package/dist/transport/proxy.js +34 -0
- package/dist/transport/stream/parse.js +20 -52
- package/dist/types/appstate/WaAppStateCrypto.d.ts +0 -1
- package/dist/types/appstate/WaAppStateSyncClient.d.ts +5 -2
- package/dist/types/appstate/constants.d.ts +1 -0
- package/dist/types/appstate/encoding.d.ts +7 -0
- package/dist/types/appstate/index.d.ts +3 -3
- package/dist/types/appstate/utils.d.ts +0 -3
- package/dist/types/auth/WaAuthClient.d.ts +10 -12
- package/dist/types/auth/flow/WaAuthCredentialsFlow.d.ts +1 -1
- package/dist/types/auth/index.d.ts +0 -4
- package/dist/types/auth/pairing/WaQrFlow.d.ts +1 -1
- package/dist/types/auth/types.d.ts +7 -9
- package/dist/types/client/WaClient.d.ts +42 -25
- package/dist/types/client/WaClientFactory.d.ts +33 -26
- package/dist/types/client/connection/WaConnectionManager.d.ts +66 -0
- package/dist/types/client/connection/WaKeyShareCoordinator.d.ts +14 -0
- package/dist/types/client/connection/WaReceiptQueue.d.ts +13 -0
- package/dist/types/client/coordinators/WaAppStateMutationCoordinator.d.ts +46 -0
- package/dist/types/client/coordinators/WaBusinessCoordinator.d.ts +57 -0
- package/dist/types/client/coordinators/WaIncomingNodeCoordinator.d.ts +3 -2
- package/dist/types/client/coordinators/WaMessageDispatchCoordinator.d.ts +29 -38
- package/dist/types/client/coordinators/WaPassiveTasksCoordinator.d.ts +4 -0
- package/dist/types/client/coordinators/WaPrivacyCoordinator.d.ts +26 -0
- package/dist/types/client/coordinators/WaProfileCoordinator.d.ts +36 -0
- package/dist/types/client/coordinators/WaRetryCoordinator.d.ts +8 -0
- package/dist/types/client/coordinators/WaStreamControlCoordinator.d.ts +3 -2
- package/dist/types/client/coordinators/WaTrustedContactTokenCoordinator.d.ts +45 -0
- package/dist/types/client/dirty.d.ts +1 -0
- package/dist/types/client/events/devices.d.ts +20 -0
- package/dist/types/client/events/group.d.ts +2 -1
- package/dist/types/client/events/identity.d.ts +9 -0
- package/dist/types/client/events/privacy-token.d.ts +7 -0
- package/dist/types/client/history-sync.d.ts +9 -6
- package/dist/types/client/incoming.d.ts +3 -1
- package/dist/types/client/index.d.ts +1 -1
- package/dist/types/client/mailbox.d.ts +3 -5
- package/dist/types/client/messages.d.ts +1 -2
- package/dist/types/client/messaging/fanout.d.ts +14 -0
- package/dist/types/client/messaging/key-protocol.d.ts +18 -0
- package/dist/types/client/messaging/participants.d.ts +13 -0
- package/dist/types/client/persistence/WriteBehindPersistence.d.ts +34 -0
- package/dist/types/client/tokens/cs-token.d.ts +10 -0
- package/dist/types/client/tokens/tc-token.d.ts +5 -0
- package/dist/types/client/types.d.ts +75 -4
- package/dist/types/crypto/core/hkdf.d.ts +0 -6
- package/dist/types/crypto/core/index.d.ts +2 -3
- package/dist/types/crypto/core/nonce.d.ts +2 -0
- package/dist/types/crypto/core/primitives.d.ts +0 -1
- package/dist/types/crypto/core/random.d.ts +2 -7
- package/dist/types/crypto/index.d.ts +0 -1
- package/dist/types/crypto/math/constants.d.ts +4 -2
- package/dist/types/crypto/math/fe.d.ts +30 -0
- package/dist/types/crypto/math/mod.d.ts +0 -2
- package/dist/types/crypto/math/types.d.ts +11 -4
- package/dist/types/index.d.ts +5 -3
- package/dist/types/infra/log/ConsoleLogger.d.ts +2 -1
- package/dist/types/infra/log/PinoLogger.d.ts +1 -1
- package/dist/types/infra/log/types.d.ts +1 -0
- package/dist/types/infra/perf/BackgroundQueue.d.ts +58 -0
- package/dist/types/infra/perf/BoundedTaskQueue.d.ts +1 -1
- package/dist/types/infra/perf/PromiseDedup.d.ts +4 -0
- package/dist/types/infra/perf/SharedExclusiveGate.d.ts +17 -0
- package/dist/types/infra/perf/StoreLock.d.ts +10 -0
- package/dist/types/media/WaMediaCrypto.d.ts +3 -2
- package/dist/types/media/WaMediaTransferClient.d.ts +16 -15
- package/dist/types/media/constants.d.ts +1 -1
- package/dist/types/media/index.d.ts +1 -1
- package/dist/types/media/types.d.ts +15 -2
- package/dist/types/message/addon-crypto.d.ts +25 -0
- package/dist/types/message/content.d.ts +8 -0
- package/dist/types/message/icdc.d.ts +13 -0
- package/dist/types/message/index.d.ts +2 -0
- package/dist/types/message/reporting-token.d.ts +18 -0
- package/dist/types/message/types.d.ts +45 -6
- package/dist/types/message/use-case-secret.d.ts +20 -0
- package/dist/types/protocol/appstate.d.ts +47 -0
- package/dist/types/protocol/constants.d.ts +8 -3
- package/dist/types/protocol/defaults.d.ts +6 -0
- package/dist/types/protocol/index.d.ts +2 -11
- package/dist/types/protocol/jid.d.ts +22 -5
- package/dist/types/protocol/message.d.ts +60 -0
- package/dist/types/protocol/nodes.d.ts +4 -0
- package/dist/types/protocol/notification.d.ts +2 -0
- package/dist/types/protocol/privacy-token.d.ts +17 -0
- package/dist/types/protocol/privacy.d.ts +75 -0
- package/dist/types/protocol/stream.d.ts +30 -0
- package/dist/types/protocol/usync.d.ts +11 -0
- package/dist/types/retry/codec.d.ts +3 -0
- package/dist/types/retry/index.d.ts +4 -3
- package/dist/types/retry/parse.d.ts +5 -2
- package/dist/types/retry/replay.d.ts +0 -4
- package/dist/types/retry/tracker.d.ts +20 -0
- package/dist/types/retry/types.d.ts +10 -4
- package/dist/types/signal/api/SignalDeviceSyncApi.d.ts +15 -2
- package/dist/types/signal/api/SignalDigestSyncApi.d.ts +6 -0
- package/dist/types/signal/api/SignalIdentitySyncApi.d.ts +2 -0
- package/dist/types/signal/api/SignalRotateKeyApi.d.ts +4 -5
- package/dist/types/signal/api/SignalSessionSyncApi.d.ts +8 -6
- package/dist/types/signal/api/result-map.d.ts +1 -0
- package/dist/types/signal/constants.d.ts +0 -3
- package/dist/types/signal/{store/sqlite.d.ts → encoding.d.ts} +3 -3
- package/dist/types/signal/group/SenderKeyCodec.d.ts +4 -6
- package/dist/types/signal/group/SenderKeyManager.d.ts +10 -5
- package/dist/types/signal/index.d.ts +3 -0
- package/dist/types/signal/session/SignalProtocol.d.ts +19 -4
- package/dist/types/signal/session/resolver.d.ts +22 -0
- package/dist/types/store/contracts/appstate.store.d.ts +4 -1
- package/dist/types/store/contracts/contact.store.d.ts +1 -0
- package/dist/types/store/contracts/device-list.store.d.ts +0 -3
- package/dist/types/store/contracts/message.store.d.ts +1 -0
- package/dist/types/store/contracts/participants.store.d.ts +0 -1
- package/dist/types/store/contracts/privacy-token.store.d.ts +16 -0
- package/dist/types/store/contracts/retry.store.d.ts +7 -0
- package/dist/types/store/contracts/sender-key.store.d.ts +0 -1
- package/dist/types/store/contracts/signal.store.d.ts +13 -0
- package/dist/types/store/contracts/thread.store.d.ts +1 -0
- package/dist/types/store/createStore.d.ts +1 -1
- package/dist/types/store/index.d.ts +5 -13
- package/dist/types/store/locks/appstate.lock.d.ts +3 -0
- package/dist/types/store/locks/auth.lock.d.ts +3 -0
- package/dist/types/store/locks/contact.lock.d.ts +3 -0
- package/dist/types/store/locks/device-list.lock.d.ts +2 -0
- package/dist/types/store/locks/message.lock.d.ts +3 -0
- package/dist/types/store/locks/participants.lock.d.ts +2 -0
- package/dist/types/store/locks/privacy-token.lock.d.ts +2 -0
- package/dist/types/store/locks/retry.lock.d.ts +2 -0
- package/dist/types/store/locks/sender-key.lock.d.ts +3 -0
- package/dist/types/store/locks/signal.lock.d.ts +3 -0
- package/dist/types/store/locks/thread.lock.d.ts +3 -0
- package/dist/types/store/providers/memory/appstate.store.d.ts +3 -1
- package/dist/types/store/providers/memory/contact.store.d.ts +1 -0
- package/dist/types/store/providers/memory/device-list.store.d.ts +0 -3
- package/dist/types/store/providers/memory/message.store.d.ts +1 -0
- package/dist/types/store/providers/memory/participants.store.d.ts +0 -1
- package/dist/types/store/providers/memory/privacy-token.store.d.ts +13 -0
- package/dist/types/store/providers/memory/retry.store.d.ts +8 -0
- package/dist/types/store/providers/memory/sender-key.store.d.ts +0 -1
- package/dist/types/store/providers/memory/signal.store.d.ts +8 -1
- package/dist/types/store/providers/memory/thread.store.d.ts +1 -0
- package/dist/types/store/types.d.ts +49 -58
- package/dist/types/transport/WaWebSocket.d.ts +3 -1
- package/dist/types/transport/binary/constants.d.ts +0 -30
- package/dist/types/transport/binary/index.d.ts +0 -1
- package/dist/types/transport/index.d.ts +2 -1
- package/dist/types/transport/keepalive/WaKeepAlive.d.ts +0 -1
- package/dist/types/transport/node/WaNodeOrchestrator.d.ts +3 -4
- package/dist/types/transport/node/WaNodeTransport.d.ts +0 -9
- package/dist/types/transport/node/builders/business.d.ts +29 -0
- package/dist/types/transport/node/builders/global.d.ts +102 -0
- package/dist/types/transport/node/builders/group.d.ts +4 -6
- package/dist/types/transport/node/builders/index.d.ts +7 -3
- package/dist/types/transport/node/builders/message.d.ts +20 -30
- package/dist/types/transport/node/builders/pairing.d.ts +0 -2
- package/dist/types/transport/node/builders/privacy-token.d.ts +9 -0
- package/dist/types/transport/node/builders/privacy.d.ts +7 -0
- package/dist/types/transport/node/builders/profile.d.ts +8 -0
- package/dist/types/transport/node/builders/retry.d.ts +2 -5
- package/dist/types/transport/node/builders/usync.d.ts +21 -0
- package/dist/types/transport/node/helpers.d.ts +13 -0
- package/dist/types/transport/node/usync.d.ts +2 -0
- package/dist/types/transport/noise/WaFrameCodec.d.ts +3 -0
- package/dist/types/transport/noise/WaNoiseSession.d.ts +4 -2
- package/dist/types/transport/noise/WaNoiseSocket.d.ts +4 -2
- package/dist/types/transport/proxy.d.ts +6 -0
- package/dist/types/transport/stream/parse.d.ts +0 -1
- package/dist/types/transport/types.d.ts +18 -1
- package/dist/types/util/bytes.d.ts +5 -0
- package/dist/types/util/index.d.ts +5 -0
- package/dist/types/util/primitives.d.ts +2 -0
- package/dist/util/bytes.js +72 -46
- package/dist/util/coercion.js +6 -14
- package/dist/util/index.js +23 -0
- package/dist/util/primitives.js +42 -14
- package/package.json +52 -9
- package/proto/index.js +1 -1
- package/dist/crypto/core/constants.js +0 -4
- package/dist/crypto/core/encoding.js +0 -29
- package/dist/esm/crypto/core/constants.js +0 -1
- package/dist/esm/crypto/core/encoding.js +0 -25
- package/dist/esm/retry/outbound.js +0 -83
- package/dist/esm/store/providers/sqlite/BaseSqliteStore.js +0 -37
- package/dist/esm/store/providers/sqlite/appstate.store.js +0 -169
- package/dist/esm/store/providers/sqlite/auth.store.js +0 -176
- package/dist/esm/store/providers/sqlite/connection.js +0 -240
- package/dist/esm/store/providers/sqlite/contact.store.js +0 -61
- package/dist/esm/store/providers/sqlite/device-list.store.js +0 -155
- package/dist/esm/store/providers/sqlite/message.store.js +0 -119
- package/dist/esm/store/providers/sqlite/migrations.js +0 -347
- package/dist/esm/store/providers/sqlite/participants.store.js +0 -85
- package/dist/esm/store/providers/sqlite/retry.store.js +0 -144
- package/dist/esm/store/providers/sqlite/sender-key.store.js +0 -203
- package/dist/esm/store/providers/sqlite/signal.store.js +0 -353
- package/dist/esm/store/providers/sqlite/thread.store.js +0 -72
- package/dist/esm/util/base64.js +0 -18
- package/dist/esm/util/signal-address.js +0 -5
- package/dist/retry/outbound.js +0 -88
- package/dist/store/providers/sqlite/BaseSqliteStore.js +0 -41
- package/dist/store/providers/sqlite/appstate.store.js +0 -173
- package/dist/store/providers/sqlite/auth.store.js +0 -180
- package/dist/store/providers/sqlite/connection.js +0 -276
- package/dist/store/providers/sqlite/contact.store.js +0 -65
- package/dist/store/providers/sqlite/device-list.store.js +0 -159
- package/dist/store/providers/sqlite/message.store.js +0 -123
- package/dist/store/providers/sqlite/migrations.js +0 -350
- package/dist/store/providers/sqlite/participants.store.js +0 -89
- package/dist/store/providers/sqlite/retry.store.js +0 -148
- package/dist/store/providers/sqlite/sender-key.store.js +0 -207
- package/dist/store/providers/sqlite/signal.store.js +0 -357
- package/dist/store/providers/sqlite/thread.store.js +0 -76
- package/dist/types/appstate/store/sqlite.d.ts +0 -21
- package/dist/types/crypto/core/constants.d.ts +0 -1
- package/dist/types/crypto/core/encoding.d.ts +0 -11
- package/dist/types/retry/outbound.d.ts +0 -4
- package/dist/types/store/providers/sqlite/BaseSqliteStore.d.ts +0 -12
- package/dist/types/store/providers/sqlite/appstate.store.d.ts +0 -15
- package/dist/types/store/providers/sqlite/auth.store.d.ts +0 -10
- package/dist/types/store/providers/sqlite/connection.d.ts +0 -10
- package/dist/types/store/providers/sqlite/contact.store.d.ts +0 -10
- package/dist/types/store/providers/sqlite/device-list.store.d.ts +0 -18
- package/dist/types/store/providers/sqlite/message.store.d.ts +0 -11
- package/dist/types/store/providers/sqlite/migrations.d.ts +0 -3
- package/dist/types/store/providers/sqlite/participants.store.d.ts +0 -13
- package/dist/types/store/providers/sqlite/retry.store.d.ts +0 -16
- package/dist/types/store/providers/sqlite/sender-key.store.d.ts +0 -25
- package/dist/types/store/providers/sqlite/signal.store.d.ts +0 -46
- package/dist/types/store/providers/sqlite/thread.store.d.ts +0 -11
- package/dist/types/util/base64.d.ts +0 -4
- package/dist/types/util/signal-address.d.ts +0 -2
- package/dist/util/base64.js +0 -24
- package/dist/util/signal-address.js +0 -8
- /package/dist/types/transport/node/builders/{accountSync.d.ts → account-sync.d.ts} +0 -0
|
@@ -5,7 +5,9 @@ export async function computePhashV2(participants) {
|
|
|
5
5
|
if (participants.length === 0) {
|
|
6
6
|
return '2:';
|
|
7
7
|
}
|
|
8
|
-
const canonical = participants.
|
|
8
|
+
const canonical = new Array(participants.length);
|
|
9
|
+
for (let i = 0; i < participants.length; i += 1)
|
|
10
|
+
canonical[i] = toPhashCanonicalWid(participants[i]);
|
|
9
11
|
const joined = canonical.sort().join('');
|
|
10
12
|
const digest = await sha256(TEXT_ENCODER.encode(joined));
|
|
11
13
|
return `2:${bytesToBase64(digest.subarray(0, 6))}`;
|
|
@@ -0,0 +1,425 @@
|
|
|
1
|
+
import { hkdf, hmacSign, importHmacKey } from '../crypto/index.js';
|
|
2
|
+
import { proto } from '../proto.js';
|
|
3
|
+
import { base64ToBytesChecked, concatBytes, EMPTY_BYTES, TEXT_ENCODER, toBytesView } from '../util/bytes.js';
|
|
4
|
+
const WA_REPORTING_TOKEN_BYTES = 16;
|
|
5
|
+
const WA_REPORTING_TOKEN_KEY_BYTES = 32;
|
|
6
|
+
const WA_REPORTING_TOKEN_USE_CASE = 'Report Token';
|
|
7
|
+
const WA_REPORTING_TOKEN_CONFIG_BASE64 = 'CgQIARIACjQIAxIwKgQIAhIAKgQIAxIAKgQICBIAKgQICxIAKhAIERIMKgQIFRIAKgQIFhIAKgQIGRIACioIBBImCAIqBggBEgIIAioGCBASAggCKhIIERIOCAIqBAgVEgAqBAgWEgAKOggFEjYIAioGCAMSAggCKgYIBBICCAIqBggFEgIIAioGCBASAggCKhIIERIOCAIqBAgVEgAqBAgWEgAKIggGEh4qBAgBEgAqEAgREgwqBAgVEgAqBAgWEgAqBAgeEgAKLggHEioqBAgCEgAqBAgHEgAqBAgKEgAqEAgREgwqBAgVEgAqBAgWEgAqBAgUEgAKLggIEioqBAgCEgAqBAgHEgAqBAgJEgAqEAgREgwqBAgVEgAqBAgWEgAqBAgVEgAKNAgJEjAqBAgCEgAqBAgGEgAqBAgHEgAqBAgNEgAqEAgREgwqBAgVEgAqBAgWEgAqBAgUEgAKKAgMEiQIAioGCAESAggCKgYIAhICCAIqCAgOEgQIAiABKgYIDxICCAIKKggSEiYIAioGCAYSAggCKgYIEBICCAIqEggREg4IAioECBUSACoECBYSAAouCBoSKioECAQSACoECAUSACoECAgSACoECA0SACoQCBESDCoECBUSACoECBYSAApCCBwSPggCKgYIARICCAIqBggCEgIIAioGCAQSAggCKgYIBRICCAIqBggGEgIIAioSCAcSDggCKgQIFRIAKgQIFhIACgwIJRIIKgYIARICIAEKUggxEk4IAioGCAISAggCKhYIAxISCAIqBggBEgIIAioGCAISAggCKhIIBRIOCAIqBAgVEgAqBAgWEgAqFggIEhIIAioGCAESAggCKgYIAhICCAIKDAg1EggqBggBEgIgAQoOCDcSCggCKgYIARICIAEKDgg6EgoIAioGCAESAiABCg4IOxIKCAIqBggBEgIgAQpSCDwSTggCKgYIAhICCAIqFggDEhIIAioGCAESAggCKgYIAhICCAIqEggFEg4IAioECBUSACoECBYSACoWCAgSEggCKgYIARICCAIqBggCEgIIAgpSCEASTggCKgYIAhICCAIqFggDEhIIAioGCAESAggCKgYIAhICCAIqEggFEg4IAioECBUSACoECBYSACoWCAgSEggCKgYIARICCAIqBggCEgIIAgo2CEISMggCKgQIAhIAKgQIBhIAKgQIBxIAKgQIDRIAKhAIERIMKgQIFRIAKgQIFhIAKgQIFBIACg4IShIKCAIqBggBEgIgAQoOCFcSCggCKgYIARICIAEKMghYEi4IAioGCAESAggCKg4IAhIKCAIqBggBEgIIAioSCAMSDggCKgQIFRIAKgQIFhIACg4IXBIKCAIqBggBEgIgAQoOCF0SCggCKgYIARICIAEKDgheEgoIAioGCAESAiAB';
|
|
8
|
+
const WA_REPORTING_TOKEN_CONFIG_BYTES = base64ToBytesChecked(WA_REPORTING_TOKEN_CONFIG_BASE64, 'reporting_token.config');
|
|
9
|
+
export const WA_REPORTING_TOKEN_VERSION = 2;
|
|
10
|
+
let reportingTokenConfigSpec = null;
|
|
11
|
+
const reportingTokenConfigCache = new Map();
|
|
12
|
+
export async function buildReportingTokenArtifacts(input) {
|
|
13
|
+
const stanzaId = input.stanzaId.trim();
|
|
14
|
+
if (!stanzaId || !isMessageReportingTokenCompatible(input.message)) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
const messageSecret = input.message.messageContextInfo?.messageSecret;
|
|
18
|
+
if (!messageSecret || toBytesView(messageSecret).byteLength === 0) {
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
const reportingTokenContent = computeReportingTokenContent(proto.Message.encode(input.message).finish(), input.version ?? WA_REPORTING_TOKEN_VERSION);
|
|
22
|
+
if (reportingTokenContent.byteLength === 0) {
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
const secretInfo = TEXT_ENCODER.encode(stanzaId + input.senderUserJid + input.remoteJid + WA_REPORTING_TOKEN_USE_CASE);
|
|
26
|
+
const reportingTokenKey = await hkdf(toBytesView(messageSecret), null, secretInfo, WA_REPORTING_TOKEN_KEY_BYTES);
|
|
27
|
+
const hmacKey = await importHmacKey(reportingTokenKey);
|
|
28
|
+
const reportingToken = (await hmacSign(hmacKey, reportingTokenContent)).subarray(0, WA_REPORTING_TOKEN_BYTES);
|
|
29
|
+
const version = input.version ?? WA_REPORTING_TOKEN_VERSION;
|
|
30
|
+
return {
|
|
31
|
+
node: {
|
|
32
|
+
tag: 'reporting',
|
|
33
|
+
attrs: {},
|
|
34
|
+
content: [
|
|
35
|
+
{
|
|
36
|
+
tag: 'reporting_token',
|
|
37
|
+
attrs: {
|
|
38
|
+
v: String(version)
|
|
39
|
+
},
|
|
40
|
+
content: reportingToken
|
|
41
|
+
}
|
|
42
|
+
]
|
|
43
|
+
},
|
|
44
|
+
version,
|
|
45
|
+
reportingToken,
|
|
46
|
+
reportingTokenContent,
|
|
47
|
+
reportingTokenKey
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
function isMessageReportingTokenCompatible(message) {
|
|
51
|
+
return (!message.reactionMessage &&
|
|
52
|
+
!message.encReactionMessage &&
|
|
53
|
+
!message.encEventResponseMessage &&
|
|
54
|
+
!message.pollUpdateMessage);
|
|
55
|
+
}
|
|
56
|
+
function computeReportingTokenContent(messageBytes, version) {
|
|
57
|
+
const reportingConfig = getReportingTokenConfig(version);
|
|
58
|
+
const extracted = extractProtobufFieldParts(messageBytes, 0, messageBytes.length, reportingConfig, reportingConfig);
|
|
59
|
+
if (extracted.totalSize === 0) {
|
|
60
|
+
return EMPTY_BYTES;
|
|
61
|
+
}
|
|
62
|
+
const parts = new Array(extracted.parts.length);
|
|
63
|
+
for (let index = 0; index < extracted.parts.length; index += 1) {
|
|
64
|
+
parts[index] = extracted.parts[index].bytes;
|
|
65
|
+
}
|
|
66
|
+
return concatBytes(parts);
|
|
67
|
+
}
|
|
68
|
+
function getReportingTokenConfig(version) {
|
|
69
|
+
const cached = reportingTokenConfigCache.get(version);
|
|
70
|
+
if (cached) {
|
|
71
|
+
return cached;
|
|
72
|
+
}
|
|
73
|
+
const spec = getReportingTokenConfigSpec();
|
|
74
|
+
const fields = new Map();
|
|
75
|
+
for (const [fieldNumber, fieldSpec] of spec.fields) {
|
|
76
|
+
const selectedField = selectFieldForVersion(version, fieldNumber, fieldSpec);
|
|
77
|
+
if (selectedField) {
|
|
78
|
+
fields.set(fieldNumber, selectedField);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
const config = { fields };
|
|
82
|
+
reportingTokenConfigCache.set(version, config);
|
|
83
|
+
return config;
|
|
84
|
+
}
|
|
85
|
+
function getReportingTokenConfigSpec() {
|
|
86
|
+
if (reportingTokenConfigSpec) {
|
|
87
|
+
return reportingTokenConfigSpec;
|
|
88
|
+
}
|
|
89
|
+
reportingTokenConfigSpec = parseReportingTokenConfigSpec(WA_REPORTING_TOKEN_CONFIG_BYTES);
|
|
90
|
+
return reportingTokenConfigSpec;
|
|
91
|
+
}
|
|
92
|
+
function parseReportingTokenConfigSpec(bytes) {
|
|
93
|
+
let cursor = 0;
|
|
94
|
+
const fields = new Map();
|
|
95
|
+
while (cursor < bytes.length) {
|
|
96
|
+
const tag = readVarint(bytes, cursor, bytes.length);
|
|
97
|
+
cursor = tag.next;
|
|
98
|
+
const fieldNumber = Math.floor(tag.value / 8);
|
|
99
|
+
const wireType = tag.value & 0x07;
|
|
100
|
+
if (fieldNumber === 1 && wireType === 2) {
|
|
101
|
+
const lengthInfo = readVarint(bytes, cursor, bytes.length);
|
|
102
|
+
const entryStart = lengthInfo.next;
|
|
103
|
+
const entryEnd = entryStart + lengthInfo.value;
|
|
104
|
+
if (entryEnd > bytes.length) {
|
|
105
|
+
throw new Error('invalid reporting token config map entry length');
|
|
106
|
+
}
|
|
107
|
+
const parsedEntry = parseReportingTokenConfigMapEntry(bytes, entryStart, entryEnd);
|
|
108
|
+
if (parsedEntry) {
|
|
109
|
+
fields.set(parsedEntry.key, parsedEntry.value);
|
|
110
|
+
}
|
|
111
|
+
cursor = entryEnd;
|
|
112
|
+
continue;
|
|
113
|
+
}
|
|
114
|
+
cursor = skipField(bytes, cursor, bytes.length, wireType);
|
|
115
|
+
}
|
|
116
|
+
return { fields };
|
|
117
|
+
}
|
|
118
|
+
function parseReportingTokenConfigMapEntry(bytes, start, end) {
|
|
119
|
+
let cursor = start;
|
|
120
|
+
let key = null;
|
|
121
|
+
let value = null;
|
|
122
|
+
while (cursor < end) {
|
|
123
|
+
const tag = readVarint(bytes, cursor, end);
|
|
124
|
+
cursor = tag.next;
|
|
125
|
+
const fieldNumber = Math.floor(tag.value / 8);
|
|
126
|
+
const wireType = tag.value & 0x07;
|
|
127
|
+
if (fieldNumber === 1 && wireType === 0) {
|
|
128
|
+
const keyVarint = readVarint(bytes, cursor, end);
|
|
129
|
+
key = keyVarint.value;
|
|
130
|
+
cursor = keyVarint.next;
|
|
131
|
+
continue;
|
|
132
|
+
}
|
|
133
|
+
if (fieldNumber === 2 && wireType === 2) {
|
|
134
|
+
const valueLength = readVarint(bytes, cursor, end);
|
|
135
|
+
const valueStart = valueLength.next;
|
|
136
|
+
const valueEnd = valueStart + valueLength.value;
|
|
137
|
+
if (valueEnd > end) {
|
|
138
|
+
throw new Error('invalid reporting token config field value length');
|
|
139
|
+
}
|
|
140
|
+
value = parseReportingTokenFieldSpec(bytes, valueStart, valueEnd);
|
|
141
|
+
cursor = valueEnd;
|
|
142
|
+
continue;
|
|
143
|
+
}
|
|
144
|
+
cursor = skipField(bytes, cursor, end, wireType);
|
|
145
|
+
}
|
|
146
|
+
if (key === null || value === null) {
|
|
147
|
+
return null;
|
|
148
|
+
}
|
|
149
|
+
return { key, value };
|
|
150
|
+
}
|
|
151
|
+
function parseReportingTokenFieldSpec(bytes, start, end) {
|
|
152
|
+
let cursor = start;
|
|
153
|
+
let minVersion = 1;
|
|
154
|
+
let maxVersion = null;
|
|
155
|
+
let isMessage = false;
|
|
156
|
+
const subfields = new Map();
|
|
157
|
+
while (cursor < end) {
|
|
158
|
+
const tag = readVarint(bytes, cursor, end);
|
|
159
|
+
cursor = tag.next;
|
|
160
|
+
const fieldNumber = Math.floor(tag.value / 8);
|
|
161
|
+
const wireType = tag.value & 0x07;
|
|
162
|
+
if (fieldNumber === 1 && wireType === 0) {
|
|
163
|
+
const value = readVarint(bytes, cursor, end);
|
|
164
|
+
minVersion = value.value;
|
|
165
|
+
cursor = value.next;
|
|
166
|
+
continue;
|
|
167
|
+
}
|
|
168
|
+
if (fieldNumber === 2 && wireType === 0) {
|
|
169
|
+
const value = readVarint(bytes, cursor, end);
|
|
170
|
+
maxVersion = value.value;
|
|
171
|
+
cursor = value.next;
|
|
172
|
+
continue;
|
|
173
|
+
}
|
|
174
|
+
if (fieldNumber === 4 && wireType === 0) {
|
|
175
|
+
const value = readVarint(bytes, cursor, end);
|
|
176
|
+
isMessage = value.value !== 0;
|
|
177
|
+
cursor = value.next;
|
|
178
|
+
continue;
|
|
179
|
+
}
|
|
180
|
+
if (fieldNumber === 5 && wireType === 2) {
|
|
181
|
+
const lengthInfo = readVarint(bytes, cursor, end);
|
|
182
|
+
const entryStart = lengthInfo.next;
|
|
183
|
+
const entryEnd = entryStart + lengthInfo.value;
|
|
184
|
+
if (entryEnd > end) {
|
|
185
|
+
throw new Error('invalid reporting token subfield map entry length');
|
|
186
|
+
}
|
|
187
|
+
const parsedEntry = parseReportingTokenConfigMapEntry(bytes, entryStart, entryEnd);
|
|
188
|
+
if (parsedEntry) {
|
|
189
|
+
subfields.set(parsedEntry.key, parsedEntry.value);
|
|
190
|
+
}
|
|
191
|
+
cursor = entryEnd;
|
|
192
|
+
continue;
|
|
193
|
+
}
|
|
194
|
+
cursor = skipField(bytes, cursor, end, wireType);
|
|
195
|
+
}
|
|
196
|
+
return {
|
|
197
|
+
minVersion,
|
|
198
|
+
maxVersion,
|
|
199
|
+
isMessage,
|
|
200
|
+
subfields: subfields.size > 0 ? subfields : null
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
function selectFieldForVersion(version, fieldNumber, fieldSpec) {
|
|
204
|
+
if (version < fieldSpec.minVersion) {
|
|
205
|
+
return null;
|
|
206
|
+
}
|
|
207
|
+
if (fieldSpec.maxVersion !== null && version > fieldSpec.maxVersion) {
|
|
208
|
+
return null;
|
|
209
|
+
}
|
|
210
|
+
if (!fieldSpec.subfields) {
|
|
211
|
+
return {
|
|
212
|
+
fieldNumber,
|
|
213
|
+
isMessage: fieldSpec.isMessage,
|
|
214
|
+
subfields: null
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
const selectedSubfields = new Map();
|
|
218
|
+
for (const [subFieldNumber, subFieldSpec] of fieldSpec.subfields) {
|
|
219
|
+
const selectedField = selectFieldForVersion(version, subFieldNumber, subFieldSpec);
|
|
220
|
+
if (selectedField) {
|
|
221
|
+
selectedSubfields.set(subFieldNumber, selectedField);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return {
|
|
225
|
+
fieldNumber,
|
|
226
|
+
isMessage: fieldSpec.isMessage,
|
|
227
|
+
subfields: {
|
|
228
|
+
fields: selectedSubfields
|
|
229
|
+
}
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
function extractProtobufFieldParts(bytes, start, end, config, rootConfig) {
|
|
233
|
+
const parts = [];
|
|
234
|
+
let totalSize = 0;
|
|
235
|
+
let cursor = start;
|
|
236
|
+
while (cursor < end) {
|
|
237
|
+
const parsedField = parseProtobufField(bytes, cursor, end);
|
|
238
|
+
cursor = parsedField.next;
|
|
239
|
+
const configuredField = config.fields.get(parsedField.fieldNumber);
|
|
240
|
+
if (!configuredField) {
|
|
241
|
+
continue;
|
|
242
|
+
}
|
|
243
|
+
if (!configuredField.isMessage &&
|
|
244
|
+
(!configuredField.subfields || configuredField.subfields.fields.size === 0)) {
|
|
245
|
+
const fieldBytes = bytes.subarray(parsedField.start, parsedField.next);
|
|
246
|
+
parts.push({
|
|
247
|
+
fieldNumber: parsedField.fieldNumber,
|
|
248
|
+
bytes: fieldBytes
|
|
249
|
+
});
|
|
250
|
+
totalSize += fieldBytes.length;
|
|
251
|
+
continue;
|
|
252
|
+
}
|
|
253
|
+
if (parsedField.wireType !== 2) {
|
|
254
|
+
continue;
|
|
255
|
+
}
|
|
256
|
+
const nestedConfig = configuredField.isMessage ? rootConfig : configuredField.subfields;
|
|
257
|
+
if (!nestedConfig) {
|
|
258
|
+
continue;
|
|
259
|
+
}
|
|
260
|
+
const nestedFields = extractProtobufFieldParts(bytes, parsedField.valueStart, parsedField.valueEnd, nestedConfig, rootConfig);
|
|
261
|
+
if (nestedFields.parts.length === 0 || nestedFields.totalSize === 0) {
|
|
262
|
+
continue;
|
|
263
|
+
}
|
|
264
|
+
const tagBytes = encodeVarint(parsedField.tag);
|
|
265
|
+
const nestedLengthBytes = encodeVarint(nestedFields.totalSize);
|
|
266
|
+
const fieldBytes = new Uint8Array(tagBytes.length + nestedLengthBytes.length + nestedFields.totalSize);
|
|
267
|
+
fieldBytes.set(tagBytes, 0);
|
|
268
|
+
fieldBytes.set(nestedLengthBytes, tagBytes.length);
|
|
269
|
+
let nestedOffset = tagBytes.length + nestedLengthBytes.length;
|
|
270
|
+
for (const nestedPart of nestedFields.parts) {
|
|
271
|
+
fieldBytes.set(nestedPart.bytes, nestedOffset);
|
|
272
|
+
nestedOffset += nestedPart.bytes.length;
|
|
273
|
+
}
|
|
274
|
+
parts.push({
|
|
275
|
+
fieldNumber: parsedField.fieldNumber,
|
|
276
|
+
bytes: fieldBytes
|
|
277
|
+
});
|
|
278
|
+
totalSize += fieldBytes.length;
|
|
279
|
+
}
|
|
280
|
+
parts.sort((left, right) => left.fieldNumber - right.fieldNumber);
|
|
281
|
+
return {
|
|
282
|
+
parts,
|
|
283
|
+
totalSize
|
|
284
|
+
};
|
|
285
|
+
}
|
|
286
|
+
function parseProtobufField(bytes, start, end) {
|
|
287
|
+
const tag = readVarint(bytes, start, end);
|
|
288
|
+
const tagValue = tag.value;
|
|
289
|
+
if (tagValue <= 0 || tagValue > 4294967295) {
|
|
290
|
+
throw new Error(`protobuf field tag out of bounds: ${tagValue}`);
|
|
291
|
+
}
|
|
292
|
+
const fieldNumber = Math.floor(tagValue / 8);
|
|
293
|
+
if (fieldNumber < 1) {
|
|
294
|
+
throw new Error(`invalid protobuf field number: ${fieldNumber}`);
|
|
295
|
+
}
|
|
296
|
+
const wireType = tagValue & 0x07;
|
|
297
|
+
if (wireType === 0) {
|
|
298
|
+
const value = readVarint(bytes, tag.next, end);
|
|
299
|
+
return {
|
|
300
|
+
tag: tagValue,
|
|
301
|
+
fieldNumber,
|
|
302
|
+
wireType,
|
|
303
|
+
start,
|
|
304
|
+
next: value.next,
|
|
305
|
+
valueStart: value.next,
|
|
306
|
+
valueEnd: value.next
|
|
307
|
+
};
|
|
308
|
+
}
|
|
309
|
+
if (wireType === 1) {
|
|
310
|
+
const next = tag.next + 8;
|
|
311
|
+
if (next > end) {
|
|
312
|
+
throw new Error('invalid protobuf fixed64 field length');
|
|
313
|
+
}
|
|
314
|
+
return {
|
|
315
|
+
tag: tagValue,
|
|
316
|
+
fieldNumber,
|
|
317
|
+
wireType,
|
|
318
|
+
start,
|
|
319
|
+
next,
|
|
320
|
+
valueStart: next,
|
|
321
|
+
valueEnd: next
|
|
322
|
+
};
|
|
323
|
+
}
|
|
324
|
+
if (wireType === 2) {
|
|
325
|
+
const valueLength = readVarint(bytes, tag.next, end);
|
|
326
|
+
const valueStart = valueLength.next;
|
|
327
|
+
const valueEnd = valueStart + valueLength.value;
|
|
328
|
+
if (valueEnd > end) {
|
|
329
|
+
throw new Error('invalid protobuf length-delimited field length');
|
|
330
|
+
}
|
|
331
|
+
return {
|
|
332
|
+
tag: tagValue,
|
|
333
|
+
fieldNumber,
|
|
334
|
+
wireType,
|
|
335
|
+
start,
|
|
336
|
+
next: valueEnd,
|
|
337
|
+
valueStart,
|
|
338
|
+
valueEnd
|
|
339
|
+
};
|
|
340
|
+
}
|
|
341
|
+
if (wireType === 5) {
|
|
342
|
+
const next = tag.next + 4;
|
|
343
|
+
if (next > end) {
|
|
344
|
+
throw new Error('invalid protobuf fixed32 field length');
|
|
345
|
+
}
|
|
346
|
+
return {
|
|
347
|
+
tag: tagValue,
|
|
348
|
+
fieldNumber,
|
|
349
|
+
wireType,
|
|
350
|
+
start,
|
|
351
|
+
next,
|
|
352
|
+
valueStart: next,
|
|
353
|
+
valueEnd: next
|
|
354
|
+
};
|
|
355
|
+
}
|
|
356
|
+
throw new Error(`unsupported protobuf wire type: ${wireType}`);
|
|
357
|
+
}
|
|
358
|
+
function readVarint(bytes, start, end) {
|
|
359
|
+
let cursor = start;
|
|
360
|
+
let value = 0;
|
|
361
|
+
let factor = 1;
|
|
362
|
+
while (cursor < end) {
|
|
363
|
+
const byte = bytes[cursor];
|
|
364
|
+
value += (byte & 0x7f) * factor;
|
|
365
|
+
if (!Number.isSafeInteger(value)) {
|
|
366
|
+
throw new Error('varint exceeds safe integer range');
|
|
367
|
+
}
|
|
368
|
+
cursor += 1;
|
|
369
|
+
if ((byte & 0x80) === 0) {
|
|
370
|
+
return {
|
|
371
|
+
value,
|
|
372
|
+
next: cursor
|
|
373
|
+
};
|
|
374
|
+
}
|
|
375
|
+
factor *= 128;
|
|
376
|
+
if (factor > 2 ** 56) {
|
|
377
|
+
throw new Error('varint exceeds supported range');
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
throw new Error('unexpected end of buffer while reading varint');
|
|
381
|
+
}
|
|
382
|
+
function skipField(bytes, start, end, wireType) {
|
|
383
|
+
if (wireType === 0) {
|
|
384
|
+
return readVarint(bytes, start, end).next;
|
|
385
|
+
}
|
|
386
|
+
if (wireType === 1) {
|
|
387
|
+
const next = start + 8;
|
|
388
|
+
if (next > end) {
|
|
389
|
+
throw new Error('invalid fixed64 field size while skipping');
|
|
390
|
+
}
|
|
391
|
+
return next;
|
|
392
|
+
}
|
|
393
|
+
if (wireType === 2) {
|
|
394
|
+
const lengthInfo = readVarint(bytes, start, end);
|
|
395
|
+
const next = lengthInfo.next + lengthInfo.value;
|
|
396
|
+
if (next > end) {
|
|
397
|
+
throw new Error('invalid length-delimited field size while skipping');
|
|
398
|
+
}
|
|
399
|
+
return next;
|
|
400
|
+
}
|
|
401
|
+
if (wireType === 5) {
|
|
402
|
+
const next = start + 4;
|
|
403
|
+
if (next > end) {
|
|
404
|
+
throw new Error('invalid fixed32 field size while skipping');
|
|
405
|
+
}
|
|
406
|
+
return next;
|
|
407
|
+
}
|
|
408
|
+
throw new Error(`unsupported wire type while skipping field: ${wireType}`);
|
|
409
|
+
}
|
|
410
|
+
function encodeVarint(value) {
|
|
411
|
+
if (!Number.isSafeInteger(value) || value < 0) {
|
|
412
|
+
throw new Error(`invalid varint value: ${value}`);
|
|
413
|
+
}
|
|
414
|
+
const bytes = new Uint8Array(10);
|
|
415
|
+
let length = 0;
|
|
416
|
+
let current = value;
|
|
417
|
+
while (current >= 128) {
|
|
418
|
+
bytes[length] = (current % 128) + 128;
|
|
419
|
+
length += 1;
|
|
420
|
+
current = Math.floor(current / 128);
|
|
421
|
+
}
|
|
422
|
+
bytes[length] = current;
|
|
423
|
+
length += 1;
|
|
424
|
+
return bytes.subarray(0, length);
|
|
425
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { hkdf, randomBytesAsync } from '../crypto/index.js';
|
|
2
|
+
import { TEXT_ENCODER, toBytesView } from '../util/bytes.js';
|
|
3
|
+
export const WA_MESSAGE_SECRET_BYTES = 32;
|
|
4
|
+
export const WA_USE_CASE_SECRET_MODIFICATION_TYPES = Object.freeze({
|
|
5
|
+
POLL_VOTE: 'Poll Vote',
|
|
6
|
+
ENC_REACTION: 'Enc Reaction',
|
|
7
|
+
ENC_COMMENT: 'Enc Comment',
|
|
8
|
+
REPORT_TOKEN: 'Report Token',
|
|
9
|
+
EVENT_RESPONSE: 'Event Response',
|
|
10
|
+
EVENT_EDIT_ENCRYPTED: 'Event Edit',
|
|
11
|
+
MESSAGE_EDIT: 'Message Edit'
|
|
12
|
+
});
|
|
13
|
+
export function assertMessageSecret(messageSecret, context = 'message secret') {
|
|
14
|
+
const bytes = toBytesView(messageSecret);
|
|
15
|
+
if (bytes.byteLength !== WA_MESSAGE_SECRET_BYTES) {
|
|
16
|
+
throw new Error(`${context} must be ${WA_MESSAGE_SECRET_BYTES} bytes (got ${bytes.byteLength})`);
|
|
17
|
+
}
|
|
18
|
+
return bytes;
|
|
19
|
+
}
|
|
20
|
+
export async function ensureMessageSecret(message) {
|
|
21
|
+
const messageSecret = message.messageContextInfo?.messageSecret;
|
|
22
|
+
if (messageSecret && toBytesView(messageSecret).byteLength > 0) {
|
|
23
|
+
return message;
|
|
24
|
+
}
|
|
25
|
+
const generatedMessageSecret = await randomBytesAsync(WA_MESSAGE_SECRET_BYTES);
|
|
26
|
+
return {
|
|
27
|
+
...message,
|
|
28
|
+
messageContextInfo: {
|
|
29
|
+
...(message.messageContextInfo ?? {}),
|
|
30
|
+
messageSecret: generatedMessageSecret
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
export async function createUseCaseSecret(input) {
|
|
35
|
+
if (!input.stanzaId.trim()) {
|
|
36
|
+
throw new Error('stanza id must be a non-empty string');
|
|
37
|
+
}
|
|
38
|
+
if (!input.parentMsgOriginalSender.trim()) {
|
|
39
|
+
throw new Error('parent message original sender must be a non-empty string');
|
|
40
|
+
}
|
|
41
|
+
if (!input.modificationSender.trim()) {
|
|
42
|
+
throw new Error('modification sender must be a non-empty string');
|
|
43
|
+
}
|
|
44
|
+
const secretInfo = TEXT_ENCODER.encode(input.stanzaId +
|
|
45
|
+
input.parentMsgOriginalSender +
|
|
46
|
+
input.modificationSender +
|
|
47
|
+
input.modificationType);
|
|
48
|
+
return hkdf(assertMessageSecret(input.messageSecret), null, secretInfo, WA_MESSAGE_SECRET_BYTES);
|
|
49
|
+
}
|
|
@@ -32,3 +32,30 @@ export const WA_APP_STATE_KDF_INFO = Object.freeze({
|
|
|
32
32
|
MUTATION_KEYS: 'WhatsApp Mutation Keys',
|
|
33
33
|
PATCH_INTEGRITY: 'WhatsApp Patch Integrity'
|
|
34
34
|
});
|
|
35
|
+
export const WA_APP_STATE_CHAT_MUTATION_SPECS = Object.freeze({
|
|
36
|
+
STAR: { collection: WA_APP_STATE_COLLECTIONS.REGULAR_HIGH, action: 'star', version: 2 },
|
|
37
|
+
MUTE: { collection: WA_APP_STATE_COLLECTIONS.REGULAR_HIGH, action: 'mute', version: 2 },
|
|
38
|
+
PIN: { collection: WA_APP_STATE_COLLECTIONS.REGULAR_LOW, action: 'pin_v1', version: 5 },
|
|
39
|
+
ARCHIVE: { collection: WA_APP_STATE_COLLECTIONS.REGULAR_LOW, action: 'archive', version: 3 },
|
|
40
|
+
DELETE_MESSAGE_FOR_ME: {
|
|
41
|
+
collection: WA_APP_STATE_COLLECTIONS.REGULAR_HIGH,
|
|
42
|
+
action: 'deleteMessageForMe',
|
|
43
|
+
version: 3
|
|
44
|
+
},
|
|
45
|
+
MARK_CHAT_AS_READ: {
|
|
46
|
+
collection: WA_APP_STATE_COLLECTIONS.REGULAR_LOW,
|
|
47
|
+
action: 'markChatAsRead',
|
|
48
|
+
version: 3
|
|
49
|
+
},
|
|
50
|
+
CLEAR_CHAT: {
|
|
51
|
+
collection: WA_APP_STATE_COLLECTIONS.REGULAR_HIGH,
|
|
52
|
+
action: 'clearChat',
|
|
53
|
+
version: 6
|
|
54
|
+
},
|
|
55
|
+
DELETE_CHAT: {
|
|
56
|
+
collection: WA_APP_STATE_COLLECTIONS.REGULAR_HIGH,
|
|
57
|
+
action: 'deleteChat',
|
|
58
|
+
version: 6
|
|
59
|
+
},
|
|
60
|
+
LOCK_CHAT: { collection: WA_APP_STATE_COLLECTIONS.REGULAR_LOW, action: 'lock', version: 7 }
|
|
61
|
+
});
|
|
@@ -19,23 +19,15 @@ export const WA_COMPANION_PLATFORM_IDS = Object.freeze({
|
|
|
19
19
|
UWP: '8',
|
|
20
20
|
OTHER_WEB_CLIENT: '9'
|
|
21
21
|
});
|
|
22
|
+
const BROWSER_TO_PLATFORM_ID = {
|
|
23
|
+
[WA_BROWSERS.CHROME]: WA_COMPANION_PLATFORM_IDS.CHROME,
|
|
24
|
+
[WA_BROWSERS.FIREFOX]: WA_COMPANION_PLATFORM_IDS.FIREFOX,
|
|
25
|
+
[WA_BROWSERS.IE]: WA_COMPANION_PLATFORM_IDS.IE,
|
|
26
|
+
[WA_BROWSERS.OPERA]: WA_COMPANION_PLATFORM_IDS.OPERA,
|
|
27
|
+
[WA_BROWSERS.SAFARI]: WA_COMPANION_PLATFORM_IDS.SAFARI,
|
|
28
|
+
[WA_BROWSERS.EDGE]: WA_COMPANION_PLATFORM_IDS.EDGE
|
|
29
|
+
};
|
|
22
30
|
export function getWaCompanionPlatformId(browser) {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
case WA_BROWSERS.CHROME:
|
|
26
|
-
return WA_COMPANION_PLATFORM_IDS.CHROME;
|
|
27
|
-
case WA_BROWSERS.FIREFOX:
|
|
28
|
-
return WA_COMPANION_PLATFORM_IDS.FIREFOX;
|
|
29
|
-
case WA_BROWSERS.IE:
|
|
30
|
-
return WA_COMPANION_PLATFORM_IDS.IE;
|
|
31
|
-
case WA_BROWSERS.OPERA:
|
|
32
|
-
return WA_COMPANION_PLATFORM_IDS.OPERA;
|
|
33
|
-
case WA_BROWSERS.SAFARI:
|
|
34
|
-
return WA_COMPANION_PLATFORM_IDS.SAFARI;
|
|
35
|
-
case WA_BROWSERS.EDGE:
|
|
36
|
-
return WA_COMPANION_PLATFORM_IDS.EDGE;
|
|
37
|
-
case WA_BROWSERS.CHROMIUM:
|
|
38
|
-
default:
|
|
39
|
-
return WA_COMPANION_PLATFORM_IDS.OTHER_WEB_CLIENT;
|
|
40
|
-
}
|
|
31
|
+
return (BROWSER_TO_PLATFORM_ID[browser.trim().toLowerCase()] ??
|
|
32
|
+
WA_COMPANION_PLATFORM_IDS.OTHER_WEB_CLIENT);
|
|
41
33
|
}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
export { getWaCompanionPlatformId, WA_BROWSERS, WA_COMPANION_PLATFORM_IDS } from './browser.js';
|
|
2
2
|
export { WA_SIGNALING, WA_PAIRING_KDF_INFO } from './auth.js';
|
|
3
|
-
export { WA_DISCONNECT_REASONS, WA_LOGOUT_REASONS, WA_READY_STATES, WA_STREAM_SIGNALING } from './stream.js';
|
|
3
|
+
export { WA_CONNECTION_REASONS, WA_DISCONNECT_REASONS, WA_FAILURE_REASONS, WA_LOGOUT_REASONS, WA_READY_STATES, WA_STREAM_SIGNALING } from './stream.js';
|
|
4
4
|
export { WA_IQ_TYPES, WA_NODE_TAGS, WA_XMLNS } from './nodes.js';
|
|
5
|
-
export { WA_MESSAGE_TAGS, WA_MESSAGE_TYPES, WA_RETRYABLE_ACK_CODES } from './message.js';
|
|
6
|
-
export { WA_APP_STATE_COLLECTIONS, WA_APP_STATE_COLLECTION_STATES, WA_APP_STATE_ERROR_CODES, WA_APP_STATE_KDF_INFO, WA_APP_STATE_KEY_TYPES, WA_APP_STATE_SYNC_DATA_TYPE } from './appstate.js';
|
|
5
|
+
export { WA_EDIT_ATTRS, WA_ENC_MEDIA_TYPES, WA_EVENT_META_TYPES, WA_MESSAGE_TAGS, WA_MESSAGE_TYPES, WA_POLL_META_TYPES, WA_RETRYABLE_ACK_CODES, WA_STANZA_MSG_TYPES } from './message.js';
|
|
6
|
+
export { WA_APP_STATE_COLLECTIONS, WA_APP_STATE_COLLECTION_STATES, WA_APP_STATE_CHAT_MUTATION_SPECS, WA_APP_STATE_ERROR_CODES, WA_APP_STATE_KDF_INFO, WA_APP_STATE_KEY_TYPES, WA_APP_STATE_SYNC_DATA_TYPE } from './appstate.js';
|
|
7
7
|
export { getWaMediaHkdfInfo, WA_MEDIA_HKDF_INFO, WA_PREVIEW_MEDIA_HKDF_INFO } from './media.js';
|
|
8
8
|
export { WA_ACCOUNT_SYNC_PROTOCOLS, WA_DIRTY_PROTOCOLS, WA_DIRTY_TYPES, WA_SUPPORTED_DIRTY_TYPES } from './dirty.js';
|
|
9
9
|
export { WA_GROUP_NOTIFICATION_TAGS, WA_NOTIFICATION_TYPES } from './notification.js';
|
|
10
|
+
export { WA_PRIVACY_TOKEN_NOTIFICATION_TYPE, WA_PRIVACY_TOKEN_TAGS, WA_PRIVACY_TOKEN_TYPES, WA_TC_TOKEN_DEFAULTS } from './privacy-token.js';
|
|
11
|
+
export { WA_PRIVACY_CATEGORIES, WA_PRIVACY_CATEGORY_TO_SETTING, WA_PRIVACY_DISALLOWED_LIST_CATEGORIES, WA_PRIVACY_SETTING_TO_CATEGORY, WA_PRIVACY_TAGS, WA_PRIVACY_VALUES } from './privacy.js';
|
|
10
12
|
export { WA_DEFAULTS } from './defaults.js';
|
|
11
13
|
export { WA_GROUP_PARTICIPANT_TYPES } from './group.js';
|
|
14
|
+
export { WA_USYNC_CONTEXTS, WA_USYNC_DEFAULTS, WA_USYNC_MODES } from './usync.js';
|
|
@@ -3,6 +3,12 @@ export const WA_DEFAULTS = Object.freeze({
|
|
|
3
3
|
HOST_DOMAIN: 's.whatsapp.net',
|
|
4
4
|
GROUP_SERVER: 'g.us',
|
|
5
5
|
BROADCAST_SERVER: 'broadcast',
|
|
6
|
+
LID_SERVER: 'lid',
|
|
7
|
+
HOSTED_SERVER: 'hosted',
|
|
8
|
+
HOSTED_LID_SERVER: 'hosted.lid',
|
|
9
|
+
HOSTED_DEVICE_ID: 99,
|
|
10
|
+
MSGR_SERVER: 'msgr',
|
|
11
|
+
INTEROP_SERVER: 'interop',
|
|
6
12
|
DEVICE_BROWSER: WA_BROWSERS.FIREFOX,
|
|
7
13
|
DEVICE_PLATFORM: getWaCompanionPlatformId(WA_BROWSERS.FIREFOX),
|
|
8
14
|
CHAT_SOCKET_URLS: ['wss://web.whatsapp.com/ws/chat', 'wss://web.whatsapp.com:5222/ws/chat'],
|
|
@@ -1,11 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
export {
|
|
3
|
-
export { WA_DISCONNECT_REASONS, WA_LOGOUT_REASONS, WA_READY_STATES, WA_STREAM_SIGNALING } from './stream.js';
|
|
4
|
-
export { WA_IQ_TYPES, WA_NODE_TAGS, WA_XMLNS } from './nodes.js';
|
|
5
|
-
export { WA_MESSAGE_TAGS, WA_MESSAGE_TYPES, WA_RETRYABLE_ACK_CODES } from './message.js';
|
|
6
|
-
export { WA_APP_STATE_COLLECTIONS, WA_APP_STATE_COLLECTION_STATES, WA_APP_STATE_ERROR_CODES, WA_APP_STATE_KDF_INFO, WA_APP_STATE_KEY_TYPES, WA_APP_STATE_SYNC_DATA_TYPE } from './appstate.js';
|
|
7
|
-
export { getWaMediaHkdfInfo, WA_MEDIA_HKDF_INFO, WA_PREVIEW_MEDIA_HKDF_INFO } from './media.js';
|
|
8
|
-
export { WA_ACCOUNT_SYNC_PROTOCOLS, WA_DIRTY_PROTOCOLS, WA_DIRTY_TYPES, WA_SUPPORTED_DIRTY_TYPES } from './dirty.js';
|
|
9
|
-
export { WA_GROUP_NOTIFICATION_TAGS, WA_NOTIFICATION_TYPES } from './notification.js';
|
|
10
|
-
export { WA_DEFAULTS } from './defaults.js';
|
|
11
|
-
export { getLoginIdentity, isGroupJid, normalizeDeviceJid, normalizeRecipientJid, parsePhoneJid, parseSignalAddressFromJid, splitJid, toUserJid } from './jid.js';
|
|
1
|
+
export * from './constants.js';
|
|
2
|
+
export { buildDeviceJid, canonicalizeSignalJid, canonicalizeSignalServer, getLoginIdentity, isHostedDeviceId, isHostedDeviceJid, isHostedServer, isGroupJid, normalizeDeviceJid, normalizeRecipientJid, parsePhoneJid, parseSignalAddressFromJid, splitJid, signalAddressKey, toUserJid } from './jid.js';
|