@arkade-os/sdk 0.4.26 → 0.4.28
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 +36 -125
- package/dist/adapters/asyncStorage.cjs +48 -0
- package/dist/adapters/asyncStorage.cjs.map +1 -0
- package/dist/adapters/asyncStorage.d.cts +16 -0
- package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
- package/dist/adapters/asyncStorage.js +46 -0
- package/dist/adapters/asyncStorage.js.map +1 -0
- package/dist/adapters/expo.cjs +19 -0
- package/dist/adapters/expo.cjs.map +1 -0
- package/dist/adapters/expo.d.cts +48 -0
- package/dist/adapters/expo.d.ts +48 -0
- package/dist/adapters/expo.js +6 -0
- package/dist/adapters/expo.js.map +1 -0
- package/dist/adapters/fileSystem.cjs +116 -0
- package/dist/adapters/fileSystem.cjs.map +1 -0
- package/dist/adapters/fileSystem.d.cts +17 -0
- package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
- package/dist/adapters/fileSystem.js +93 -0
- package/dist/adapters/fileSystem.js.map +1 -0
- package/dist/adapters/indexedDB.cjs +103 -0
- package/dist/adapters/indexedDB.cjs.map +1 -0
- package/dist/adapters/indexedDB.d.cts +18 -0
- package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
- package/dist/adapters/indexedDB.js +101 -0
- package/dist/adapters/indexedDB.js.map +1 -0
- package/dist/adapters/localStorage.cjs +50 -0
- package/dist/adapters/localStorage.cjs.map +1 -0
- package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
- package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
- package/dist/adapters/localStorage.js +48 -0
- package/dist/adapters/localStorage.js.map +1 -0
- package/dist/ark-TZ1gXAXU.d.cts +3880 -0
- package/dist/ark-TZ1gXAXU.d.ts +3880 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
- package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-5PG7DV7A.cjs +805 -0
- package/dist/chunk-5PG7DV7A.cjs.map +1 -0
- package/dist/chunk-A3EMF7RN.js +95 -0
- package/dist/chunk-A3EMF7RN.js.map +1 -0
- package/dist/chunk-ADV27S4N.cjs +2701 -0
- package/dist/chunk-ADV27S4N.cjs.map +1 -0
- package/dist/chunk-BQLHADL7.js +13805 -0
- package/dist/chunk-BQLHADL7.js.map +1 -0
- package/dist/chunk-CFZMTDWI.js +209 -0
- package/dist/chunk-CFZMTDWI.js.map +1 -0
- package/dist/chunk-FG5ACJJW.cjs +212 -0
- package/dist/chunk-FG5ACJJW.cjs.map +1 -0
- package/dist/chunk-HW3JJ323.js +768 -0
- package/dist/chunk-HW3JJ323.js.map +1 -0
- package/dist/chunk-I3DGUUCT.cjs +838 -0
- package/dist/chunk-I3DGUUCT.cjs.map +1 -0
- package/dist/chunk-IPX2R7FR.cjs +100 -0
- package/dist/chunk-IPX2R7FR.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-T64LAI7L.js +829 -0
- package/dist/chunk-T64LAI7L.js.map +1 -0
- package/dist/chunk-ZBUDLTBO.js +2671 -0
- package/dist/chunk-ZBUDLTBO.js.map +1 -0
- package/dist/chunk-ZLO6NETT.cjs +13910 -0
- package/dist/chunk-ZLO6NETT.cjs.map +1 -0
- package/dist/contracts/handlers/index.cjs +26 -0
- package/dist/contracts/handlers/index.cjs.map +1 -0
- package/dist/contracts/handlers/index.d.cts +7 -0
- package/dist/contracts/handlers/index.d.ts +7 -0
- package/dist/contracts/handlers/index.js +5 -0
- package/dist/contracts/handlers/index.js.map +1 -0
- package/dist/delegate-BFZs69hp.d.cts +84 -0
- package/dist/delegate-aaVGfWsV.d.ts +84 -0
- package/dist/index-B22cA64m.d.cts +199 -0
- package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
- package/dist/index-C0IanN1m.d.ts +11 -0
- package/dist/index-NDla_UoJ.d.ts +199 -0
- package/dist/index.cjs +480 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3343 -0
- package/dist/index.d.ts +3343 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/repositories/realm/index.cjs +513 -0
- package/dist/repositories/realm/index.cjs.map +1 -0
- package/dist/repositories/realm/index.d.cts +217 -0
- package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
- package/dist/repositories/realm/index.js +507 -0
- package/dist/repositories/realm/index.js.map +1 -0
- package/dist/repositories/sqlite/index.cjs +588 -0
- package/dist/repositories/sqlite/index.cjs.map +1 -0
- package/dist/repositories/sqlite/index.d.cts +118 -0
- package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
- package/dist/repositories/sqlite/index.js +585 -0
- package/dist/repositories/sqlite/index.js.map +1 -0
- package/dist/taskRunner-C6Ff4OaU.d.cts +114 -0
- package/dist/taskRunner-yvPN8Z0K.d.ts +114 -0
- package/dist/wallet/expo/background.cjs +93 -0
- package/dist/wallet/expo/background.cjs.map +1 -0
- package/dist/wallet/expo/background.d.cts +84 -0
- package/dist/wallet/expo/background.d.ts +84 -0
- package/dist/wallet/expo/background.js +68 -0
- package/dist/wallet/expo/background.js.map +1 -0
- package/dist/wallet/expo/index.cjs +171 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +122 -0
- package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
- package/dist/wallet/expo/index.js +169 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-AF-p-OWj.d.cts +774 -0
- package/dist/wallet-D9NBRqvC.d.ts +774 -0
- package/dist/worker/expo/index.cjs +140 -0
- package/dist/worker/expo/index.cjs.map +1 -0
- package/dist/worker/expo/index.d.cts +29 -0
- package/dist/worker/expo/index.d.ts +29 -0
- package/dist/worker/expo/index.js +121 -0
- package/dist/worker/expo/index.js.map +1 -0
- package/package.json +110 -76
- package/dist/cjs/adapters/asyncStorage.js +0 -5
- package/dist/cjs/adapters/expo.js +0 -8
- package/dist/cjs/adapters/fileSystem.js +0 -5
- package/dist/cjs/adapters/indexedDB.js +0 -5
- package/dist/cjs/adapters/localStorage.js +0 -5
- package/dist/cjs/arkfee/celenv.js +0 -43
- package/dist/cjs/arkfee/estimator.js +0 -143
- package/dist/cjs/arkfee/index.js +0 -5
- package/dist/cjs/arkfee/types.js +0 -26
- package/dist/cjs/arknote/index.js +0 -128
- package/dist/cjs/bip322/index.js +0 -270
- package/dist/cjs/contracts/arkcontract.js +0 -147
- package/dist/cjs/contracts/contractManager.js +0 -629
- package/dist/cjs/contracts/contractWatcher.js +0 -598
- package/dist/cjs/contracts/handlers/default.js +0 -93
- package/dist/cjs/contracts/handlers/delegate.js +0 -90
- package/dist/cjs/contracts/handlers/helpers.js +0 -115
- package/dist/cjs/contracts/handlers/index.js +0 -19
- package/dist/cjs/contracts/handlers/registry.js +0 -89
- package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
- package/dist/cjs/contracts/index.js +0 -41
- package/dist/cjs/contracts/types.js +0 -2
- package/dist/cjs/contracts/vtxoOwnership.js +0 -78
- package/dist/cjs/extension/asset/assetGroup.js +0 -228
- package/dist/cjs/extension/asset/assetId.js +0 -152
- package/dist/cjs/extension/asset/assetInput.js +0 -222
- package/dist/cjs/extension/asset/assetOutput.js +0 -174
- package/dist/cjs/extension/asset/assetRef.js +0 -148
- package/dist/cjs/extension/asset/index.js +0 -23
- package/dist/cjs/extension/asset/metadata.js +0 -187
- package/dist/cjs/extension/asset/packet.js +0 -114
- package/dist/cjs/extension/asset/types.js +0 -22
- package/dist/cjs/extension/asset/utils.js +0 -105
- package/dist/cjs/extension/index.js +0 -254
- package/dist/cjs/extension/packet.js +0 -20
- package/dist/cjs/forfeit.js +0 -45
- package/dist/cjs/identity/descriptor.js +0 -169
- package/dist/cjs/identity/descriptorProvider.js +0 -2
- package/dist/cjs/identity/hdCapableIdentity.js +0 -2
- package/dist/cjs/identity/index.js +0 -38
- package/dist/cjs/identity/seedIdentity.js +0 -461
- package/dist/cjs/identity/serialize.js +0 -171
- package/dist/cjs/identity/singleKey.js +0 -126
- package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
- package/dist/cjs/index.js +0 -200
- package/dist/cjs/intent/index.js +0 -259
- package/dist/cjs/musig2/index.js +0 -11
- package/dist/cjs/musig2/keys.js +0 -57
- package/dist/cjs/musig2/nonces.js +0 -48
- package/dist/cjs/musig2/sign.js +0 -102
- package/dist/cjs/networks.js +0 -26
- package/dist/cjs/package.json +0 -3
- package/dist/cjs/providers/ark.js +0 -577
- package/dist/cjs/providers/delegator.js +0 -85
- package/dist/cjs/providers/electrum.js +0 -869
- package/dist/cjs/providers/errors.js +0 -59
- package/dist/cjs/providers/expoArk.js +0 -82
- package/dist/cjs/providers/expoIndexer.js +0 -111
- package/dist/cjs/providers/expoUtils.js +0 -124
- package/dist/cjs/providers/indexer.js +0 -630
- package/dist/cjs/providers/onchain.js +0 -262
- package/dist/cjs/providers/utils.js +0 -121
- package/dist/cjs/repositories/contractRepository.js +0 -2
- package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
- package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
- package/dist/cjs/repositories/index.js +0 -34
- package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
- package/dist/cjs/repositories/indexedDB/db.js +0 -19
- package/dist/cjs/repositories/indexedDB/manager.js +0 -100
- package/dist/cjs/repositories/indexedDB/schema.js +0 -204
- package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
- package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
- package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
- package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
- package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
- package/dist/cjs/repositories/realm/contractRepository.js +0 -116
- package/dist/cjs/repositories/realm/index.js +0 -11
- package/dist/cjs/repositories/realm/schemas.js +0 -157
- package/dist/cjs/repositories/realm/types.js +0 -7
- package/dist/cjs/repositories/realm/walletRepository.js +0 -305
- package/dist/cjs/repositories/scriptFromAddress.js +0 -16
- package/dist/cjs/repositories/serialization.js +0 -82
- package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
- package/dist/cjs/repositories/sqlite/index.js +0 -7
- package/dist/cjs/repositories/sqlite/types.js +0 -2
- package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
- package/dist/cjs/repositories/walletRepository.js +0 -2
- package/dist/cjs/script/address.js +0 -108
- package/dist/cjs/script/base.js +0 -185
- package/dist/cjs/script/default.js +0 -57
- package/dist/cjs/script/delegate.js +0 -53
- package/dist/cjs/script/tapscript.js +0 -619
- package/dist/cjs/script/vhtlc.js +0 -170
- package/dist/cjs/storage/asyncStorage.js +0 -50
- package/dist/cjs/storage/fileSystem.js +0 -141
- package/dist/cjs/storage/inMemory.js +0 -24
- package/dist/cjs/storage/index.js +0 -2
- package/dist/cjs/storage/indexedDB.js +0 -101
- package/dist/cjs/storage/localStorage.js +0 -51
- package/dist/cjs/tree/signingSession.js +0 -229
- package/dist/cjs/tree/txTree.js +0 -192
- package/dist/cjs/tree/validation.js +0 -107
- package/dist/cjs/utils/anchor.js +0 -35
- package/dist/cjs/utils/arkTransaction.js +0 -271
- package/dist/cjs/utils/bip21.js +0 -127
- package/dist/cjs/utils/syncCursors.js +0 -128
- package/dist/cjs/utils/timelock.js +0 -59
- package/dist/cjs/utils/transaction.js +0 -28
- package/dist/cjs/utils/transactionHistory.js +0 -183
- package/dist/cjs/utils/txSizeEstimator.js +0 -132
- package/dist/cjs/utils/unknownFields.js +0 -174
- package/dist/cjs/wallet/asset-manager.js +0 -330
- package/dist/cjs/wallet/asset.js +0 -119
- package/dist/cjs/wallet/batch.js +0 -183
- package/dist/cjs/wallet/delegator.js +0 -302
- package/dist/cjs/wallet/expo/background.js +0 -116
- package/dist/cjs/wallet/expo/index.js +0 -9
- package/dist/cjs/wallet/expo/wallet.js +0 -230
- package/dist/cjs/wallet/hdDescriptorProvider.js +0 -159
- package/dist/cjs/wallet/index.js +0 -82
- package/dist/cjs/wallet/onchain.js +0 -290
- package/dist/cjs/wallet/ramps.js +0 -216
- package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
- package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1173
- package/dist/cjs/wallet/unroll.js +0 -289
- package/dist/cjs/wallet/utils.js +0 -111
- package/dist/cjs/wallet/validation.js +0 -154
- package/dist/cjs/wallet/vtxo-manager.js +0 -1142
- package/dist/cjs/wallet/wallet.js +0 -2049
- package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
- package/dist/cjs/worker/browser/utils.js +0 -67
- package/dist/cjs/worker/errors.js +0 -16
- package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
- package/dist/cjs/worker/expo/index.js +0 -13
- package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
- package/dist/cjs/worker/expo/processors/index.js +0 -6
- package/dist/cjs/worker/expo/taskQueue.js +0 -41
- package/dist/cjs/worker/expo/taskRunner.js +0 -73
- package/dist/cjs/worker/messageBus.js +0 -473
- package/dist/esm/adapters/asyncStorage.js +0 -1
- package/dist/esm/adapters/expo.js +0 -3
- package/dist/esm/adapters/fileSystem.js +0 -1
- package/dist/esm/adapters/indexedDB.js +0 -1
- package/dist/esm/adapters/localStorage.js +0 -1
- package/dist/esm/arkfee/celenv.js +0 -40
- package/dist/esm/arkfee/estimator.js +0 -139
- package/dist/esm/arkfee/index.js +0 -1
- package/dist/esm/arkfee/types.js +0 -22
- package/dist/esm/arknote/index.js +0 -124
- package/dist/esm/bip322/index.js +0 -267
- package/dist/esm/contracts/arkcontract.js +0 -140
- package/dist/esm/contracts/contractManager.js +0 -625
- package/dist/esm/contracts/contractWatcher.js +0 -594
- package/dist/esm/contracts/handlers/default.js +0 -90
- package/dist/esm/contracts/handlers/delegate.js +0 -87
- package/dist/esm/contracts/handlers/helpers.js +0 -110
- package/dist/esm/contracts/handlers/index.js +0 -12
- package/dist/esm/contracts/handlers/registry.js +0 -86
- package/dist/esm/contracts/handlers/vhtlc.js +0 -191
- package/dist/esm/contracts/index.js +0 -13
- package/dist/esm/contracts/types.js +0 -1
- package/dist/esm/contracts/vtxoOwnership.js +0 -69
- package/dist/esm/extension/asset/assetGroup.js +0 -224
- package/dist/esm/extension/asset/assetId.js +0 -148
- package/dist/esm/extension/asset/assetInput.js +0 -217
- package/dist/esm/extension/asset/assetOutput.js +0 -169
- package/dist/esm/extension/asset/assetRef.js +0 -144
- package/dist/esm/extension/asset/index.js +0 -8
- package/dist/esm/extension/asset/metadata.js +0 -182
- package/dist/esm/extension/asset/packet.js +0 -110
- package/dist/esm/extension/asset/types.js +0 -19
- package/dist/esm/extension/asset/utils.js +0 -99
- package/dist/esm/extension/index.js +0 -248
- package/dist/esm/extension/packet.js +0 -16
- package/dist/esm/forfeit.js +0 -41
- package/dist/esm/identity/descriptor.js +0 -161
- package/dist/esm/identity/descriptorProvider.js +0 -1
- package/dist/esm/identity/hdCapableIdentity.js +0 -1
- package/dist/esm/identity/index.js +0 -12
- package/dist/esm/identity/seedIdentity.js +0 -453
- package/dist/esm/identity/serialize.js +0 -164
- package/dist/esm/identity/singleKey.js +0 -121
- package/dist/esm/identity/staticDescriptorProvider.js +0 -61
- package/dist/esm/index.js +0 -87
- package/dist/esm/intent/index.js +0 -255
- package/dist/esm/musig2/index.js +0 -3
- package/dist/esm/musig2/keys.js +0 -21
- package/dist/esm/musig2/nonces.js +0 -11
- package/dist/esm/musig2/sign.js +0 -63
- package/dist/esm/networks.js +0 -22
- package/dist/esm/package.json +0 -3
- package/dist/esm/providers/ark.js +0 -572
- package/dist/esm/providers/delegator.js +0 -81
- package/dist/esm/providers/electrum.js +0 -864
- package/dist/esm/providers/errors.js +0 -54
- package/dist/esm/providers/expoArk.js +0 -78
- package/dist/esm/providers/expoIndexer.js +0 -107
- package/dist/esm/providers/expoUtils.js +0 -87
- package/dist/esm/providers/indexer.js +0 -626
- package/dist/esm/providers/onchain.js +0 -258
- package/dist/esm/providers/utils.js +0 -117
- package/dist/esm/repositories/contractRepository.js +0 -1
- package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
- package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
- package/dist/esm/repositories/index.js +0 -10
- package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
- package/dist/esm/repositories/indexedDB/db.js +0 -4
- package/dist/esm/repositories/indexedDB/manager.js +0 -95
- package/dist/esm/repositories/indexedDB/schema.js +0 -199
- package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
- package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
- package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
- package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
- package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
- package/dist/esm/repositories/realm/contractRepository.js +0 -112
- package/dist/esm/repositories/realm/index.js +0 -3
- package/dist/esm/repositories/realm/schemas.js +0 -153
- package/dist/esm/repositories/realm/types.js +0 -6
- package/dist/esm/repositories/realm/walletRepository.js +0 -301
- package/dist/esm/repositories/scriptFromAddress.js +0 -13
- package/dist/esm/repositories/serialization.js +0 -67
- package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
- package/dist/esm/repositories/sqlite/index.js +0 -2
- package/dist/esm/repositories/sqlite/types.js +0 -1
- package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
- package/dist/esm/repositories/walletRepository.js +0 -1
- package/dist/esm/script/address.js +0 -104
- package/dist/esm/script/base.js +0 -179
- package/dist/esm/script/default.js +0 -54
- package/dist/esm/script/delegate.js +0 -50
- package/dist/esm/script/tapscript.js +0 -615
- package/dist/esm/script/vhtlc.js +0 -167
- package/dist/esm/storage/asyncStorage.js +0 -46
- package/dist/esm/storage/fileSystem.js +0 -104
- package/dist/esm/storage/inMemory.js +0 -20
- package/dist/esm/storage/index.js +0 -1
- package/dist/esm/storage/indexedDB.js +0 -97
- package/dist/esm/storage/localStorage.js +0 -47
- package/dist/esm/tree/signingSession.js +0 -191
- package/dist/esm/tree/txTree.js +0 -188
- package/dist/esm/tree/validation.js +0 -101
- package/dist/esm/utils/anchor.js +0 -31
- package/dist/esm/utils/arkTransaction.js +0 -264
- package/dist/esm/utils/bip21.js +0 -123
- package/dist/esm/utils/syncCursors.js +0 -119
- package/dist/esm/utils/timelock.js +0 -22
- package/dist/esm/utils/transaction.js +0 -24
- package/dist/esm/utils/transactionHistory.js +0 -180
- package/dist/esm/utils/txSizeEstimator.js +0 -128
- package/dist/esm/utils/unknownFields.js +0 -169
- package/dist/esm/wallet/asset-manager.js +0 -325
- package/dist/esm/wallet/asset.js +0 -113
- package/dist/esm/wallet/batch.js +0 -180
- package/dist/esm/wallet/delegator.js +0 -297
- package/dist/esm/wallet/expo/background.js +0 -111
- package/dist/esm/wallet/expo/index.js +0 -2
- package/dist/esm/wallet/expo/wallet.js +0 -193
- package/dist/esm/wallet/hdDescriptorProvider.js +0 -155
- package/dist/esm/wallet/index.js +0 -75
- package/dist/esm/wallet/onchain.js +0 -285
- package/dist/esm/wallet/ramps.js +0 -212
- package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
- package/dist/esm/wallet/serviceWorker/wallet.js +0 -1168
- package/dist/esm/wallet/unroll.js +0 -285
- package/dist/esm/wallet/utils.js +0 -103
- package/dist/esm/wallet/validation.js +0 -142
- package/dist/esm/wallet/vtxo-manager.js +0 -1136
- package/dist/esm/wallet/wallet.js +0 -2041
- package/dist/esm/worker/browser/service-worker-manager.js +0 -177
- package/dist/esm/worker/browser/utils.js +0 -63
- package/dist/esm/worker/errors.js +0 -11
- package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
- package/dist/esm/worker/expo/index.js +0 -4
- package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
- package/dist/esm/worker/expo/processors/index.js +0 -1
- package/dist/esm/worker/expo/taskQueue.js +0 -37
- package/dist/esm/worker/expo/taskRunner.js +0 -69
- package/dist/esm/worker/messageBus.js +0 -469
- package/dist/types/adapters/asyncStorage.d.ts +0 -2
- package/dist/types/adapters/expo.d.ts +0 -4
- package/dist/types/adapters/fileSystem.d.ts +0 -2
- package/dist/types/adapters/indexedDB.d.ts +0 -2
- package/dist/types/adapters/localStorage.d.ts +0 -2
- package/dist/types/arkfee/celenv.d.ts +0 -25
- package/dist/types/arkfee/estimator.d.ts +0 -49
- package/dist/types/arkfee/index.d.ts +0 -2
- package/dist/types/arkfee/types.d.ts +0 -38
- package/dist/types/arknote/index.d.ts +0 -84
- package/dist/types/bip322/index.d.ts +0 -55
- package/dist/types/contracts/arkcontract.d.ts +0 -99
- package/dist/types/contracts/contractManager.d.ts +0 -381
- package/dist/types/contracts/contractWatcher.d.ts +0 -217
- package/dist/types/contracts/handlers/default.d.ts +0 -19
- package/dist/types/contracts/handlers/delegate.d.ts +0 -21
- package/dist/types/contracts/handlers/helpers.d.ts +0 -19
- package/dist/types/contracts/handlers/index.d.ts +0 -7
- package/dist/types/contracts/handlers/registry.d.ts +0 -65
- package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
- package/dist/types/contracts/index.d.ts +0 -14
- package/dist/types/contracts/types.d.ts +0 -233
- package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
- package/dist/types/extension/asset/assetGroup.d.ts +0 -119
- package/dist/types/extension/asset/assetId.d.ts +0 -83
- package/dist/types/extension/asset/assetInput.d.ts +0 -64
- package/dist/types/extension/asset/assetOutput.d.ts +0 -54
- package/dist/types/extension/asset/assetRef.d.ts +0 -91
- package/dist/types/extension/asset/index.d.ts +0 -8
- package/dist/types/extension/asset/metadata.d.ts +0 -52
- package/dist/types/extension/asset/packet.d.ts +0 -41
- package/dist/types/extension/asset/types.d.ts +0 -16
- package/dist/types/extension/asset/utils.d.ts +0 -21
- package/dist/types/extension/index.d.ts +0 -56
- package/dist/types/extension/packet.d.ts +0 -21
- package/dist/types/forfeit.d.ts +0 -18
- package/dist/types/identity/descriptor.d.ts +0 -61
- package/dist/types/identity/descriptorProvider.d.ts +0 -35
- package/dist/types/identity/hdCapableIdentity.d.ts +0 -44
- package/dist/types/identity/index.d.ts +0 -56
- package/dist/types/identity/seedIdentity.d.ts +0 -254
- package/dist/types/identity/serialize.d.ts +0 -96
- package/dist/types/identity/singleKey.d.ts +0 -62
- package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
- package/dist/types/index.d.ts +0 -59
- package/dist/types/intent/index.d.ts +0 -86
- package/dist/types/musig2/index.d.ts +0 -4
- package/dist/types/musig2/keys.d.ts +0 -9
- package/dist/types/musig2/nonces.d.ts +0 -14
- package/dist/types/musig2/sign.d.ts +0 -27
- package/dist/types/networks.d.ts +0 -16
- package/dist/types/providers/ark.d.ts +0 -369
- package/dist/types/providers/delegator.d.ts +0 -82
- package/dist/types/providers/electrum.d.ts +0 -312
- package/dist/types/providers/errors.d.ts +0 -13
- package/dist/types/providers/expoArk.d.ts +0 -22
- package/dist/types/providers/expoIndexer.d.ts +0 -18
- package/dist/types/providers/expoUtils.d.ts +0 -18
- package/dist/types/providers/indexer.d.ts +0 -301
- package/dist/types/providers/onchain.d.ts +0 -148
- package/dist/types/providers/utils.d.ts +0 -12
- package/dist/types/repositories/contractRepository.d.ts +0 -32
- package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
- package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
- package/dist/types/repositories/index.d.ts +0 -9
- package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
- package/dist/types/repositories/indexedDB/db.d.ts +0 -4
- package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
- package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
- package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
- package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
- package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
- package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
- package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
- package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
- package/dist/types/repositories/realm/index.d.ts +0 -4
- package/dist/types/repositories/realm/types.d.ts +0 -16
- package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
- package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
- package/dist/types/repositories/serialization.d.ts +0 -65
- package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
- package/dist/types/repositories/sqlite/index.d.ts +0 -3
- package/dist/types/repositories/sqlite/types.d.ts +0 -18
- package/dist/types/repositories/walletRepository.d.ts +0 -72
- package/dist/types/script/address.d.ts +0 -67
- package/dist/types/script/base.d.ts +0 -105
- package/dist/types/script/default.d.ts +0 -44
- package/dist/types/script/delegate.d.ts +0 -40
- package/dist/types/script/tapscript.d.ts +0 -169
- package/dist/types/script/vhtlc.d.ts +0 -66
- package/dist/types/tree/signingSession.d.ts +0 -37
- package/dist/types/tree/txTree.d.ts +0 -28
- package/dist/types/tree/validation.d.ts +0 -15
- package/dist/types/utils/anchor.d.ts +0 -19
- package/dist/types/utils/arkTransaction.d.ts +0 -49
- package/dist/types/utils/bip21.d.ts +0 -38
- package/dist/types/utils/syncCursors.d.ts +0 -60
- package/dist/types/utils/timelock.d.ts +0 -9
- package/dist/types/utils/transaction.d.ts +0 -13
- package/dist/types/utils/transactionHistory.d.ts +0 -15
- package/dist/types/utils/txSizeEstimator.d.ts +0 -40
- package/dist/types/utils/unknownFields.d.ts +0 -83
- package/dist/types/wallet/asset-manager.d.ts +0 -69
- package/dist/types/wallet/asset.d.ts +0 -21
- package/dist/types/wallet/batch.d.ts +0 -107
- package/dist/types/wallet/delegator.d.ts +0 -48
- package/dist/types/wallet/expo/background.d.ts +0 -66
- package/dist/types/wallet/expo/index.d.ts +0 -4
- package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -93
- package/dist/types/wallet/index.d.ts +0 -755
- package/dist/types/wallet/onchain.d.ts +0 -109
- package/dist/types/wallet/ramps.d.ts +0 -64
- package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
- package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -238
- package/dist/types/wallet/unroll.d.ts +0 -114
- package/dist/types/wallet/utils.d.ts +0 -36
- package/dist/types/wallet/validation.d.ts +0 -24
- package/dist/types/wallet/vtxo-manager.d.ts +0 -476
- package/dist/types/wallet/wallet.d.ts +0 -360
- package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
- package/dist/types/worker/browser/utils.d.ts +0 -17
- package/dist/types/worker/errors.d.ts +0 -7
- package/dist/types/worker/expo/index.d.ts +0 -7
- package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
- package/dist/types/worker/expo/processors/index.d.ts +0 -1
- package/dist/types/worker/expo/taskQueue.d.ts +0 -50
- package/dist/types/worker/expo/taskRunner.d.ts +0 -66
- package/dist/types/worker/messageBus.d.ts +0 -188
|
@@ -1,469 +0,0 @@
|
|
|
1
|
-
/// <reference lib="webworker" />
|
|
2
|
-
import { getActiveServiceWorker, setupServiceWorkerOnce, } from "./browser/service-worker-manager.js";
|
|
3
|
-
import { RestArkProvider } from "../providers/ark.js";
|
|
4
|
-
import { RestDelegatorProvider } from "../providers/delegator.js";
|
|
5
|
-
import { hydrateIdentity, isSigningSerialized, normalizeSerializedIdentity, } from "../identity/index.js";
|
|
6
|
-
import { ReadonlyWallet, Wallet } from "../wallet/wallet.js";
|
|
7
|
-
import { MessageBusNotInitializedError, ServiceWorkerTimeoutError, } from "./errors.js";
|
|
8
|
-
/**
|
|
9
|
-
* Grace period after a handler times out during which late handler
|
|
10
|
-
* completion is still delivered to the client. Once this expires,
|
|
11
|
-
* the bus sends an "Operation abandoned" error so the message id
|
|
12
|
-
* never goes silent indefinitely.
|
|
13
|
-
*/
|
|
14
|
-
const LATE_DELIVERY_GRACE_MS = 5 * 60000;
|
|
15
|
-
export class MessageBus {
|
|
16
|
-
/** Create the service-worker message bus with repositories and handler configuration. */
|
|
17
|
-
constructor(walletRepository, contractRepository, { messageHandlers, tickIntervalMs = 10000, messageTimeoutMs = 30000, messageTimeoutOverrides = {}, debug = false, buildServices, }) {
|
|
18
|
-
this.walletRepository = walletRepository;
|
|
19
|
-
this.contractRepository = contractRepository;
|
|
20
|
-
this.lateDeliveries = new Set();
|
|
21
|
-
this.running = false;
|
|
22
|
-
this.tickTimeout = null;
|
|
23
|
-
this.tickInProgress = false;
|
|
24
|
-
this.debug = false;
|
|
25
|
-
this.initialized = false;
|
|
26
|
-
this.boundOnMessage = this.onMessage.bind(this);
|
|
27
|
-
this.handlers = new Map(messageHandlers.map((u) => [u.messageTag, u]));
|
|
28
|
-
this.tickIntervalMs = tickIntervalMs;
|
|
29
|
-
this.messageTimeoutMs = messageTimeoutMs;
|
|
30
|
-
this.constructorTimeoutOverrides = { ...messageTimeoutOverrides };
|
|
31
|
-
this.messageTimeoutOverrides = { ...this.constructorTimeoutOverrides };
|
|
32
|
-
this.debug = debug;
|
|
33
|
-
this.buildServicesFn = buildServices ?? this.buildServices.bind(this);
|
|
34
|
-
}
|
|
35
|
-
/** Start the message bus and attach service-worker event listeners. */
|
|
36
|
-
async start() {
|
|
37
|
-
if (this.running)
|
|
38
|
-
return;
|
|
39
|
-
this.running = true;
|
|
40
|
-
if (this.debug)
|
|
41
|
-
console.log("MessageBus starting");
|
|
42
|
-
// Hook message routing
|
|
43
|
-
self.addEventListener("message", this.boundOnMessage);
|
|
44
|
-
// activate service worker immediately
|
|
45
|
-
self.addEventListener("install", () => {
|
|
46
|
-
self.skipWaiting();
|
|
47
|
-
});
|
|
48
|
-
// take control of clients immediately
|
|
49
|
-
self.addEventListener("activate", () => {
|
|
50
|
-
self.clients.claim();
|
|
51
|
-
if (this.initialized) {
|
|
52
|
-
this.runTick();
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
/** Stop the message bus, cancel ticks, and stop all registered handlers. */
|
|
57
|
-
async stop() {
|
|
58
|
-
if (this.debug)
|
|
59
|
-
console.log("MessageBus stopping");
|
|
60
|
-
this.running = false;
|
|
61
|
-
this.tickInProgress = false;
|
|
62
|
-
this.initialized = false;
|
|
63
|
-
if (this.tickTimeout !== null) {
|
|
64
|
-
self.clearTimeout(this.tickTimeout);
|
|
65
|
-
this.tickTimeout = null;
|
|
66
|
-
}
|
|
67
|
-
for (const record of this.lateDeliveries) {
|
|
68
|
-
record.settled = true;
|
|
69
|
-
self.clearTimeout(record.deadline);
|
|
70
|
-
}
|
|
71
|
-
this.lateDeliveries.clear();
|
|
72
|
-
self.removeEventListener("message", this.boundOnMessage);
|
|
73
|
-
await Promise.all(Array.from(this.handlers.values()).map((updater) => updater.stop()));
|
|
74
|
-
}
|
|
75
|
-
scheduleNextTick() {
|
|
76
|
-
if (!this.running)
|
|
77
|
-
return;
|
|
78
|
-
if (this.tickTimeout !== null)
|
|
79
|
-
return;
|
|
80
|
-
if (this.tickInProgress)
|
|
81
|
-
return;
|
|
82
|
-
this.tickTimeout = self.setTimeout(() => this.runTick(), this.tickIntervalMs);
|
|
83
|
-
}
|
|
84
|
-
async runTick() {
|
|
85
|
-
if (!this.running)
|
|
86
|
-
return;
|
|
87
|
-
if (this.tickInProgress)
|
|
88
|
-
return;
|
|
89
|
-
this.tickInProgress = true;
|
|
90
|
-
if (this.tickTimeout !== null) {
|
|
91
|
-
self.clearTimeout(this.tickTimeout);
|
|
92
|
-
this.tickTimeout = null;
|
|
93
|
-
}
|
|
94
|
-
try {
|
|
95
|
-
const now = Date.now();
|
|
96
|
-
for (const updater of this.handlers.values()) {
|
|
97
|
-
try {
|
|
98
|
-
const tickLabel = `${updater.messageTag}:tick`;
|
|
99
|
-
const response = await this.withTimeout(updater.tick(now), this.resolveTimeoutMs(tickLabel, updater.messageTag), tickLabel);
|
|
100
|
-
if (this.debug)
|
|
101
|
-
console.log(`[${updater.messageTag}] outgoing tick response:`, response);
|
|
102
|
-
if (response && response.length > 0) {
|
|
103
|
-
self.clients
|
|
104
|
-
.matchAll({
|
|
105
|
-
includeUncontrolled: true,
|
|
106
|
-
type: "window",
|
|
107
|
-
})
|
|
108
|
-
.then((clients) => {
|
|
109
|
-
for (const message of response) {
|
|
110
|
-
clients.forEach((client) => {
|
|
111
|
-
client.postMessage(message);
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
catch (err) {
|
|
118
|
-
if (this.debug)
|
|
119
|
-
console.error(`[${updater.messageTag}] tick failed`, err);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
finally {
|
|
124
|
-
this.tickInProgress = false;
|
|
125
|
-
this.scheduleNextTick();
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
async waitForInit(config) {
|
|
129
|
-
if (this.initialized) {
|
|
130
|
-
// Stop existing handlers before re-initializing.
|
|
131
|
-
// This handles the case where CLEAR was called, which nullifies
|
|
132
|
-
// handler state (readonlyWallet, etc.) without resetting the
|
|
133
|
-
// initialized flag. Without this, handlers never get start()
|
|
134
|
-
// called again and all messages fail with "not initialized".
|
|
135
|
-
//
|
|
136
|
-
// Clear the flag first so onMessage() rejects incoming messages
|
|
137
|
-
// during the stop/start window instead of routing them to
|
|
138
|
-
// half-reset handlers. Restored to true after start() completes.
|
|
139
|
-
this.initialized = false;
|
|
140
|
-
await Promise.all(Array.from(this.handlers.values()).map((h) => h.stop().catch(() => { })));
|
|
141
|
-
}
|
|
142
|
-
// Recompute the active timeout map from scratch so a prior init's
|
|
143
|
-
// keys cannot linger after re-init with a smaller map.
|
|
144
|
-
this.messageTimeoutOverrides = {
|
|
145
|
-
...this.constructorTimeoutOverrides,
|
|
146
|
-
...(config.messageTimeouts ?? {}),
|
|
147
|
-
};
|
|
148
|
-
const services = await this.buildServicesFn(config);
|
|
149
|
-
// Start all handlers
|
|
150
|
-
for (const updater of this.handlers.values()) {
|
|
151
|
-
if (this.debug)
|
|
152
|
-
console.log(`Starting updater: ${updater.messageTag}`);
|
|
153
|
-
await updater.start(services, {
|
|
154
|
-
walletRepository: this.walletRepository,
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
// Kick off scheduler
|
|
158
|
-
this.scheduleNextTick();
|
|
159
|
-
this.initialized = true;
|
|
160
|
-
}
|
|
161
|
-
async buildServices(config) {
|
|
162
|
-
const arkProvider = new RestArkProvider(config.arkServer.url);
|
|
163
|
-
const storage = {
|
|
164
|
-
walletRepository: this.walletRepository,
|
|
165
|
-
contractRepository: this.contractRepository,
|
|
166
|
-
};
|
|
167
|
-
const delegatorProvider = config.delegatorUrl
|
|
168
|
-
? new RestDelegatorProvider(config.delegatorUrl)
|
|
169
|
-
: undefined;
|
|
170
|
-
const serialized = normalizeSerializedIdentity(config.wallet);
|
|
171
|
-
if (isSigningSerialized(serialized)) {
|
|
172
|
-
const identity = hydrateIdentity(serialized);
|
|
173
|
-
const wallet = await Wallet.create({
|
|
174
|
-
identity,
|
|
175
|
-
arkServerUrl: config.arkServer.url,
|
|
176
|
-
arkServerPublicKey: config.arkServer.publicKey,
|
|
177
|
-
indexerUrl: config.indexerUrl,
|
|
178
|
-
esploraUrl: config.esploraUrl,
|
|
179
|
-
storage,
|
|
180
|
-
delegatorProvider,
|
|
181
|
-
settlementConfig: config.settlementConfig,
|
|
182
|
-
watcherConfig: config.watcherConfig,
|
|
183
|
-
});
|
|
184
|
-
return { wallet, arkProvider, readonlyWallet: wallet };
|
|
185
|
-
}
|
|
186
|
-
const identity = hydrateIdentity(serialized);
|
|
187
|
-
const readonlyWallet = await ReadonlyWallet.create({
|
|
188
|
-
identity,
|
|
189
|
-
arkServerUrl: config.arkServer.url,
|
|
190
|
-
arkServerPublicKey: config.arkServer.publicKey,
|
|
191
|
-
indexerUrl: config.indexerUrl,
|
|
192
|
-
esploraUrl: config.esploraUrl,
|
|
193
|
-
storage,
|
|
194
|
-
delegatorProvider,
|
|
195
|
-
watcherConfig: config.watcherConfig,
|
|
196
|
-
});
|
|
197
|
-
return { readonlyWallet, arkProvider };
|
|
198
|
-
}
|
|
199
|
-
onMessage(event) {
|
|
200
|
-
// Keep the service worker alive while async work is pending.
|
|
201
|
-
// Without this, the browser may terminate the SW mid-operation,
|
|
202
|
-
// causing all pending responses to be lost silently.
|
|
203
|
-
const promise = this.processMessage(event);
|
|
204
|
-
if (typeof event.waitUntil === "function") {
|
|
205
|
-
event.waitUntil(promise);
|
|
206
|
-
}
|
|
207
|
-
return promise;
|
|
208
|
-
}
|
|
209
|
-
async processMessage(event) {
|
|
210
|
-
const { id, tag, broadcast } = event.data;
|
|
211
|
-
if (tag === "PING") {
|
|
212
|
-
this.deliverResponse(event.source, { id, tag: "PONG" }, { id, tag: "PONG" });
|
|
213
|
-
return;
|
|
214
|
-
}
|
|
215
|
-
if (tag === "INITIALIZE_MESSAGE_BUS") {
|
|
216
|
-
if (this.debug) {
|
|
217
|
-
console.log("Init Command received");
|
|
218
|
-
}
|
|
219
|
-
// Intentionally not wrapped with withTimeout: initialization
|
|
220
|
-
// performs network calls (buildServices) and handler startup
|
|
221
|
-
// that may legitimately exceed the message timeout.
|
|
222
|
-
await this.waitForInit(event.data.config);
|
|
223
|
-
this.deliverResponse(event.source, { id, tag }, { id, tag });
|
|
224
|
-
if (this.debug) {
|
|
225
|
-
console.log("MessageBus initialized");
|
|
226
|
-
}
|
|
227
|
-
return;
|
|
228
|
-
}
|
|
229
|
-
if (!this.initialized) {
|
|
230
|
-
if (this.debug)
|
|
231
|
-
console.warn("Event received before initialization, dropping", event.data);
|
|
232
|
-
// Send error response so the caller's promise rejects instead of
|
|
233
|
-
// hanging forever. This happens when the browser kills and restarts
|
|
234
|
-
// the service worker — the new instance has initialized=false and
|
|
235
|
-
// messages arrive before INITIALIZE_MESSAGE_BUS is re-sent.
|
|
236
|
-
const fallbackTag = tag ?? "unknown";
|
|
237
|
-
this.deliverResponse(event.source, {
|
|
238
|
-
id,
|
|
239
|
-
tag: fallbackTag,
|
|
240
|
-
error: new MessageBusNotInitializedError(),
|
|
241
|
-
}, { id, tag: fallbackTag });
|
|
242
|
-
return;
|
|
243
|
-
}
|
|
244
|
-
if (!id || !tag) {
|
|
245
|
-
if (this.debug)
|
|
246
|
-
console.error("Invalid message received, missing required fields:", event.data);
|
|
247
|
-
const fallbackTag = tag ?? "unknown";
|
|
248
|
-
this.deliverResponse(event.source, {
|
|
249
|
-
id,
|
|
250
|
-
tag: fallbackTag,
|
|
251
|
-
error: new TypeError("Invalid message received, missing required fields"),
|
|
252
|
-
}, { id, tag: fallbackTag });
|
|
253
|
-
return;
|
|
254
|
-
}
|
|
255
|
-
const messageType = this.extractMessageType(event.data);
|
|
256
|
-
if (broadcast) {
|
|
257
|
-
const updaters = Array.from(this.handlers.values());
|
|
258
|
-
const entries = updaters.map((updater) => {
|
|
259
|
-
const label = this.labelFor(messageType, updater.messageTag);
|
|
260
|
-
const timeoutMs = this.resolveTimeoutMs(messageType, updater.messageTag);
|
|
261
|
-
const handlerPromise = updater.handleMessage(event.data);
|
|
262
|
-
const raced = updater.isLongRunning?.(event.data)
|
|
263
|
-
? handlerPromise
|
|
264
|
-
: this.withTimeout(handlerPromise, timeoutMs, label);
|
|
265
|
-
return { updater, handlerPromise, raced };
|
|
266
|
-
});
|
|
267
|
-
const results = await Promise.allSettled(entries.map((e) => e.raced));
|
|
268
|
-
results.forEach((result, index) => {
|
|
269
|
-
const { updater, handlerPromise } = entries[index];
|
|
270
|
-
const handlerTag = updater.messageTag;
|
|
271
|
-
const context = { id, tag: handlerTag, messageType };
|
|
272
|
-
if (result.status === "fulfilled") {
|
|
273
|
-
const response = result.value;
|
|
274
|
-
// Always deliver a response so the caller's message id
|
|
275
|
-
// never goes silent. Handlers returning null/undefined
|
|
276
|
-
// get an explicit ack envelope.
|
|
277
|
-
this.deliverResponse(event.source, response ?? { id, tag: handlerTag }, context);
|
|
278
|
-
}
|
|
279
|
-
else {
|
|
280
|
-
if (this.debug)
|
|
281
|
-
console.error(`[${handlerTag}] handleMessage failed`, result.reason);
|
|
282
|
-
const error = toError(result.reason);
|
|
283
|
-
this.deliverResponse(event.source, { id, tag: handlerTag, error }, context);
|
|
284
|
-
// If the error was a timeout, keep watching the
|
|
285
|
-
// underlying handler and surface its eventual result
|
|
286
|
-
// under the same id.
|
|
287
|
-
if (result.reason instanceof ServiceWorkerTimeoutError) {
|
|
288
|
-
this.attachLateDelivery(handlerPromise, event.source, id, handlerTag, messageType);
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
});
|
|
292
|
-
return;
|
|
293
|
-
}
|
|
294
|
-
const updater = this.handlers.get(tag);
|
|
295
|
-
if (!updater) {
|
|
296
|
-
if (this.debug)
|
|
297
|
-
console.warn(`[${tag}] unknown message tag, ignoring message`);
|
|
298
|
-
this.deliverResponse(event.source, {
|
|
299
|
-
id,
|
|
300
|
-
tag,
|
|
301
|
-
error: new Error(`Unknown handler tag: ${tag}`),
|
|
302
|
-
}, { id, tag, messageType });
|
|
303
|
-
return;
|
|
304
|
-
}
|
|
305
|
-
const label = this.labelFor(messageType, tag);
|
|
306
|
-
const timeoutMs = this.resolveTimeoutMs(messageType, tag);
|
|
307
|
-
const handlerPromise = updater.handleMessage(event.data);
|
|
308
|
-
const context = { id, tag, messageType };
|
|
309
|
-
try {
|
|
310
|
-
const response = updater.isLongRunning?.(event.data)
|
|
311
|
-
? await handlerPromise
|
|
312
|
-
: await this.withTimeout(handlerPromise, timeoutMs, label);
|
|
313
|
-
if (this.debug)
|
|
314
|
-
console.log(`[${tag}] outgoing response:`, response);
|
|
315
|
-
// Always deliver a response so the caller's message id never
|
|
316
|
-
// goes silent. A handler returning null/undefined yields an
|
|
317
|
-
// explicit ack envelope.
|
|
318
|
-
this.deliverResponse(event.source, response ?? { id, tag }, context);
|
|
319
|
-
}
|
|
320
|
-
catch (err) {
|
|
321
|
-
if (this.debug)
|
|
322
|
-
console.error(`[${tag}] handleMessage failed`, err);
|
|
323
|
-
const error = toError(err);
|
|
324
|
-
this.deliverResponse(event.source, { id, tag, error }, context);
|
|
325
|
-
// When we abandoned the handler via timeout, keep watching it
|
|
326
|
-
// so the client's message id eventually gets a final response.
|
|
327
|
-
if (err instanceof ServiceWorkerTimeoutError) {
|
|
328
|
-
this.attachLateDelivery(handlerPromise, event.source, id, tag, messageType);
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
|
-
}
|
|
332
|
-
/**
|
|
333
|
-
* Race `promise` against a timeout. Note: this does NOT cancel the
|
|
334
|
-
* underlying work — the original promise keeps running. Call
|
|
335
|
-
* `attachLateDelivery` after catching the timeout to surface the
|
|
336
|
-
* eventual result so the message id does not go silent.
|
|
337
|
-
*/
|
|
338
|
-
withTimeout(promise, timeoutMs, label) {
|
|
339
|
-
if (timeoutMs <= 0)
|
|
340
|
-
return promise;
|
|
341
|
-
return new Promise((resolve, reject) => {
|
|
342
|
-
const timer = self.setTimeout(() => {
|
|
343
|
-
reject(new ServiceWorkerTimeoutError(`Message handler timed out after ${timeoutMs}ms (${label})`));
|
|
344
|
-
}, timeoutMs);
|
|
345
|
-
promise.then((val) => {
|
|
346
|
-
self.clearTimeout(timer);
|
|
347
|
-
resolve(val);
|
|
348
|
-
}, (err) => {
|
|
349
|
-
self.clearTimeout(timer);
|
|
350
|
-
reject(err);
|
|
351
|
-
});
|
|
352
|
-
});
|
|
353
|
-
}
|
|
354
|
-
/**
|
|
355
|
-
* Extract the declared `type` from a request envelope (e.g. "SETTLE").
|
|
356
|
-
* Not every envelope carries a type (PING/INIT are special cased
|
|
357
|
-
* earlier), so this returns undefined for envelopes that lack one.
|
|
358
|
-
*/
|
|
359
|
-
extractMessageType(data) {
|
|
360
|
-
const maybeType = data.type;
|
|
361
|
-
return typeof maybeType === "string" ? maybeType : undefined;
|
|
362
|
-
}
|
|
363
|
-
/**
|
|
364
|
-
* Resolve the timeout for an operation. Message-type overrides take
|
|
365
|
-
* precedence over handler-tag overrides, with the bus-wide default
|
|
366
|
-
* (`messageTimeoutMs`) as the final fallback.
|
|
367
|
-
*/
|
|
368
|
-
resolveTimeoutMs(messageType, handlerTag) {
|
|
369
|
-
if (messageType &&
|
|
370
|
-
Object.prototype.hasOwnProperty.call(this.messageTimeoutOverrides, messageType)) {
|
|
371
|
-
return this.messageTimeoutOverrides[messageType];
|
|
372
|
-
}
|
|
373
|
-
if (Object.prototype.hasOwnProperty.call(this.messageTimeoutOverrides, handlerTag)) {
|
|
374
|
-
return this.messageTimeoutOverrides[handlerTag];
|
|
375
|
-
}
|
|
376
|
-
return this.messageTimeoutMs;
|
|
377
|
-
}
|
|
378
|
-
/**
|
|
379
|
-
* Build a human-readable label for timeout errors. Format:
|
|
380
|
-
* `"<MESSAGE_TYPE> via <HANDLER_TAG>"` when both are known, else the
|
|
381
|
-
* handler tag alone. Used so timeout errors name the operation the
|
|
382
|
-
* client actually triggered (e.g. SETTLE) rather than just the
|
|
383
|
-
* handler that received it (e.g. WALLET_UPDATER).
|
|
384
|
-
*/
|
|
385
|
-
labelFor(messageType, handlerTag) {
|
|
386
|
-
return messageType ? `${messageType} via ${handlerTag}` : handlerTag;
|
|
387
|
-
}
|
|
388
|
-
/**
|
|
389
|
-
* Post a response to the originating client. When `source` is null
|
|
390
|
-
* (client tab closed, detached frame, etc.) the response cannot be
|
|
391
|
-
* delivered; we log the drop in debug mode so it is not invisible.
|
|
392
|
-
*/
|
|
393
|
-
deliverResponse(source, response, context) {
|
|
394
|
-
if (!source) {
|
|
395
|
-
if (this.debug)
|
|
396
|
-
console.warn(`[${context.tag}] cannot deliver response: event.source is null`, {
|
|
397
|
-
id: context.id,
|
|
398
|
-
messageType: context.messageType,
|
|
399
|
-
});
|
|
400
|
-
return;
|
|
401
|
-
}
|
|
402
|
-
source.postMessage(response);
|
|
403
|
-
}
|
|
404
|
-
/**
|
|
405
|
-
* After a handler times out the client has already received a timeout
|
|
406
|
-
* error, but the handler keeps running. Attach a follow-up so the
|
|
407
|
-
* handler's eventual result (or error) is delivered under the same
|
|
408
|
-
* message id, or — if the handler never completes within
|
|
409
|
-
* {@link LATE_DELIVERY_GRACE_MS} — an "Operation abandoned" error is
|
|
410
|
-
* sent so the client's listener (if still attached) does not hang.
|
|
411
|
-
*/
|
|
412
|
-
attachLateDelivery(handlerPromise, source, id, tag, messageType) {
|
|
413
|
-
const context = { id, tag, messageType };
|
|
414
|
-
const record = {
|
|
415
|
-
settled: false,
|
|
416
|
-
deadline: self.setTimeout(() => {
|
|
417
|
-
if (record.settled)
|
|
418
|
-
return;
|
|
419
|
-
record.settled = true;
|
|
420
|
-
this.lateDeliveries.delete(record);
|
|
421
|
-
this.deliverResponse(source, {
|
|
422
|
-
id,
|
|
423
|
-
tag,
|
|
424
|
-
error: new Error(`Operation abandoned: handler did not complete within ${LATE_DELIVERY_GRACE_MS}ms after timeout (${this.labelFor(messageType, tag)})`),
|
|
425
|
-
}, context);
|
|
426
|
-
}, LATE_DELIVERY_GRACE_MS),
|
|
427
|
-
};
|
|
428
|
-
this.lateDeliveries.add(record);
|
|
429
|
-
handlerPromise.then((response) => {
|
|
430
|
-
if (record.settled)
|
|
431
|
-
return;
|
|
432
|
-
record.settled = true;
|
|
433
|
-
self.clearTimeout(record.deadline);
|
|
434
|
-
this.lateDeliveries.delete(record);
|
|
435
|
-
this.deliverResponse(source, response ?? { id, tag }, context);
|
|
436
|
-
}, (err) => {
|
|
437
|
-
if (record.settled)
|
|
438
|
-
return;
|
|
439
|
-
record.settled = true;
|
|
440
|
-
self.clearTimeout(record.deadline);
|
|
441
|
-
this.lateDeliveries.delete(record);
|
|
442
|
-
this.deliverResponse(source, { id, tag, error: toError(err) }, context);
|
|
443
|
-
});
|
|
444
|
-
}
|
|
445
|
-
/**
|
|
446
|
-
* Returns the registered SW for the path.
|
|
447
|
-
* It uses the functions in `service-worker-manager.ts` module.
|
|
448
|
-
* @param path
|
|
449
|
-
* @return the Service Worker
|
|
450
|
-
* @throws if not running in a browser environment
|
|
451
|
-
*/
|
|
452
|
-
static async getServiceWorker(path) {
|
|
453
|
-
return getActiveServiceWorker(path);
|
|
454
|
-
}
|
|
455
|
-
/**
|
|
456
|
-
* Set up and register the Service Worker, ensuring it's done once at most.
|
|
457
|
-
* It uses the functions in `service-worker-manager.ts` module.
|
|
458
|
-
* @param path
|
|
459
|
-
* @return the Service Worker
|
|
460
|
-
* @throws if not running in a browser environment
|
|
461
|
-
*/
|
|
462
|
-
static async setup(path) {
|
|
463
|
-
await setupServiceWorkerOnce(path);
|
|
464
|
-
return getActiveServiceWorker(path);
|
|
465
|
-
}
|
|
466
|
-
}
|
|
467
|
-
function toError(value) {
|
|
468
|
-
return value instanceof Error ? value : new Error(String(value));
|
|
469
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Environment } from "@marcbachmann/cel-js";
|
|
2
|
-
/**
|
|
3
|
-
* Variable names used in CEL expressions
|
|
4
|
-
*/
|
|
5
|
-
export declare const AmountVariableName = "amount";
|
|
6
|
-
export declare const ExpiryVariableName = "expiry";
|
|
7
|
-
export declare const BirthVariableName = "birth";
|
|
8
|
-
export declare const WeightVariableName = "weight";
|
|
9
|
-
export declare const InputTypeVariableName = "inputType";
|
|
10
|
-
export declare const OutputScriptVariableName = "script";
|
|
11
|
-
/**
|
|
12
|
-
* IntentOutputEnv is the CEL environment for output fee calculation
|
|
13
|
-
* Variables: amount, script
|
|
14
|
-
*/
|
|
15
|
-
export declare const IntentOutputEnv: Environment;
|
|
16
|
-
/**
|
|
17
|
-
* IntentOffchainInputEnv is the CEL environment for offchain input fee calculation
|
|
18
|
-
* Variables: amount, expiry, birth, weight, inputType
|
|
19
|
-
*/
|
|
20
|
-
export declare const IntentOffchainInputEnv: Environment;
|
|
21
|
-
/**
|
|
22
|
-
* IntentOnchainInputEnv is the CEL environment for onchain input fee calculation
|
|
23
|
-
* Variables: amount
|
|
24
|
-
*/
|
|
25
|
-
export declare const IntentOnchainInputEnv: Environment;
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { IntentFeeConfig, OffchainInput, OnchainInput, FeeOutput, FeeAmount } from "./types.js";
|
|
2
|
-
/**
|
|
3
|
-
* Estimator evaluates CEL expressions to calculate fees for Arkade intents
|
|
4
|
-
*/
|
|
5
|
-
export declare class Estimator {
|
|
6
|
-
readonly config: IntentFeeConfig;
|
|
7
|
-
private intentOffchainInput?;
|
|
8
|
-
private intentOnchainInput?;
|
|
9
|
-
private intentOffchainOutput?;
|
|
10
|
-
private intentOnchainOutput?;
|
|
11
|
-
/**
|
|
12
|
-
* Creates a new Estimator with the given config
|
|
13
|
-
* @param config - Configuration containing CEL programs for fee calculation
|
|
14
|
-
*/
|
|
15
|
-
constructor(config: IntentFeeConfig);
|
|
16
|
-
/**
|
|
17
|
-
* Evaluates the fee for a given vtxo input
|
|
18
|
-
* @param input - The offchain input to evaluate
|
|
19
|
-
* @returns The fee amount for this input
|
|
20
|
-
*/
|
|
21
|
-
evalOffchainInput(input: OffchainInput): FeeAmount;
|
|
22
|
-
/**
|
|
23
|
-
* Evaluates the fee for a given boarding input
|
|
24
|
-
* @param input - The onchain input to evaluate
|
|
25
|
-
* @returns The fee amount for this input
|
|
26
|
-
*/
|
|
27
|
-
evalOnchainInput(input: OnchainInput): FeeAmount;
|
|
28
|
-
/**
|
|
29
|
-
* Evaluates the fee for a given vtxo output
|
|
30
|
-
* @param output - The output to evaluate
|
|
31
|
-
* @returns The fee amount for this output
|
|
32
|
-
*/
|
|
33
|
-
evalOffchainOutput(output: FeeOutput): FeeAmount;
|
|
34
|
-
/**
|
|
35
|
-
* Evaluates the fee for a given collaborative exit output
|
|
36
|
-
* @param output - The output to evaluate
|
|
37
|
-
* @returns The fee amount for this output
|
|
38
|
-
*/
|
|
39
|
-
evalOnchainOutput(output: FeeOutput): FeeAmount;
|
|
40
|
-
/**
|
|
41
|
-
* Evaluates the fee for a given set of inputs and outputs
|
|
42
|
-
* @param offchainInputs - Array of offchain inputs to evaluate
|
|
43
|
-
* @param onchainInputs - Array of onchain inputs to evaluate
|
|
44
|
-
* @param offchainOutputs - Array of offchain outputs to evaluate
|
|
45
|
-
* @param onchainOutputs - Array of onchain outputs to evaluate
|
|
46
|
-
* @returns The total fee amount
|
|
47
|
-
*/
|
|
48
|
-
eval(offchainInputs: OffchainInput[], onchainInputs: OnchainInput[], offchainOutputs: FeeOutput[], onchainOutputs: FeeOutput[]): FeeAmount;
|
|
49
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* FeeAmount is a wrapper around a number that represents a fee amount in satoshis floating point.
|
|
3
|
-
* @param value - The fee amount in floating point.
|
|
4
|
-
* @example
|
|
5
|
-
* const fee = new FeeAmount(1.23456789);
|
|
6
|
-
* console.log(fee.value); // 1.23456789
|
|
7
|
-
* console.log(fee.satoshis); // 2
|
|
8
|
-
*/
|
|
9
|
-
export declare class FeeAmount {
|
|
10
|
-
readonly value: number;
|
|
11
|
-
static ZERO: FeeAmount;
|
|
12
|
-
constructor(value: number);
|
|
13
|
-
/** Returns the fee amount rounded up to whole satoshis. */
|
|
14
|
-
get satoshis(): number;
|
|
15
|
-
/** Add two fee amounts together. */
|
|
16
|
-
add(other: FeeAmount): FeeAmount;
|
|
17
|
-
}
|
|
18
|
-
export interface IntentFeeConfig {
|
|
19
|
-
offchainInput?: string;
|
|
20
|
-
onchainInput?: string;
|
|
21
|
-
offchainOutput?: string;
|
|
22
|
-
onchainOutput?: string;
|
|
23
|
-
}
|
|
24
|
-
export type VtxoType = "recoverable" | "vtxo" | "note";
|
|
25
|
-
export interface OffchainInput {
|
|
26
|
-
amount: bigint;
|
|
27
|
-
expiry?: Date;
|
|
28
|
-
birth?: Date;
|
|
29
|
-
type: VtxoType;
|
|
30
|
-
weight: number;
|
|
31
|
-
}
|
|
32
|
-
export interface OnchainInput {
|
|
33
|
-
amount: bigint;
|
|
34
|
-
}
|
|
35
|
-
export interface FeeOutput {
|
|
36
|
-
amount: bigint;
|
|
37
|
-
script: string;
|
|
38
|
-
}
|