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
package/dist/util/bytes.js
CHANGED
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EMPTY_BYTES = exports.TEXT_DECODER = exports.TEXT_ENCODER = void 0;
|
|
3
|
+
exports.EMPTY_BYTES = exports.ZERO_BYTES = exports.TEXT_DECODER = exports.TEXT_ENCODER = void 0;
|
|
4
4
|
exports.bytesToHex = bytesToHex;
|
|
5
5
|
exports.hexToBytes = hexToBytes;
|
|
6
6
|
exports.bytesToBase64 = bytesToBase64;
|
|
7
7
|
exports.base64ToBytes = base64ToBytes;
|
|
8
|
+
exports.base64ToBytesChecked = base64ToBytesChecked;
|
|
9
|
+
exports.decodeBase64Url = decodeBase64Url;
|
|
10
|
+
exports.assertByteLength = assertByteLength;
|
|
11
|
+
exports.decodeProtoBytes = decodeProtoBytes;
|
|
8
12
|
exports.bytesToBase64UrlSafe = bytesToBase64UrlSafe;
|
|
9
13
|
exports.concatBytes = concatBytes;
|
|
10
14
|
exports.toBytesView = toBytesView;
|
|
@@ -17,6 +21,7 @@ exports.readAllBytes = readAllBytes;
|
|
|
17
21
|
const node_crypto_1 = require("node:crypto");
|
|
18
22
|
exports.TEXT_ENCODER = new TextEncoder();
|
|
19
23
|
exports.TEXT_DECODER = new TextDecoder();
|
|
24
|
+
exports.ZERO_BYTES = new Uint8Array([0]);
|
|
20
25
|
exports.EMPTY_BYTES = Object.freeze(new Uint8Array(0));
|
|
21
26
|
const HEX_CHARS = '0123456789abcdef';
|
|
22
27
|
const HEX_TABLE = /* @__PURE__ */ (() => {
|
|
@@ -106,28 +111,48 @@ function base64ToBytes(value) {
|
|
|
106
111
|
out[j++] = ((b & 0x0f) << 4) | (c >> 2);
|
|
107
112
|
out[j++] = ((c & 0x03) << 6) | d;
|
|
108
113
|
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
114
|
+
const a = lookupBase64(value.charCodeAt(i));
|
|
115
|
+
const b = lookupBase64(value.charCodeAt(i + 1));
|
|
116
|
+
out[j++] = (a << 2) | (b >> 4);
|
|
117
|
+
if (j < outLen) {
|
|
112
118
|
const c = lookupBase64(value.charCodeAt(i + 2));
|
|
113
|
-
const d = lookupBase64(value.charCodeAt(i + 3));
|
|
114
|
-
out[j++] = (a << 2) | (b >> 4);
|
|
115
119
|
out[j++] = ((b & 0x0f) << 4) | (c >> 2);
|
|
116
|
-
|
|
120
|
+
if (j < outLen) {
|
|
121
|
+
const d = lookupBase64(value.charCodeAt(i + 3));
|
|
122
|
+
out[j++] = ((c & 0x03) << 6) | d;
|
|
123
|
+
}
|
|
117
124
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
out[j++] = ((b & 0x0f) << 4) | (c >> 2);
|
|
125
|
+
return out;
|
|
126
|
+
}
|
|
127
|
+
function base64ToBytesChecked(value, field, requireNonEmpty = true) {
|
|
128
|
+
if (requireNonEmpty && value.length === 0) {
|
|
129
|
+
throw new Error(`invalid base64 payload for ${field}`);
|
|
124
130
|
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
131
|
+
return base64ToBytes(value);
|
|
132
|
+
}
|
|
133
|
+
function decodeBase64Url(value, field) {
|
|
134
|
+
if (!value) {
|
|
135
|
+
throw new Error(`missing ${field}`);
|
|
136
|
+
}
|
|
137
|
+
const padded = value
|
|
138
|
+
.replace(/-/g, '+')
|
|
139
|
+
.replace(/_/g, '/')
|
|
140
|
+
.padEnd(Math.ceil(value.length / 4) * 4, '=');
|
|
141
|
+
return base64ToBytesChecked(padded, field);
|
|
142
|
+
}
|
|
143
|
+
function assertByteLength(value, expectedLength, errorMessage) {
|
|
144
|
+
if (value.length !== expectedLength) {
|
|
145
|
+
throw new Error(errorMessage);
|
|
129
146
|
}
|
|
130
|
-
|
|
147
|
+
}
|
|
148
|
+
function decodeProtoBytes(value, field) {
|
|
149
|
+
if (value === null || value === undefined) {
|
|
150
|
+
throw new Error(`missing protobuf bytes field ${field}`);
|
|
151
|
+
}
|
|
152
|
+
if (value instanceof Uint8Array) {
|
|
153
|
+
return value;
|
|
154
|
+
}
|
|
155
|
+
return base64ToBytes(value);
|
|
131
156
|
}
|
|
132
157
|
function lookupBase64(code) {
|
|
133
158
|
if (code > 127) {
|
|
@@ -185,39 +210,35 @@ function encodeBase64(value, alphabet, pad) {
|
|
|
185
210
|
return out.join('');
|
|
186
211
|
}
|
|
187
212
|
function concatBytes(parts) {
|
|
188
|
-
|
|
213
|
+
let total = 0;
|
|
214
|
+
for (let i = 0; i < parts.length; i += 1) {
|
|
215
|
+
total += parts[i].length;
|
|
216
|
+
}
|
|
189
217
|
const out = new Uint8Array(total);
|
|
190
218
|
let offset = 0;
|
|
191
|
-
for (
|
|
192
|
-
out.set(
|
|
193
|
-
offset +=
|
|
219
|
+
for (let i = 0; i < parts.length; i += 1) {
|
|
220
|
+
out.set(parts[i], offset);
|
|
221
|
+
offset += parts[i].length;
|
|
194
222
|
}
|
|
195
223
|
return out;
|
|
196
224
|
}
|
|
197
225
|
function toBytesView(value) {
|
|
198
226
|
if (value instanceof Uint8Array) {
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
return new Uint8Array(value.buffer, value.byteOffset, value.byteLength);
|
|
227
|
+
return value.constructor === Uint8Array
|
|
228
|
+
? value
|
|
229
|
+
: new Uint8Array(value.buffer, value.byteOffset, value.byteLength);
|
|
203
230
|
}
|
|
204
|
-
if (ArrayBuffer
|
|
205
|
-
return new Uint8Array(value
|
|
231
|
+
if (value instanceof ArrayBuffer) {
|
|
232
|
+
return new Uint8Array(value);
|
|
206
233
|
}
|
|
207
|
-
return new Uint8Array(value);
|
|
234
|
+
return new Uint8Array(value.buffer, value.byteOffset, value.byteLength);
|
|
208
235
|
}
|
|
209
236
|
function toChunkBytes(chunk) {
|
|
210
|
-
if (chunk instanceof Uint8Array) {
|
|
211
|
-
return chunk;
|
|
212
|
-
}
|
|
213
|
-
if (chunk instanceof ArrayBuffer) {
|
|
214
|
-
return new Uint8Array(chunk);
|
|
215
|
-
}
|
|
216
237
|
if (typeof chunk === 'string') {
|
|
217
238
|
return exports.TEXT_ENCODER.encode(chunk);
|
|
218
239
|
}
|
|
219
|
-
if (ArrayBuffer.isView(chunk)) {
|
|
220
|
-
return
|
|
240
|
+
if (chunk instanceof Uint8Array || chunk instanceof ArrayBuffer || ArrayBuffer.isView(chunk)) {
|
|
241
|
+
return toBytesView(chunk);
|
|
221
242
|
}
|
|
222
243
|
throw new Error(`unsupported stream chunk type: ${typeof chunk}`);
|
|
223
244
|
}
|
|
@@ -238,10 +259,21 @@ function uint8Equal(a, b) {
|
|
|
238
259
|
return diff === 0;
|
|
239
260
|
}
|
|
240
261
|
function removeAt(items, index) {
|
|
241
|
-
|
|
262
|
+
if (items.length === 0) {
|
|
263
|
+
return [];
|
|
264
|
+
}
|
|
265
|
+
if (index < 0 || index >= items.length) {
|
|
266
|
+
const out = new Array(items.length);
|
|
267
|
+
for (let i = 0; i < items.length; i += 1) {
|
|
268
|
+
out[i] = items[i];
|
|
269
|
+
}
|
|
270
|
+
return out;
|
|
271
|
+
}
|
|
272
|
+
const out = new Array(items.length - 1);
|
|
273
|
+
let k = 0;
|
|
242
274
|
for (let i = 0; i < items.length; i += 1) {
|
|
243
275
|
if (i !== index) {
|
|
244
|
-
out
|
|
276
|
+
out[k++] = items[i];
|
|
245
277
|
}
|
|
246
278
|
}
|
|
247
279
|
return out;
|
|
@@ -281,11 +313,5 @@ async function readAllBytes(stream, options = {}) {
|
|
|
281
313
|
if (chunks.length === 1) {
|
|
282
314
|
return chunks[0];
|
|
283
315
|
}
|
|
284
|
-
|
|
285
|
-
let offset = 0;
|
|
286
|
-
for (const chunk of chunks) {
|
|
287
|
-
merged.set(chunk, offset);
|
|
288
|
-
offset += chunk.byteLength;
|
|
289
|
-
}
|
|
290
|
-
return merged;
|
|
316
|
+
return concatBytes(chunks);
|
|
291
317
|
}
|
package/dist/util/coercion.js
CHANGED
|
@@ -20,9 +20,8 @@ function asNumber(value, field) {
|
|
|
20
20
|
throw new Error(`invalid number value for ${field}`);
|
|
21
21
|
}
|
|
22
22
|
function asOptionalNumber(value, field = 'optional number') {
|
|
23
|
-
if (value === null || value === undefined)
|
|
23
|
+
if (value === null || value === undefined)
|
|
24
24
|
return undefined;
|
|
25
|
-
}
|
|
26
25
|
return asNumber(value, field);
|
|
27
26
|
}
|
|
28
27
|
function asString(value, field) {
|
|
@@ -32,9 +31,8 @@ function asString(value, field) {
|
|
|
32
31
|
throw new Error(`invalid string value for ${field}`);
|
|
33
32
|
}
|
|
34
33
|
function asOptionalString(value, field = 'optional string') {
|
|
35
|
-
if (value === null || value === undefined)
|
|
34
|
+
if (value === null || value === undefined)
|
|
36
35
|
return undefined;
|
|
37
|
-
}
|
|
38
36
|
return asString(value, field);
|
|
39
37
|
}
|
|
40
38
|
function asBytes(value, field) {
|
|
@@ -44,23 +42,17 @@ function asBytes(value, field) {
|
|
|
44
42
|
throw new Error(`invalid bytes value for ${field}`);
|
|
45
43
|
}
|
|
46
44
|
function asOptionalBytes(value, field = 'optional bytes') {
|
|
47
|
-
if (value === null || value === undefined)
|
|
45
|
+
if (value === null || value === undefined)
|
|
48
46
|
return undefined;
|
|
49
|
-
}
|
|
50
47
|
return asBytes(value, field);
|
|
51
48
|
}
|
|
52
49
|
function toBoolOrUndef(value) {
|
|
53
|
-
|
|
54
|
-
return undefined;
|
|
55
|
-
}
|
|
56
|
-
return Boolean(value);
|
|
50
|
+
return value === null || value === undefined ? undefined : Boolean(value);
|
|
57
51
|
}
|
|
58
52
|
function resolvePositive(value, fallback, name) {
|
|
59
|
-
if (value === undefined)
|
|
53
|
+
if (value === undefined)
|
|
60
54
|
return fallback;
|
|
61
|
-
|
|
62
|
-
if (Number.isSafeInteger(value) && value > 0) {
|
|
55
|
+
if (Number.isSafeInteger(value) && value > 0)
|
|
63
56
|
return value;
|
|
64
|
-
}
|
|
65
57
|
throw new Error(`${name} must be a positive safe integer`);
|
|
66
58
|
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isBunRuntime = exports.toSafeNumber = exports.normalizeQueryLimit = exports.toBoolOrUndef = exports.resolvePositive = exports.asString = exports.asOptionalString = exports.asOptionalNumber = exports.asOptionalBytes = exports.asNumber = exports.asBytes = exports.uint8Equal = exports.toBytesView = exports.hexToBytes = exports.bytesToHex = void 0;
|
|
4
|
+
var bytes_1 = require("./bytes");
|
|
5
|
+
Object.defineProperty(exports, "bytesToHex", { enumerable: true, get: function () { return bytes_1.bytesToHex; } });
|
|
6
|
+
Object.defineProperty(exports, "hexToBytes", { enumerable: true, get: function () { return bytes_1.hexToBytes; } });
|
|
7
|
+
Object.defineProperty(exports, "toBytesView", { enumerable: true, get: function () { return bytes_1.toBytesView; } });
|
|
8
|
+
Object.defineProperty(exports, "uint8Equal", { enumerable: true, get: function () { return bytes_1.uint8Equal; } });
|
|
9
|
+
var coercion_1 = require("./coercion");
|
|
10
|
+
Object.defineProperty(exports, "asBytes", { enumerable: true, get: function () { return coercion_1.asBytes; } });
|
|
11
|
+
Object.defineProperty(exports, "asNumber", { enumerable: true, get: function () { return coercion_1.asNumber; } });
|
|
12
|
+
Object.defineProperty(exports, "asOptionalBytes", { enumerable: true, get: function () { return coercion_1.asOptionalBytes; } });
|
|
13
|
+
Object.defineProperty(exports, "asOptionalNumber", { enumerable: true, get: function () { return coercion_1.asOptionalNumber; } });
|
|
14
|
+
Object.defineProperty(exports, "asOptionalString", { enumerable: true, get: function () { return coercion_1.asOptionalString; } });
|
|
15
|
+
Object.defineProperty(exports, "asString", { enumerable: true, get: function () { return coercion_1.asString; } });
|
|
16
|
+
Object.defineProperty(exports, "resolvePositive", { enumerable: true, get: function () { return coercion_1.resolvePositive; } });
|
|
17
|
+
Object.defineProperty(exports, "toBoolOrUndef", { enumerable: true, get: function () { return coercion_1.toBoolOrUndef; } });
|
|
18
|
+
var collections_1 = require("./collections");
|
|
19
|
+
Object.defineProperty(exports, "normalizeQueryLimit", { enumerable: true, get: function () { return collections_1.normalizeQueryLimit; } });
|
|
20
|
+
var primitives_1 = require("./primitives");
|
|
21
|
+
Object.defineProperty(exports, "toSafeNumber", { enumerable: true, get: function () { return primitives_1.toSafeNumber; } });
|
|
22
|
+
var runtime_1 = require("./runtime");
|
|
23
|
+
Object.defineProperty(exports, "isBunRuntime", { enumerable: true, get: function () { return runtime_1.isBunRuntime; } });
|
package/dist/util/primitives.js
CHANGED
|
@@ -3,35 +3,63 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.toError = toError;
|
|
4
4
|
exports.toSafeNumber = toSafeNumber;
|
|
5
5
|
exports.longToNumber = longToNumber;
|
|
6
|
+
exports.normalizeNonNegativeInteger = normalizeNonNegativeInteger;
|
|
7
|
+
exports.parseOptionalInt = parseOptionalInt;
|
|
8
|
+
const DIGITS_ONLY_RE = /^\d+$/;
|
|
6
9
|
function toError(value) {
|
|
7
|
-
if (value instanceof Error)
|
|
10
|
+
if (value instanceof Error)
|
|
8
11
|
return value;
|
|
9
|
-
|
|
10
|
-
if (typeof value === 'string') {
|
|
12
|
+
if (typeof value === 'string')
|
|
11
13
|
return new Error(value);
|
|
14
|
+
if (typeof value === 'number' || typeof value === 'boolean' || typeof value === 'bigint') {
|
|
15
|
+
return new Error(String(value));
|
|
16
|
+
}
|
|
17
|
+
if (value && typeof value === 'object') {
|
|
18
|
+
const message = value.message;
|
|
19
|
+
if (typeof message === 'string' && message.length > 0) {
|
|
20
|
+
return new Error(message);
|
|
21
|
+
}
|
|
22
|
+
const code = value.code;
|
|
23
|
+
if (typeof code === 'string' || typeof code === 'number') {
|
|
24
|
+
return new Error(`unknown error (${code})`);
|
|
25
|
+
}
|
|
12
26
|
}
|
|
13
27
|
return new Error('unknown error');
|
|
14
28
|
}
|
|
15
29
|
function assertSafeInteger(value, field, nullishBehavior) {
|
|
16
|
-
if (
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
20
|
-
return value;
|
|
30
|
+
if (Number.isFinite(value) && Number.isSafeInteger(value))
|
|
31
|
+
return value;
|
|
32
|
+
const prefix = nullishBehavior === 'throw' ? `invalid ${field}` : 'invalid long numeric value';
|
|
33
|
+
throw new Error(`${prefix}: ${value}`);
|
|
21
34
|
}
|
|
22
35
|
function toSafeNumber(value, field) {
|
|
23
|
-
if (value === null || value === undefined)
|
|
36
|
+
if (value === null || value === undefined)
|
|
24
37
|
throw new Error(`missing ${field}`);
|
|
25
|
-
}
|
|
26
38
|
const numeric = typeof value === 'number' ? value : value.toNumber?.();
|
|
27
|
-
if (typeof numeric !== 'number')
|
|
39
|
+
if (typeof numeric !== 'number')
|
|
28
40
|
throw new Error(`invalid ${field}`);
|
|
29
|
-
}
|
|
30
41
|
return assertSafeInteger(numeric, field, 'throw');
|
|
31
42
|
}
|
|
32
43
|
function longToNumber(value) {
|
|
33
|
-
if (value === null || value === undefined)
|
|
44
|
+
if (value === null || value === undefined)
|
|
34
45
|
return 0;
|
|
35
|
-
}
|
|
36
46
|
return assertSafeInteger(typeof value === 'number' ? value : value.toNumber(), '', 'zero');
|
|
37
47
|
}
|
|
48
|
+
function normalizeNonNegativeInteger(value, fallback) {
|
|
49
|
+
if (typeof value !== 'number' || !Number.isFinite(value))
|
|
50
|
+
return fallback;
|
|
51
|
+
return Math.max(0, Math.trunc(value));
|
|
52
|
+
}
|
|
53
|
+
function parseStrictUnsignedInt(value) {
|
|
54
|
+
if (!DIGITS_ONLY_RE.test(value))
|
|
55
|
+
return undefined;
|
|
56
|
+
const parsed = Number(value);
|
|
57
|
+
if (!Number.isSafeInteger(parsed))
|
|
58
|
+
return undefined;
|
|
59
|
+
return parsed;
|
|
60
|
+
}
|
|
61
|
+
function parseOptionalInt(value) {
|
|
62
|
+
if (!value)
|
|
63
|
+
return undefined;
|
|
64
|
+
return parseStrictUnsignedInt(value);
|
|
65
|
+
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zapo-js",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "High-performance WhatsApp Web TypeScript library",
|
|
5
|
+
"funding": {
|
|
6
|
+
"type": "github",
|
|
7
|
+
"url": "https://github.com/sponsors/vinikjkkj"
|
|
8
|
+
},
|
|
9
|
+
"packageManager": "npm@10.0.0",
|
|
5
10
|
"main": "dist/index.js",
|
|
6
11
|
"module": "dist/esm/index.js",
|
|
7
12
|
"types": "dist/types/index.d.ts",
|
|
@@ -66,6 +71,24 @@
|
|
|
66
71
|
"import": "./dist/esm/transport/index.js",
|
|
67
72
|
"default": "./dist/transport/index.js"
|
|
68
73
|
},
|
|
74
|
+
"./protocol": {
|
|
75
|
+
"types": "./dist/types/protocol/index.d.ts",
|
|
76
|
+
"require": "./dist/protocol/index.js",
|
|
77
|
+
"import": "./dist/esm/protocol/index.js",
|
|
78
|
+
"default": "./dist/protocol/index.js"
|
|
79
|
+
},
|
|
80
|
+
"./retry": {
|
|
81
|
+
"types": "./dist/types/retry/index.d.ts",
|
|
82
|
+
"require": "./dist/retry/index.js",
|
|
83
|
+
"import": "./dist/esm/retry/index.js",
|
|
84
|
+
"default": "./dist/retry/index.js"
|
|
85
|
+
},
|
|
86
|
+
"./util": {
|
|
87
|
+
"types": "./dist/types/util/index.d.ts",
|
|
88
|
+
"require": "./dist/util/index.js",
|
|
89
|
+
"import": "./dist/esm/util/index.js",
|
|
90
|
+
"default": "./dist/util/index.js"
|
|
91
|
+
},
|
|
69
92
|
"./proto": {
|
|
70
93
|
"types": "./dist/types/proto.d.ts",
|
|
71
94
|
"require": "./dist/proto.js",
|
|
@@ -80,6 +103,9 @@
|
|
|
80
103
|
"proto/index.d.ts",
|
|
81
104
|
"scripts/check-node-version.cjs"
|
|
82
105
|
],
|
|
106
|
+
"workspaces": [
|
|
107
|
+
"packages/*"
|
|
108
|
+
],
|
|
83
109
|
"engines": {
|
|
84
110
|
"node": ">=20.9.0"
|
|
85
111
|
},
|
|
@@ -88,36 +114,46 @@
|
|
|
88
114
|
"changeset": "changeset",
|
|
89
115
|
"changeset:status": "changeset status --verbose",
|
|
90
116
|
"version:packages": "changeset version",
|
|
91
|
-
"release:publish": "npm run build && changeset publish",
|
|
117
|
+
"release:publish": "npm run build && npm run build:packages && changeset publish",
|
|
92
118
|
"clean": "node -e \"require('node:fs').rmSync('dist', { recursive: true, force: true })\"",
|
|
93
119
|
"build:cjs": "tsc -p tsconfig.build.cjs.json && tsc-alias -p tsconfig.build.cjs.json",
|
|
94
120
|
"build:esm": "tsc -p tsconfig.build.esm.json && tsc-alias -p tsconfig.build.esm.json",
|
|
95
121
|
"build:types": "tsc -p tsconfig.build.types.json && tsc-alias -p tsconfig.build.types.json",
|
|
96
122
|
"build:esm:finalize": "node ./scripts/finalize-esm-build.cjs",
|
|
97
123
|
"build": "npm run clean && npm run build:cjs && npm run build:esm && npm run build:types && npm run build:esm:finalize",
|
|
124
|
+
"build:packages": "turbo run build",
|
|
98
125
|
"proto:generate": "node ./scripts/generate-proto.cjs",
|
|
99
126
|
"example": "tsx examples/example.ts",
|
|
127
|
+
"bench:media": "node --expose-gc --import tsx bench/media-streaming.bench.ts",
|
|
128
|
+
"bench:binary": "node --expose-gc --import tsx bench/binary-codec.bench.ts",
|
|
129
|
+
"bench:crypto": "node --expose-gc --import tsx bench/crypto-core.bench.ts",
|
|
130
|
+
"bench:store:memory": "node --expose-gc --import tsx bench/store-memory.bench.ts",
|
|
131
|
+
"bench:all": "npm run bench:media && npm run bench:binary && npm run bench:crypto && npm run bench:store:memory",
|
|
132
|
+
"bench:comment": "node ./scripts/build-bench-comment.cjs",
|
|
100
133
|
"test:structure": "node ./scripts/check-tests-structure.cjs",
|
|
101
134
|
"test": "npm run test:structure && node --import tsx --test --test-skip-pattern \"\\\\[flow\\\\]\" \"src/**/__tests__/**/*.test.ts\"",
|
|
135
|
+
"test:packages": "turbo run test",
|
|
136
|
+
"test:stores": "node ./scripts/test-stores.cjs",
|
|
102
137
|
"test:watch": "node --import tsx --test --watch --test-skip-pattern \"\\\\[flow\\\\]\" \"src/**/__tests__/**/*.test.ts\"",
|
|
103
138
|
"test:flow": "node --import tsx --test --test-concurrency=1 \"src/**/__tests__/**/*.flow.test.ts\"",
|
|
104
139
|
"test:flow:watch": "node --import tsx --test --watch --test-concurrency=1 \"src/**/__tests__/**/*.flow.test.ts\"",
|
|
105
140
|
"test:coverage": "npm run test:structure && c8 --all --include \"src/**/*.ts\" --exclude \"src/**/*.d.ts\" --exclude \"src/**/__tests__/**\" --exclude \"src/**/types.ts\" --exclude \"src/store/contracts/**/*.ts\" --reporter text --reporter html --reporter lcov node --import tsx --test --test-skip-pattern \"\\\\[flow\\\\]\" \"src/**/__tests__/**/*.test.ts\"",
|
|
106
141
|
"test:coverage:open": "node -e \"require('node:child_process').execSync(process.platform === 'win32' ? 'start coverage\\\\index.html' : process.platform === 'darwin' ? 'open coverage/index.html' : 'xdg-open coverage/index.html', { stdio: 'inherit' })\"",
|
|
107
142
|
"typecheck": "tsc -p tsconfig.json --noEmit",
|
|
108
|
-
"
|
|
109
|
-
"lint
|
|
143
|
+
"typecheck:packages": "turbo run typecheck",
|
|
144
|
+
"lint": "eslint . --ext .ts,.js,.cjs",
|
|
145
|
+
"lint:fix": "eslint . --ext .ts,.js,.cjs --fix",
|
|
110
146
|
"format": "prettier . --write",
|
|
111
147
|
"format:check": "prettier . --check"
|
|
112
148
|
},
|
|
113
|
-
"dependencies": {},
|
|
114
149
|
"peerDependencies": {
|
|
115
|
-
"
|
|
150
|
+
"got": "14.6.4",
|
|
116
151
|
"pino": "^9.0.0",
|
|
117
|
-
"pino-pretty": "^13.0.0"
|
|
152
|
+
"pino-pretty": "^13.0.0",
|
|
153
|
+
"ws": "^8.18.3"
|
|
118
154
|
},
|
|
119
155
|
"peerDependenciesMeta": {
|
|
120
|
-
"
|
|
156
|
+
"got": {
|
|
121
157
|
"optional": true
|
|
122
158
|
},
|
|
123
159
|
"pino": {
|
|
@@ -125,23 +161,30 @@
|
|
|
125
161
|
},
|
|
126
162
|
"pino-pretty": {
|
|
127
163
|
"optional": true
|
|
164
|
+
},
|
|
165
|
+
"ws": {
|
|
166
|
+
"optional": true
|
|
128
167
|
}
|
|
129
168
|
},
|
|
130
169
|
"devDependencies": {
|
|
131
170
|
"@changesets/cli": "^2.30.0",
|
|
132
171
|
"@types/node": "^22.13.14",
|
|
172
|
+
"@types/ws": "^8.18.1",
|
|
133
173
|
"@typescript-eslint/parser": "^8.56.1",
|
|
134
174
|
"@vinikjkkj/eslint-config": "^1.0.0",
|
|
135
175
|
"better-sqlite3": "^12.6.2",
|
|
136
176
|
"c8": "^11.0.0",
|
|
137
177
|
"eslint": "^9.39.4",
|
|
138
178
|
"eslint-plugin-import": "^2.32.0",
|
|
179
|
+
"got": "14.6.4",
|
|
139
180
|
"pino": "^10.3.1",
|
|
140
181
|
"pino-pretty": "^13.1.3",
|
|
141
182
|
"prettier": "^3.8.1",
|
|
142
183
|
"tsc-alias": "^1.8.16",
|
|
143
184
|
"tsx": "^4.20.6",
|
|
185
|
+
"turbo": "^2.8.20",
|
|
144
186
|
"typescript": "^5.7.3",
|
|
145
|
-
"typescript-eslint": "^8.56.1"
|
|
187
|
+
"typescript-eslint": "^8.56.1",
|
|
188
|
+
"ws": "^8.18.3"
|
|
146
189
|
}
|
|
147
190
|
}
|