@arkade-os/sdk 0.4.27 → 0.4.29
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 +45 -116
- 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-ChhTwpLf.d.cts +3892 -0
- package/dist/ark-ChhTwpLf.d.ts +3892 -0
- package/dist/asyncStorageTaskQueue-DW1-BpI7.d.cts +49 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-DZ0nUuEJ.d.ts} +6 -3
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-6FLL2Q36.cjs +2701 -0
- package/dist/chunk-6FLL2Q36.cjs.map +1 -0
- package/dist/chunk-6NWNOLL3.js +2671 -0
- package/dist/chunk-6NWNOLL3.js.map +1 -0
- package/dist/chunk-ABWRLTX5.js +210 -0
- package/dist/chunk-ABWRLTX5.js.map +1 -0
- package/dist/chunk-BVP2U66Q.js +13943 -0
- package/dist/chunk-BVP2U66Q.js.map +1 -0
- package/dist/chunk-GDCTOSMV.cjs +14058 -0
- package/dist/chunk-GDCTOSMV.cjs.map +1 -0
- package/dist/chunk-GIGILVVP.cjs +213 -0
- package/dist/chunk-GIGILVVP.cjs.map +1 -0
- package/dist/chunk-IEO3XDKI.cjs +838 -0
- package/dist/chunk-IEO3XDKI.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-PJUFOJ2L.cjs +100 -0
- package/dist/chunk-PJUFOJ2L.cjs.map +1 -0
- package/dist/chunk-TH6T23XG.js +95 -0
- package/dist/chunk-TH6T23XG.js.map +1 -0
- package/dist/chunk-TU3LVAPX.js +769 -0
- package/dist/chunk-TU3LVAPX.js.map +1 -0
- package/dist/chunk-WMIPYZSB.cjs +803 -0
- package/dist/chunk-WMIPYZSB.cjs.map +1 -0
- package/dist/chunk-YA4G7RFB.js +829 -0
- package/dist/chunk-YA4G7RFB.js.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-4JBUkUhR.d.cts +84 -0
- package/dist/delegate-DN7RELL1.d.ts +84 -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-Cn82bBUu.d.ts +199 -0
- package/dist/index-DfT5xzgY.d.cts +199 -0
- package/dist/index.cjs +504 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3469 -0
- package/dist/index.d.ts +3469 -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-B-aPfHhK.d.cts +114 -0
- package/dist/taskRunner-B-vG08pX.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 +175 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +124 -0
- package/dist/wallet/expo/index.d.ts +124 -0
- package/dist/wallet/expo/index.js +173 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-CCtqT2Wb.d.ts +778 -0
- package/dist/wallet-DjgFb_4T.d.cts +778 -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 -649
- 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 -20
- package/dist/cjs/identity/index.js +0 -40
- package/dist/cjs/identity/seedIdentity.js +0 -477
- 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 -202
- 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 -308
- 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 -188
- package/dist/cjs/wallet/index.js +0 -82
- package/dist/cjs/wallet/inputSignerRouter.js +0 -98
- 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 -1174
- package/dist/cjs/wallet/signingErrors.js +0 -32
- package/dist/cjs/wallet/unroll.js +0 -293
- 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 -2195
- package/dist/cjs/wallet/walletReceiveRotator.js +0 -547
- 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 -474
- 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 -645
- 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 -17
- package/dist/esm/identity/index.js +0 -13
- package/dist/esm/identity/seedIdentity.js +0 -469
- 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 -303
- 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 -184
- package/dist/esm/wallet/index.js +0 -75
- package/dist/esm/wallet/inputSignerRouter.js +0 -94
- 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 -1169
- package/dist/esm/wallet/signingErrors.js +0 -27
- package/dist/esm/wallet/unroll.js +0 -289
- 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 -2186
- package/dist/esm/wallet/walletReceiveRotator.js +0 -540
- 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 -470
- 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 -411
- 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 -250
- 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 -42
- package/dist/types/identity/hdCapableIdentity.d.ts +0 -71
- package/dist/types/identity/index.d.ts +0 -57
- package/dist/types/identity/seedIdentity.d.ts +0 -270
- 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/expo/wallet.d.ts +0 -99
- package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -114
- package/dist/types/wallet/index.d.ts +0 -789
- package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
- 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 -248
- package/dist/types/wallet/signingErrors.d.ts +0 -19
- 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 -409
- package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
- 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 -189
|
@@ -1,262 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EsploraProvider = exports.ESPLORA_URL = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* The default base URLs for esplora API providers.
|
|
6
|
-
*
|
|
7
|
-
* Mainnet, mutinynet, and signet point at Ark Labs–operated
|
|
8
|
-
* mempool deployments (mempool.space-compatible esplora API).
|
|
9
|
-
* Testnet falls back to the public mempool.space deployment
|
|
10
|
-
* because Ark doesn't host it. Regtest assumes a local nigiri
|
|
11
|
-
* stack on the standard port.
|
|
12
|
-
*/
|
|
13
|
-
exports.ESPLORA_URL = {
|
|
14
|
-
bitcoin: "https://mempool.arkade.sh/api",
|
|
15
|
-
testnet: "https://mempool.space/testnet/api",
|
|
16
|
-
signet: "https://mempool.signet.arkade.sh/api",
|
|
17
|
-
mutinynet: "https://mempool.mutinynet.arkade.sh/api",
|
|
18
|
-
regtest: "http://localhost:3000",
|
|
19
|
-
};
|
|
20
|
-
/**
|
|
21
|
-
* Implementation of the onchain provider interface for esplora REST API.
|
|
22
|
-
*
|
|
23
|
-
* @see https://mempool.space/docs/api/rest
|
|
24
|
-
* @example
|
|
25
|
-
* ```typescript
|
|
26
|
-
* const provider = new EsploraProvider("https://mempool.space/api");
|
|
27
|
-
* const outputs = await provider.getCoins("bcrt1q679zsd45msawvr7782r0twvmukns3drlstjt77");
|
|
28
|
-
* ```
|
|
29
|
-
*/
|
|
30
|
-
class EsploraProvider {
|
|
31
|
-
constructor(baseUrl, opts) {
|
|
32
|
-
this.baseUrl = baseUrl;
|
|
33
|
-
this.pollingInterval = opts?.pollingInterval ?? 15000;
|
|
34
|
-
this.forcePolling = opts?.forcePolling ?? false;
|
|
35
|
-
}
|
|
36
|
-
async getCoins(address) {
|
|
37
|
-
const response = await fetch(`${this.baseUrl}/address/${address}/utxo`);
|
|
38
|
-
if (!response.ok) {
|
|
39
|
-
throw new Error(`Failed to fetch UTXOs: ${response.statusText}`);
|
|
40
|
-
}
|
|
41
|
-
return response.json();
|
|
42
|
-
}
|
|
43
|
-
async getFeeRate() {
|
|
44
|
-
const response = await fetch(`${this.baseUrl}/fee-estimates`);
|
|
45
|
-
if (!response.ok) {
|
|
46
|
-
throw new Error(`Failed to fetch fee rate: ${response.statusText}`);
|
|
47
|
-
}
|
|
48
|
-
const fees = (await response.json());
|
|
49
|
-
return fees["1"] ?? undefined;
|
|
50
|
-
}
|
|
51
|
-
async broadcastTransaction(...txs) {
|
|
52
|
-
switch (txs.length) {
|
|
53
|
-
case 1:
|
|
54
|
-
return this.broadcastTx(txs[0]);
|
|
55
|
-
case 2:
|
|
56
|
-
return this.broadcastPackage(txs[0], txs[1]);
|
|
57
|
-
default:
|
|
58
|
-
throw new Error("Only 1 or 1C1P package can be broadcast");
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
async getTxOutspends(txid) {
|
|
62
|
-
const response = await fetch(`${this.baseUrl}/tx/${txid}/outspends`);
|
|
63
|
-
if (!response.ok) {
|
|
64
|
-
const error = await response.text();
|
|
65
|
-
throw new Error(`Failed to get transaction outspends: ${error}`);
|
|
66
|
-
}
|
|
67
|
-
return response.json();
|
|
68
|
-
}
|
|
69
|
-
async getTransactions(address) {
|
|
70
|
-
const response = await fetch(`${this.baseUrl}/address/${address}/txs`);
|
|
71
|
-
if (!response.ok) {
|
|
72
|
-
const error = await response.text();
|
|
73
|
-
throw new Error(`Failed to get transactions: ${error}`);
|
|
74
|
-
}
|
|
75
|
-
return response.json();
|
|
76
|
-
}
|
|
77
|
-
async getTxStatus(txid) {
|
|
78
|
-
// make sure tx exists in mempool or in block
|
|
79
|
-
const txresponse = await fetch(`${this.baseUrl}/tx/${txid}`);
|
|
80
|
-
if (!txresponse.ok) {
|
|
81
|
-
throw new Error(txresponse.statusText);
|
|
82
|
-
}
|
|
83
|
-
const tx = await txresponse.json();
|
|
84
|
-
if (!tx.status.confirmed) {
|
|
85
|
-
return { confirmed: false };
|
|
86
|
-
}
|
|
87
|
-
const response = await fetch(`${this.baseUrl}/tx/${txid}/status`);
|
|
88
|
-
if (!response.ok) {
|
|
89
|
-
throw new Error(`Failed to get transaction status: ${response.statusText}`);
|
|
90
|
-
}
|
|
91
|
-
const data = await response.json();
|
|
92
|
-
if (!data.confirmed) {
|
|
93
|
-
return { confirmed: false };
|
|
94
|
-
}
|
|
95
|
-
return {
|
|
96
|
-
confirmed: data.confirmed,
|
|
97
|
-
blockTime: data.block_time,
|
|
98
|
-
blockHeight: data.block_height,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
async watchAddresses(addresses, callback) {
|
|
102
|
-
let intervalId = null;
|
|
103
|
-
const wsUrl = this.baseUrl.replace(/^http(s)?:/, "ws$1:") + "/v1/ws";
|
|
104
|
-
const poll = async () => {
|
|
105
|
-
const getAllTxs = async () => {
|
|
106
|
-
const txArrays = await Promise.all(addresses.map((address) => this.getTransactions(address)));
|
|
107
|
-
return txArrays.flat();
|
|
108
|
-
};
|
|
109
|
-
// initial fetch to get existing transactions
|
|
110
|
-
const initialTxs = await getAllTxs();
|
|
111
|
-
// we use block_time in key to also notify when a transaction is confirmed
|
|
112
|
-
const txKey = (tx) => `${tx.txid}_${tx.status.block_time}`;
|
|
113
|
-
// create a set of existing transactions to avoid duplicates
|
|
114
|
-
const existingTxs = new Set(initialTxs.map(txKey));
|
|
115
|
-
// polling for new transactions
|
|
116
|
-
intervalId = setInterval(async () => {
|
|
117
|
-
try {
|
|
118
|
-
// get current transactions
|
|
119
|
-
// we will compare with initialTxs to find new ones
|
|
120
|
-
const currentTxs = await getAllTxs();
|
|
121
|
-
// filter out transactions that are already in initialTxs
|
|
122
|
-
const newTxs = currentTxs.filter((tx) => !existingTxs.has(txKey(tx)));
|
|
123
|
-
if (newTxs.length > 0) {
|
|
124
|
-
// Update the tracking set instead of growing the array
|
|
125
|
-
newTxs.forEach((tx) => existingTxs.add(txKey(tx)));
|
|
126
|
-
callback(newTxs);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
catch (error) {
|
|
130
|
-
console.error("Error in polling mechanism:", error);
|
|
131
|
-
}
|
|
132
|
-
}, this.pollingInterval);
|
|
133
|
-
};
|
|
134
|
-
let ws = null;
|
|
135
|
-
const stopFunc = () => {
|
|
136
|
-
if (ws)
|
|
137
|
-
ws.close();
|
|
138
|
-
if (intervalId)
|
|
139
|
-
clearInterval(intervalId);
|
|
140
|
-
};
|
|
141
|
-
if (this.forcePolling) {
|
|
142
|
-
await poll();
|
|
143
|
-
return stopFunc;
|
|
144
|
-
}
|
|
145
|
-
try {
|
|
146
|
-
ws = new WebSocket(wsUrl);
|
|
147
|
-
ws.addEventListener("open", () => {
|
|
148
|
-
// subscribe to address updates
|
|
149
|
-
const subscribeMsg = {
|
|
150
|
-
"track-addresses": addresses,
|
|
151
|
-
};
|
|
152
|
-
ws.send(JSON.stringify(subscribeMsg));
|
|
153
|
-
});
|
|
154
|
-
ws.addEventListener("message", (event) => {
|
|
155
|
-
try {
|
|
156
|
-
const newTxs = [];
|
|
157
|
-
const message = JSON.parse(event.data.toString());
|
|
158
|
-
if (!message["multi-address-transactions"])
|
|
159
|
-
return;
|
|
160
|
-
const aux = message["multi-address-transactions"];
|
|
161
|
-
for (const address in aux) {
|
|
162
|
-
for (const type of [
|
|
163
|
-
"mempool",
|
|
164
|
-
"confirmed",
|
|
165
|
-
"removed",
|
|
166
|
-
]) {
|
|
167
|
-
if (!aux[address][type])
|
|
168
|
-
continue;
|
|
169
|
-
newTxs.push(...aux[address][type].filter(isExplorerTransaction));
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
// callback with new transactions
|
|
173
|
-
if (newTxs.length > 0)
|
|
174
|
-
callback(newTxs);
|
|
175
|
-
}
|
|
176
|
-
catch (error) {
|
|
177
|
-
console.error("Failed to process WebSocket message:", error);
|
|
178
|
-
}
|
|
179
|
-
});
|
|
180
|
-
ws.addEventListener("error", async () => {
|
|
181
|
-
// if websocket is not available, fallback to polling
|
|
182
|
-
await poll();
|
|
183
|
-
});
|
|
184
|
-
}
|
|
185
|
-
catch {
|
|
186
|
-
if (intervalId)
|
|
187
|
-
clearInterval(intervalId);
|
|
188
|
-
// if websocket is not available, fallback to polling
|
|
189
|
-
await poll();
|
|
190
|
-
}
|
|
191
|
-
return stopFunc;
|
|
192
|
-
}
|
|
193
|
-
async getChainTip() {
|
|
194
|
-
const tipBlocks = await fetch(`${this.baseUrl}/blocks/tip`);
|
|
195
|
-
if (!tipBlocks.ok) {
|
|
196
|
-
throw new Error(`Failed to get chain tip: ${tipBlocks.statusText}`);
|
|
197
|
-
}
|
|
198
|
-
const tip = await tipBlocks.json();
|
|
199
|
-
if (!isValidBlocksTip(tip)) {
|
|
200
|
-
throw new Error(`Invalid chain tip: ${JSON.stringify(tip)}`);
|
|
201
|
-
}
|
|
202
|
-
if (tip.length === 0) {
|
|
203
|
-
throw new Error("No chain tip found");
|
|
204
|
-
}
|
|
205
|
-
const hash = tip[0].id;
|
|
206
|
-
return {
|
|
207
|
-
height: tip[0].height,
|
|
208
|
-
time: tip[0].mediantime,
|
|
209
|
-
hash,
|
|
210
|
-
};
|
|
211
|
-
}
|
|
212
|
-
async broadcastPackage(parent, child) {
|
|
213
|
-
const response = await fetch(`${this.baseUrl}/txs/package`, {
|
|
214
|
-
method: "POST",
|
|
215
|
-
headers: {
|
|
216
|
-
"Content-Type": "application/json",
|
|
217
|
-
},
|
|
218
|
-
body: JSON.stringify([parent, child]),
|
|
219
|
-
});
|
|
220
|
-
if (!response.ok) {
|
|
221
|
-
const error = await response.text();
|
|
222
|
-
throw new Error(`Failed to broadcast package: ${error}`);
|
|
223
|
-
}
|
|
224
|
-
return response.json();
|
|
225
|
-
}
|
|
226
|
-
async broadcastTx(tx) {
|
|
227
|
-
const response = await fetch(`${this.baseUrl}/tx`, {
|
|
228
|
-
method: "POST",
|
|
229
|
-
headers: {
|
|
230
|
-
"Content-Type": "text/plain",
|
|
231
|
-
},
|
|
232
|
-
body: tx,
|
|
233
|
-
});
|
|
234
|
-
if (!response.ok) {
|
|
235
|
-
const error = await response.text();
|
|
236
|
-
throw new Error(`Failed to broadcast transaction: ${error}`);
|
|
237
|
-
}
|
|
238
|
-
return response.text();
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
exports.EsploraProvider = EsploraProvider;
|
|
242
|
-
function isValidBlocksTip(tip) {
|
|
243
|
-
return (Array.isArray(tip) &&
|
|
244
|
-
tip.every((t) => {
|
|
245
|
-
return (t &&
|
|
246
|
-
typeof t === "object" &&
|
|
247
|
-
typeof t.id === "string" &&
|
|
248
|
-
t.id.length > 0 &&
|
|
249
|
-
typeof t.height === "number" &&
|
|
250
|
-
t.height >= 0 &&
|
|
251
|
-
typeof t.mediantime === "number" &&
|
|
252
|
-
t.mediantime > 0);
|
|
253
|
-
}));
|
|
254
|
-
}
|
|
255
|
-
const isExplorerTransaction = (tx) => {
|
|
256
|
-
return (typeof tx.txid === "string" &&
|
|
257
|
-
Array.isArray(tx.vout) &&
|
|
258
|
-
tx.vout.every((vout) => typeof vout.scriptpubkey_address === "string" &&
|
|
259
|
-
typeof vout.value === "number") &&
|
|
260
|
-
typeof tx.status === "object" &&
|
|
261
|
-
typeof tx.status.confirmed === "boolean");
|
|
262
|
-
};
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.eventSourceIterator = eventSourceIterator;
|
|
4
|
-
exports.isEventSourceError = isEventSourceError;
|
|
5
|
-
function createAbortError() {
|
|
6
|
-
const error = new Error("EventSource closed");
|
|
7
|
-
error.name = "AbortError";
|
|
8
|
-
return error;
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Creates a close-aware EventSource async iterator.
|
|
12
|
-
*
|
|
13
|
-
* Listeners attach eagerly so events are buffered before the first next() call.
|
|
14
|
-
* close() closes the EventSource, removes listeners, and wakes any pending
|
|
15
|
-
* next() even when the browser does not emit an error from EventSource.close().
|
|
16
|
-
*/
|
|
17
|
-
function eventSourceIterator(eventSource) {
|
|
18
|
-
const messageQueue = [];
|
|
19
|
-
const errorQueue = [];
|
|
20
|
-
let messageResolve = null;
|
|
21
|
-
let errorResolve = null;
|
|
22
|
-
let closed = false;
|
|
23
|
-
let cleanedUp = false;
|
|
24
|
-
const cleanup = () => {
|
|
25
|
-
if (cleanedUp)
|
|
26
|
-
return;
|
|
27
|
-
cleanedUp = true;
|
|
28
|
-
eventSource.removeEventListener("message", messageHandler);
|
|
29
|
-
eventSource.removeEventListener("error", errorHandler);
|
|
30
|
-
};
|
|
31
|
-
const close = () => {
|
|
32
|
-
if (closed)
|
|
33
|
-
return;
|
|
34
|
-
closed = true;
|
|
35
|
-
messageQueue.length = 0;
|
|
36
|
-
errorQueue.length = 0;
|
|
37
|
-
eventSource.close();
|
|
38
|
-
cleanup();
|
|
39
|
-
if (errorResolve) {
|
|
40
|
-
const reject = errorResolve;
|
|
41
|
-
messageResolve = null;
|
|
42
|
-
errorResolve = null;
|
|
43
|
-
reject(createAbortError());
|
|
44
|
-
}
|
|
45
|
-
};
|
|
46
|
-
const messageHandler = (event) => {
|
|
47
|
-
if (closed)
|
|
48
|
-
return;
|
|
49
|
-
if (messageResolve) {
|
|
50
|
-
const resolve = messageResolve;
|
|
51
|
-
messageResolve = null;
|
|
52
|
-
errorResolve = null;
|
|
53
|
-
resolve(event);
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
messageQueue.push(event);
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
const errorHandler = () => {
|
|
60
|
-
if (closed)
|
|
61
|
-
return;
|
|
62
|
-
const error = new Error("EventSource error");
|
|
63
|
-
error.name = "EventSourceError";
|
|
64
|
-
if (errorResolve) {
|
|
65
|
-
const reject = errorResolve;
|
|
66
|
-
messageResolve = null;
|
|
67
|
-
errorResolve = null;
|
|
68
|
-
reject(error);
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
errorQueue.push(error);
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
// Attach listeners immediately so events are buffered
|
|
75
|
-
// even before the caller starts iterating
|
|
76
|
-
eventSource.addEventListener("message", messageHandler);
|
|
77
|
-
eventSource.addEventListener("error", errorHandler);
|
|
78
|
-
const gen = (async function* () {
|
|
79
|
-
try {
|
|
80
|
-
while (!closed) {
|
|
81
|
-
// if we have queued messages, yield the first one, remove it from the queue
|
|
82
|
-
if (messageQueue.length > 0) {
|
|
83
|
-
yield messageQueue.shift();
|
|
84
|
-
continue;
|
|
85
|
-
}
|
|
86
|
-
// if we have queued errors, throw the first one, remove it from the queue
|
|
87
|
-
if (errorQueue.length > 0) {
|
|
88
|
-
const error = errorQueue.shift();
|
|
89
|
-
throw error;
|
|
90
|
-
}
|
|
91
|
-
// wait for the next message or error
|
|
92
|
-
const result = await new Promise((resolve, reject) => {
|
|
93
|
-
messageResolve = resolve;
|
|
94
|
-
errorResolve = reject;
|
|
95
|
-
}).finally(() => {
|
|
96
|
-
messageResolve = null;
|
|
97
|
-
errorResolve = null;
|
|
98
|
-
});
|
|
99
|
-
if (!closed && result) {
|
|
100
|
-
yield result;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
finally {
|
|
105
|
-
closed = true;
|
|
106
|
-
cleanup();
|
|
107
|
-
eventSource.close();
|
|
108
|
-
}
|
|
109
|
-
})();
|
|
110
|
-
const origReturn = gen.return.bind(gen);
|
|
111
|
-
const managed = gen;
|
|
112
|
-
managed.close = close;
|
|
113
|
-
managed.return = (value) => {
|
|
114
|
-
close();
|
|
115
|
-
return origReturn(value);
|
|
116
|
-
};
|
|
117
|
-
return managed;
|
|
118
|
-
}
|
|
119
|
-
function isEventSourceError(error) {
|
|
120
|
-
return error instanceof Error && error.name === "EventSourceError";
|
|
121
|
-
}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.InMemoryContractRepository = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* In-memory implementation of ContractRepository.
|
|
6
|
-
* Data is ephemeral and scoped to the instance.
|
|
7
|
-
*/
|
|
8
|
-
class InMemoryContractRepository {
|
|
9
|
-
constructor() {
|
|
10
|
-
this.version = 1;
|
|
11
|
-
this.contractData = new Map();
|
|
12
|
-
this.collections = new Map();
|
|
13
|
-
this.contractsByScript = new Map();
|
|
14
|
-
}
|
|
15
|
-
async clear() {
|
|
16
|
-
this.contractData.clear();
|
|
17
|
-
this.collections.clear();
|
|
18
|
-
this.contractsByScript.clear();
|
|
19
|
-
}
|
|
20
|
-
// Contract entity management methods
|
|
21
|
-
async getContracts(filter) {
|
|
22
|
-
const contracts = this.contractsByScript.values();
|
|
23
|
-
if (!filter) {
|
|
24
|
-
return [...contracts];
|
|
25
|
-
}
|
|
26
|
-
const matches = (value, criterion) => {
|
|
27
|
-
if (criterion === undefined) {
|
|
28
|
-
return true;
|
|
29
|
-
}
|
|
30
|
-
return Array.isArray(criterion)
|
|
31
|
-
? criterion.includes(value)
|
|
32
|
-
: value === criterion;
|
|
33
|
-
};
|
|
34
|
-
const results = [];
|
|
35
|
-
for (const contract of contracts) {
|
|
36
|
-
if (matches(contract.script, filter.script) &&
|
|
37
|
-
matches(contract.state, filter.state) &&
|
|
38
|
-
matches(contract.type, filter.type)) {
|
|
39
|
-
results.push(contract);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
return results;
|
|
43
|
-
}
|
|
44
|
-
async saveContract(contract) {
|
|
45
|
-
this.contractsByScript.set(contract.script, contract);
|
|
46
|
-
}
|
|
47
|
-
async deleteContract(script) {
|
|
48
|
-
this.contractsByScript.delete(script);
|
|
49
|
-
}
|
|
50
|
-
async [Symbol.asyncDispose]() {
|
|
51
|
-
// nothing to dispose, data is ephemeral and scoped to the instance
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
exports.InMemoryContractRepository = InMemoryContractRepository;
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.InMemoryWalletRepository = void 0;
|
|
4
|
-
const vtxoOwnership_1 = require("../../contracts/vtxoOwnership");
|
|
5
|
-
/**
|
|
6
|
-
* In-memory implementation of WalletRepository.
|
|
7
|
-
* Data is ephemeral and scoped to the instance.
|
|
8
|
-
*/
|
|
9
|
-
class InMemoryWalletRepository {
|
|
10
|
-
constructor() {
|
|
11
|
-
this.version = 1;
|
|
12
|
-
this.vtxosByAddress = new Map();
|
|
13
|
-
this.utxosByAddress = new Map();
|
|
14
|
-
this.txsByAddress = new Map();
|
|
15
|
-
this.walletState = null;
|
|
16
|
-
}
|
|
17
|
-
async getVtxos(address) {
|
|
18
|
-
return this.vtxosByAddress.get(address) ?? [];
|
|
19
|
-
}
|
|
20
|
-
async saveVtxos(address, vtxos) {
|
|
21
|
-
const existing = this.vtxosByAddress.get(address) ?? [];
|
|
22
|
-
const next = mergeByKey(existing, vtxos, (item) => `${item.txid}:${item.vout}`);
|
|
23
|
-
this.vtxosByAddress.set(address, next);
|
|
24
|
-
}
|
|
25
|
-
async deleteVtxos(address) {
|
|
26
|
-
this.vtxosByAddress.delete(address);
|
|
27
|
-
}
|
|
28
|
-
async getVtxosForScript(script) {
|
|
29
|
-
const allMatches = [];
|
|
30
|
-
for (const bucket of this.vtxosByAddress.values()) {
|
|
31
|
-
for (const vtxo of bucket) {
|
|
32
|
-
if ((0, vtxoOwnership_1.isVtxoForScript)(vtxo, script)) {
|
|
33
|
-
allMatches.push(vtxo);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
// Dedup by outpoint (last-write-wins across address buckets)
|
|
38
|
-
return mergeByKey([], allMatches, (item) => `${item.txid}:${item.vout}`);
|
|
39
|
-
}
|
|
40
|
-
async saveVtxosForScript(key, vtxos) {
|
|
41
|
-
if (!key.address) {
|
|
42
|
-
throw new Error("InMemoryWalletRepository requires an address");
|
|
43
|
-
}
|
|
44
|
-
for (const vtxo of vtxos) {
|
|
45
|
-
if (!(0, vtxoOwnership_1.isVtxoForScript)(vtxo, key.script)) {
|
|
46
|
-
throw new Error(`VTXO ${vtxo.txid}:${vtxo.vout} script mismatch: expected ${key.script}, got ${vtxo.script}`);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return this.saveVtxos(key.address, vtxos);
|
|
50
|
-
}
|
|
51
|
-
async deleteVtxosForScript(script) {
|
|
52
|
-
for (const [address, bucket] of this.vtxosByAddress.entries()) {
|
|
53
|
-
const next = bucket.filter((v) => !(0, vtxoOwnership_1.isVtxoForScript)(v, script));
|
|
54
|
-
if (next.length === 0) {
|
|
55
|
-
this.vtxosByAddress.delete(address);
|
|
56
|
-
}
|
|
57
|
-
else {
|
|
58
|
-
this.vtxosByAddress.set(address, next);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
async getUtxos(address) {
|
|
63
|
-
return this.utxosByAddress.get(address) ?? [];
|
|
64
|
-
}
|
|
65
|
-
async saveUtxos(address, utxos) {
|
|
66
|
-
const existing = this.utxosByAddress.get(address) ?? [];
|
|
67
|
-
const next = mergeByKey(existing, utxos, (item) => `${item.txid}:${item.vout}`);
|
|
68
|
-
this.utxosByAddress.set(address, next);
|
|
69
|
-
}
|
|
70
|
-
async deleteUtxos(address) {
|
|
71
|
-
this.utxosByAddress.delete(address);
|
|
72
|
-
}
|
|
73
|
-
async getTransactionHistory(address) {
|
|
74
|
-
return this.txsByAddress.get(address) ?? [];
|
|
75
|
-
}
|
|
76
|
-
async saveTransactions(address, txs) {
|
|
77
|
-
const existing = this.txsByAddress.get(address) ?? [];
|
|
78
|
-
const next = mergeByKey(existing, txs, serializeTxKey);
|
|
79
|
-
this.txsByAddress.set(address, next);
|
|
80
|
-
}
|
|
81
|
-
async deleteTransactions(address) {
|
|
82
|
-
this.txsByAddress.delete(address);
|
|
83
|
-
}
|
|
84
|
-
async getWalletState() {
|
|
85
|
-
return this.walletState;
|
|
86
|
-
}
|
|
87
|
-
async saveWalletState(state) {
|
|
88
|
-
this.walletState = state;
|
|
89
|
-
}
|
|
90
|
-
async clear() {
|
|
91
|
-
this.vtxosByAddress.clear();
|
|
92
|
-
this.utxosByAddress.clear();
|
|
93
|
-
this.txsByAddress.clear();
|
|
94
|
-
this.walletState = null;
|
|
95
|
-
}
|
|
96
|
-
async [Symbol.asyncDispose]() {
|
|
97
|
-
// nothing to dispose, data is ephemeral and scoped to the instance
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
exports.InMemoryWalletRepository = InMemoryWalletRepository;
|
|
102
|
-
function serializeTxKey(tx) {
|
|
103
|
-
const key = tx.key;
|
|
104
|
-
return `${key.boardingTxid}:${key.commitmentTxid}:${key.arkTxid}`;
|
|
105
|
-
}
|
|
106
|
-
function mergeByKey(existing, incoming, toKey) {
|
|
107
|
-
const next = new Map();
|
|
108
|
-
existing.forEach((item) => {
|
|
109
|
-
next.set(toKey(item), item);
|
|
110
|
-
});
|
|
111
|
-
incoming.forEach((item) => {
|
|
112
|
-
next.set(toKey(item), item);
|
|
113
|
-
});
|
|
114
|
-
return Array.from(next.values());
|
|
115
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.ContractRepositoryImpl = exports.WalletRepositoryImpl = exports.rollbackMigration = exports.getMigrationStatus = exports.requiresMigration = exports.migrateWalletRepository = exports.MIGRATION_KEY = void 0;
|
|
18
|
-
__exportStar(require("./walletRepository"), exports);
|
|
19
|
-
__exportStar(require("./contractRepository"), exports);
|
|
20
|
-
__exportStar(require("./inMemory/walletRepository"), exports);
|
|
21
|
-
__exportStar(require("./inMemory/contractRepository"), exports);
|
|
22
|
-
__exportStar(require("./indexedDB/contractRepository"), exports);
|
|
23
|
-
__exportStar(require("./indexedDB/walletRepository"), exports);
|
|
24
|
-
var fromStorageAdapter_1 = require("./migrations/fromStorageAdapter");
|
|
25
|
-
Object.defineProperty(exports, "MIGRATION_KEY", { enumerable: true, get: function () { return fromStorageAdapter_1.MIGRATION_KEY; } });
|
|
26
|
-
Object.defineProperty(exports, "migrateWalletRepository", { enumerable: true, get: function () { return fromStorageAdapter_1.migrateWalletRepository; } });
|
|
27
|
-
Object.defineProperty(exports, "requiresMigration", { enumerable: true, get: function () { return fromStorageAdapter_1.requiresMigration; } });
|
|
28
|
-
Object.defineProperty(exports, "getMigrationStatus", { enumerable: true, get: function () { return fromStorageAdapter_1.getMigrationStatus; } });
|
|
29
|
-
Object.defineProperty(exports, "rollbackMigration", { enumerable: true, get: function () { return fromStorageAdapter_1.rollbackMigration; } });
|
|
30
|
-
// Deprecated
|
|
31
|
-
var walletRepositoryImpl_1 = require("./migrations/walletRepositoryImpl");
|
|
32
|
-
Object.defineProperty(exports, "WalletRepositoryImpl", { enumerable: true, get: function () { return walletRepositoryImpl_1.WalletRepositoryImpl; } });
|
|
33
|
-
var contractRepositoryImpl_1 = require("./migrations/contractRepositoryImpl");
|
|
34
|
-
Object.defineProperty(exports, "ContractRepositoryImpl", { enumerable: true, get: function () { return contractRepositoryImpl_1.ContractRepositoryImpl; } });
|