@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,308 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DelegatorManagerImpl = void 0;
|
|
4
|
-
exports.findDestinationOutputIndex = findDestinationOutputIndex;
|
|
5
|
-
const __1 = require("..");
|
|
6
|
-
const base_1 = require("@scure/base");
|
|
7
|
-
const base_2 = require("../script/base");
|
|
8
|
-
const forfeit_1 = require("../forfeit");
|
|
9
|
-
const btc_signer_1 = require("@scure/btc-signer");
|
|
10
|
-
const utils_js_1 = require("@scure/btc-signer/utils.js");
|
|
11
|
-
const networks_1 = require("../networks");
|
|
12
|
-
const asset_1 = require("./asset");
|
|
13
|
-
const extension_1 = require("../extension");
|
|
14
|
-
class DelegatorManagerImpl {
|
|
15
|
-
/** Create a delegator manager from the configured provider, Arkade info source, and wallet identity. */
|
|
16
|
-
constructor(delegatorProvider, arkInfoProvider, identity) {
|
|
17
|
-
this.delegatorProvider = delegatorProvider;
|
|
18
|
-
this.arkInfoProvider = arkInfoProvider;
|
|
19
|
-
this.identity = identity;
|
|
20
|
-
}
|
|
21
|
-
async getDelegateInfo() {
|
|
22
|
-
return this.delegatorProvider.getDelegateInfo();
|
|
23
|
-
}
|
|
24
|
-
async delegate(vtxos, destination, delegateAt) {
|
|
25
|
-
if (vtxos.length === 0) {
|
|
26
|
-
return { delegated: [], failed: [] };
|
|
27
|
-
}
|
|
28
|
-
const destinationScript = __1.ArkAddress.decode(destination).pkScript;
|
|
29
|
-
// fetch server and delegator info once, shared across all groups
|
|
30
|
-
const arkInfo = await this.arkInfoProvider.getInfo();
|
|
31
|
-
const delegateInfo = await this.delegatorProvider.getDelegateInfo();
|
|
32
|
-
// keep only vtxos that can be signed by the delegate. The guard
|
|
33
|
-
// narrows ContractVtxo (with optional taproot fields) to the
|
|
34
|
-
// ExtendedVirtualCoin shape required by makeDelegateForfeitTx.
|
|
35
|
-
const eligible = vtxos.filter((v) => isAnnotated(v) &&
|
|
36
|
-
findDelegateTapLeaf(v, delegateInfo.pubkey) !== undefined);
|
|
37
|
-
if (eligible.length === 0) {
|
|
38
|
-
return { delegated: [], failed: [] };
|
|
39
|
-
}
|
|
40
|
-
// if explicit delegateAt is provided, delegate all virtual outputs at once without sorting
|
|
41
|
-
if (delegateAt) {
|
|
42
|
-
try {
|
|
43
|
-
await delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, eligible, destinationScript, delegateAt);
|
|
44
|
-
}
|
|
45
|
-
catch (error) {
|
|
46
|
-
return {
|
|
47
|
-
delegated: [],
|
|
48
|
-
failed: [{ outpoints: eligible, error }],
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
return { delegated: eligible, failed: [] };
|
|
52
|
-
}
|
|
53
|
-
// if no explicit delegateAt is provided, sort virtual outputs by expiry and delegate in groups of the same expiry day
|
|
54
|
-
const groupByExpiry = new Map();
|
|
55
|
-
let recoverableVtxos = [];
|
|
56
|
-
for (const vtxo of eligible) {
|
|
57
|
-
if ((0, __1.isRecoverable)(vtxo)) {
|
|
58
|
-
recoverableVtxos.push(vtxo);
|
|
59
|
-
continue;
|
|
60
|
-
}
|
|
61
|
-
const expiry = vtxo.virtualStatus.batchExpiry;
|
|
62
|
-
if (!expiry)
|
|
63
|
-
continue;
|
|
64
|
-
const dayKey = getDayTimestamp(expiry);
|
|
65
|
-
groupByExpiry.set(dayKey, [
|
|
66
|
-
...(groupByExpiry.get(dayKey) ?? []),
|
|
67
|
-
vtxo,
|
|
68
|
-
]);
|
|
69
|
-
}
|
|
70
|
-
// if no groups, it means we only need to delegate the recoverable virtual outputs
|
|
71
|
-
if (groupByExpiry.size === 0) {
|
|
72
|
-
try {
|
|
73
|
-
await delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, recoverableVtxos, destinationScript, delegateAt);
|
|
74
|
-
}
|
|
75
|
-
catch (error) {
|
|
76
|
-
return {
|
|
77
|
-
delegated: [],
|
|
78
|
-
failed: [{ outpoints: recoverableVtxos, error }],
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
return { delegated: recoverableVtxos, failed: [] };
|
|
82
|
-
}
|
|
83
|
-
// search for the earliest group, include recoverable virtual outputs into it
|
|
84
|
-
const earliestGroup = Math.min(...groupByExpiry.keys());
|
|
85
|
-
groupByExpiry.set(earliestGroup, [
|
|
86
|
-
...(groupByExpiry.get(earliestGroup) ?? []),
|
|
87
|
-
...recoverableVtxos,
|
|
88
|
-
]);
|
|
89
|
-
const groupsList = Array.from(groupByExpiry.entries());
|
|
90
|
-
const result = await Promise.allSettled(groupsList.map(async ([, vtxosGroup]) => delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, vtxosGroup, destinationScript)));
|
|
91
|
-
const delegated = [];
|
|
92
|
-
const failed = [];
|
|
93
|
-
for (const [index, resultItem] of result.entries()) {
|
|
94
|
-
const vtxos = groupsList[index][1];
|
|
95
|
-
if (resultItem.status === "rejected") {
|
|
96
|
-
failed.push({ outpoints: vtxos, error: resultItem.reason });
|
|
97
|
-
continue;
|
|
98
|
-
}
|
|
99
|
-
delegated.push(...vtxos);
|
|
100
|
-
}
|
|
101
|
-
return { delegated, failed };
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
exports.DelegatorManagerImpl = DelegatorManagerImpl;
|
|
105
|
-
/**
|
|
106
|
-
* Delegates virtual outputs to a delegation service, allowing them to manage their renewal
|
|
107
|
-
* on behalf of the wallet owner.
|
|
108
|
-
* @param vtxos - Array of extended virtual outputs to delegate. Must not be empty.
|
|
109
|
-
* @param delegateAt - Optional Date specifying when the delegation
|
|
110
|
-
* should occur. If not provided, defaults to 12 hours before the earliest
|
|
111
|
-
* expiry time of the provided vtxos.
|
|
112
|
-
*/
|
|
113
|
-
async function delegate(identity, delegatorProvider, arkInfo, delegateInfo, vtxos, destinationScript, delegateAt) {
|
|
114
|
-
if (vtxos.length === 0) {
|
|
115
|
-
throw new Error("unable to delegate: no vtxos provided");
|
|
116
|
-
}
|
|
117
|
-
if (!delegatorProvider) {
|
|
118
|
-
throw new Error("unable to delegate: delegator provider not configured");
|
|
119
|
-
}
|
|
120
|
-
if (!delegateAt) {
|
|
121
|
-
const expiryTimestamp = vtxos
|
|
122
|
-
.filter((coin) => !(0, __1.isRecoverable)(coin) && coin.virtualStatus.batchExpiry)
|
|
123
|
-
.reduce((min, coin) => Math.min(min, coin.virtualStatus.batchExpiry), Number.MAX_SAFE_INTEGER);
|
|
124
|
-
if (!expiryTimestamp || expiryTimestamp === Number.MAX_SAFE_INTEGER) {
|
|
125
|
-
// if no expiry (recoverable virtual outputs), delegate 1 minute from now
|
|
126
|
-
delegateAt = new Date(Date.now() + 1 * 60 * 1000);
|
|
127
|
-
}
|
|
128
|
-
else {
|
|
129
|
-
const remainingTimeMs = expiryTimestamp - Date.now();
|
|
130
|
-
if (remainingTimeMs <= 0) {
|
|
131
|
-
delegateAt = new Date(Date.now() + 1 * 60 * 1000);
|
|
132
|
-
}
|
|
133
|
-
else {
|
|
134
|
-
// delegate 10% before the expiry
|
|
135
|
-
delegateAt = new Date(expiryTimestamp - remainingTimeMs * 0.1);
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
const { fees, dust, forfeitAddress, network } = arkInfo;
|
|
140
|
-
const delegateAtSeconds = delegateAt.getTime() / 1000;
|
|
141
|
-
const estimator = new __1.Estimator({
|
|
142
|
-
...fees.intentFee,
|
|
143
|
-
// replace now() function with the delegateAt timestamp
|
|
144
|
-
offchainInput: fees.intentFee.offchainInput?.replace("now()", `double(${delegateAtSeconds})`),
|
|
145
|
-
offchainOutput: fees.intentFee.offchainOutput?.replace("now()", `double(${delegateAtSeconds})`),
|
|
146
|
-
});
|
|
147
|
-
let amount = 0n;
|
|
148
|
-
for (const coin of vtxos) {
|
|
149
|
-
const inputFee = estimator.evalOffchainInput({
|
|
150
|
-
amount: BigInt(coin.value),
|
|
151
|
-
type: "vtxo",
|
|
152
|
-
weight: 0,
|
|
153
|
-
birth: coin.createdAt,
|
|
154
|
-
expiry: coin.virtualStatus.batchExpiry
|
|
155
|
-
? new Date(coin.virtualStatus.batchExpiry)
|
|
156
|
-
: undefined,
|
|
157
|
-
});
|
|
158
|
-
if (inputFee.value >= coin.value) {
|
|
159
|
-
continue;
|
|
160
|
-
}
|
|
161
|
-
amount += BigInt(coin.value) - BigInt(inputFee.value);
|
|
162
|
-
}
|
|
163
|
-
const { delegatorAddress, pubkey, fee } = delegateInfo;
|
|
164
|
-
const outputs = [];
|
|
165
|
-
const delegatorFee = BigInt(Number(fee));
|
|
166
|
-
if (delegatorFee > 0n) {
|
|
167
|
-
outputs.push({
|
|
168
|
-
script: __1.ArkAddress.decode(delegatorAddress).pkScript,
|
|
169
|
-
amount: delegatorFee,
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
const outputFee = outputs.reduce((fee, output) => {
|
|
173
|
-
if (!output.amount || !output.script)
|
|
174
|
-
return fee;
|
|
175
|
-
return (fee +
|
|
176
|
-
estimator.evalOffchainOutput({
|
|
177
|
-
amount: output.amount,
|
|
178
|
-
script: base_1.hex.encode(output.script),
|
|
179
|
-
}).satoshis);
|
|
180
|
-
}, 0);
|
|
181
|
-
if (amount - BigInt(outputFee) <= dust) {
|
|
182
|
-
throw new Error("Amount is below dust limit, cannot delegate");
|
|
183
|
-
}
|
|
184
|
-
amount -= BigInt(outputFee);
|
|
185
|
-
amount -= delegatorFee;
|
|
186
|
-
if (amount <= dust) {
|
|
187
|
-
throw new Error("Amount is below dust limit, cannot delegate");
|
|
188
|
-
}
|
|
189
|
-
outputs.push({
|
|
190
|
-
script: destinationScript,
|
|
191
|
-
amount: amount,
|
|
192
|
-
});
|
|
193
|
-
const registerIntent = await makeSignedDelegateIntent(identity, vtxos, outputs, [], [pubkey], delegateAtSeconds, destinationScript);
|
|
194
|
-
const forfeitOutputScript = btc_signer_1.OutScript.encode((0, btc_signer_1.Address)((0, networks_1.getNetwork)(network)).decode(forfeitAddress));
|
|
195
|
-
const forfeits = await Promise.all(vtxos
|
|
196
|
-
.filter((v) => !(0, __1.isRecoverable)(v))
|
|
197
|
-
.map(async (coin) => {
|
|
198
|
-
const forfeit = await makeDelegateForfeitTx(coin, dust, pubkey, forfeitOutputScript, identity);
|
|
199
|
-
return base_1.base64.encode(forfeit.toPSBT());
|
|
200
|
-
}));
|
|
201
|
-
await delegatorProvider.delegate(registerIntent, forfeits);
|
|
202
|
-
}
|
|
203
|
-
async function makeDelegateForfeitTx(input, connectorAmount, delegatePubkey, forfeitOutputScript, identity) {
|
|
204
|
-
const delegateTapLeaf = findDelegateTapLeaf(input, delegatePubkey);
|
|
205
|
-
if (!delegateTapLeaf) {
|
|
206
|
-
throw new Error(`delegate tap leaf not found for input: ${input.txid}:${input.vout}`);
|
|
207
|
-
}
|
|
208
|
-
const tx = (0, forfeit_1.buildForfeitTxWithOutput)([
|
|
209
|
-
{
|
|
210
|
-
txid: input.txid,
|
|
211
|
-
index: input.vout,
|
|
212
|
-
witnessUtxo: {
|
|
213
|
-
amount: BigInt(input.value),
|
|
214
|
-
script: __1.VtxoScript.decode(input.tapTree).pkScript,
|
|
215
|
-
},
|
|
216
|
-
sighashType: btc_signer_1.SigHash.ALL_ANYONECANPAY,
|
|
217
|
-
tapLeafScript: [delegateTapLeaf],
|
|
218
|
-
},
|
|
219
|
-
], {
|
|
220
|
-
script: forfeitOutputScript,
|
|
221
|
-
amount: BigInt(input.value) + connectorAmount,
|
|
222
|
-
});
|
|
223
|
-
return identity.sign(tx);
|
|
224
|
-
}
|
|
225
|
-
async function makeSignedDelegateIntent(identity, coins, outputs, onchainOutputsIndexes, cosignerPubKeys, validAt, destinationScript) {
|
|
226
|
-
// if some of the inputs hold assets, build the asset packet and append as output
|
|
227
|
-
// in the intent proof tx, there is a "fake" input at index 0
|
|
228
|
-
// so the real coin indices are offset by +1
|
|
229
|
-
const assetInputs = new Map();
|
|
230
|
-
for (let i = 0; i < coins.length; i++) {
|
|
231
|
-
if ("assets" in coins[i]) {
|
|
232
|
-
const assets = coins[i].assets;
|
|
233
|
-
if (assets && assets.length > 0) {
|
|
234
|
-
assetInputs.set(i + 1, assets);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
let outputAssets;
|
|
239
|
-
const assetOutputIndex = findDestinationOutputIndex(outputs, destinationScript);
|
|
240
|
-
if (assetInputs.size > 0) {
|
|
241
|
-
if (assetOutputIndex === -1) {
|
|
242
|
-
throw new Error("Cannot assign assets: no output matches the destination address");
|
|
243
|
-
}
|
|
244
|
-
// collect all input assets and assign them to the first offchain output
|
|
245
|
-
const allAssets = new Map();
|
|
246
|
-
for (const [, assets] of assetInputs) {
|
|
247
|
-
for (const asset of assets) {
|
|
248
|
-
const existing = allAssets.get(asset.assetId) ?? 0n;
|
|
249
|
-
allAssets.set(asset.assetId, existing + asset.amount);
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
outputAssets = [];
|
|
253
|
-
for (const [assetId, amount] of allAssets) {
|
|
254
|
-
outputAssets.push({ assetId, amount });
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
const recipients = outputs.map((output, i) => ({
|
|
258
|
-
address: "", // not needed for asset packet creation
|
|
259
|
-
amount: Number(output.amount),
|
|
260
|
-
assets: i === assetOutputIndex ? outputAssets : undefined,
|
|
261
|
-
}));
|
|
262
|
-
if (outputAssets && outputAssets.length > 0) {
|
|
263
|
-
const assetPacket = (0, asset_1.createAssetPacket)(assetInputs, recipients);
|
|
264
|
-
outputs.push(extension_1.Extension.create([assetPacket]).txOut());
|
|
265
|
-
}
|
|
266
|
-
const message = {
|
|
267
|
-
type: "register",
|
|
268
|
-
onchain_output_indexes: onchainOutputsIndexes,
|
|
269
|
-
valid_at: Math.floor(validAt),
|
|
270
|
-
expire_at: 0,
|
|
271
|
-
cosigners_public_keys: cosignerPubKeys,
|
|
272
|
-
};
|
|
273
|
-
const proof = __1.Intent.create(message, coins, outputs);
|
|
274
|
-
const signedProof = await identity.sign(proof);
|
|
275
|
-
return {
|
|
276
|
-
proof: base_1.base64.encode(signedProof.toPSBT()),
|
|
277
|
-
message,
|
|
278
|
-
};
|
|
279
|
-
}
|
|
280
|
-
/**
|
|
281
|
-
* Finds the index of the output whose script matches the destination script.
|
|
282
|
-
* Returns -1 if no match is found.
|
|
283
|
-
*/
|
|
284
|
-
function findDestinationOutputIndex(outputs, destinationScript) {
|
|
285
|
-
return outputs.findIndex((o) => o.script && (0, utils_js_1.equalBytes)(o.script, destinationScript));
|
|
286
|
-
}
|
|
287
|
-
function getDayTimestamp(timestamp) {
|
|
288
|
-
const date = new Date(timestamp);
|
|
289
|
-
date.setUTCHours(0, 0, 0, 0);
|
|
290
|
-
return date.getTime();
|
|
291
|
-
}
|
|
292
|
-
function findDelegateTapLeaf(vtxo, delegatePubkey) {
|
|
293
|
-
if (!vtxo.tapTree)
|
|
294
|
-
return undefined;
|
|
295
|
-
const pk = delegatePubkey.length === 66 ? delegatePubkey.slice(2) : delegatePubkey;
|
|
296
|
-
const vtxoScript = __1.VtxoScript.decode(vtxo.tapTree);
|
|
297
|
-
return vtxoScript.leaves.find((tapLeaf) => {
|
|
298
|
-
const arkTapscript = (0, __1.decodeTapscript)((0, base_2.scriptFromTapLeafScript)(tapLeaf));
|
|
299
|
-
if (!__1.MultisigTapscript.is(arkTapscript))
|
|
300
|
-
return false;
|
|
301
|
-
return arkTapscript.params.pubkeys.map(base_1.hex.encode).includes(pk);
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
function isAnnotated(v) {
|
|
305
|
-
return (v.tapTree !== undefined &&
|
|
306
|
-
v.forfeitTapLeafScript !== undefined &&
|
|
307
|
-
v.intentTapLeafScript !== undefined);
|
|
308
|
-
}
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.defineExpoBackgroundTask = defineExpoBackgroundTask;
|
|
4
|
-
exports.registerExpoBackgroundTask = registerExpoBackgroundTask;
|
|
5
|
-
exports.unregisterExpoBackgroundTask = unregisterExpoBackgroundTask;
|
|
6
|
-
const taskRunner_1 = require("../../worker/expo/taskRunner");
|
|
7
|
-
const processors_1 = require("../../worker/expo/processors");
|
|
8
|
-
const expoArk_1 = require("../../providers/expoArk");
|
|
9
|
-
const expoIndexer_1 = require("../../providers/expoIndexer");
|
|
10
|
-
const utils_1 = require("../utils");
|
|
11
|
-
function requireTaskManager() {
|
|
12
|
-
try {
|
|
13
|
-
return require("expo-task-manager");
|
|
14
|
-
}
|
|
15
|
-
catch {
|
|
16
|
-
throw new Error("expo-task-manager is required for background tasks. " +
|
|
17
|
-
"Install it with: npx expo install expo-task-manager");
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
function requireBackgroundTask() {
|
|
21
|
-
try {
|
|
22
|
-
return require("expo-background-task");
|
|
23
|
-
}
|
|
24
|
-
catch {
|
|
25
|
-
throw new Error("expo-background-task is required for background tasks. " +
|
|
26
|
-
"Install it with: npx expo install expo-background-task");
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Define the Expo background task handler.
|
|
31
|
-
*
|
|
32
|
-
* **Must be called at module/global scope** (before React mounts).
|
|
33
|
-
* Internally calls `TaskManager.defineTask()`.
|
|
34
|
-
*
|
|
35
|
-
* @example
|
|
36
|
-
* ```ts
|
|
37
|
-
* // At the top of your app entry file
|
|
38
|
-
* import { defineExpoBackgroundTask } from "@arkade-os/sdk/wallet/expo";
|
|
39
|
-
* import { AsyncStorageTaskQueue } from "@arkade-os/sdk/worker/expo";
|
|
40
|
-
* import AsyncStorage from "@react-native-async-storage/async-storage";
|
|
41
|
-
*
|
|
42
|
-
* const taskQueue = new AsyncStorageTaskQueue(AsyncStorage);
|
|
43
|
-
* defineExpoBackgroundTask("ark-background-poll", {
|
|
44
|
-
* taskQueue,
|
|
45
|
-
* walletRepository: new IndexedDBWalletRepository(),
|
|
46
|
-
* contractRepository: new IndexedDBContractRepository(),
|
|
47
|
-
* });
|
|
48
|
-
* ```
|
|
49
|
-
*/
|
|
50
|
-
function defineExpoBackgroundTask(taskName, options) {
|
|
51
|
-
const TaskManager = requireTaskManager();
|
|
52
|
-
const BackgroundTask = requireBackgroundTask();
|
|
53
|
-
const { taskQueue, walletRepository, contractRepository, processors = [processors_1.contractPollProcessor], } = options;
|
|
54
|
-
TaskManager.defineTask(taskName, async () => {
|
|
55
|
-
try {
|
|
56
|
-
const config = await taskQueue.loadConfig();
|
|
57
|
-
if (!config) {
|
|
58
|
-
// No config persisted yet — ExpoWallet.setup() hasn't run.
|
|
59
|
-
// Nothing to do.
|
|
60
|
-
return BackgroundTask.BackgroundTaskResult.Success;
|
|
61
|
-
}
|
|
62
|
-
// Reconstruct providers
|
|
63
|
-
const indexerProvider = new expoIndexer_1.ExpoIndexerProvider(config.arkServerUrl);
|
|
64
|
-
const arkProvider = new expoArk_1.ExpoArkProvider(config.arkServerUrl);
|
|
65
|
-
const deps = (0, taskRunner_1.createTaskDependencies)({
|
|
66
|
-
walletRepository,
|
|
67
|
-
contractRepository,
|
|
68
|
-
indexerProvider,
|
|
69
|
-
arkProvider,
|
|
70
|
-
});
|
|
71
|
-
await (0, taskRunner_1.runTasks)(taskQueue, processors, deps);
|
|
72
|
-
// Acknowledge outbox results (no foreground to consume them)
|
|
73
|
-
const results = await taskQueue.getResults();
|
|
74
|
-
if (results.length > 0) {
|
|
75
|
-
await taskQueue.acknowledgeResults(results.map((r) => r.id));
|
|
76
|
-
}
|
|
77
|
-
// Re-seed the contract-poll task for the next OS wake
|
|
78
|
-
const existing = await taskQueue.getTasks(processors_1.CONTRACT_POLL_TASK_TYPE);
|
|
79
|
-
if (existing.length === 0) {
|
|
80
|
-
const task = {
|
|
81
|
-
id: (0, utils_1.getRandomId)(),
|
|
82
|
-
type: processors_1.CONTRACT_POLL_TASK_TYPE,
|
|
83
|
-
data: {},
|
|
84
|
-
createdAt: Date.now(),
|
|
85
|
-
};
|
|
86
|
-
await taskQueue.addTask(task);
|
|
87
|
-
}
|
|
88
|
-
return BackgroundTask.BackgroundTaskResult.Success;
|
|
89
|
-
}
|
|
90
|
-
catch (error) {
|
|
91
|
-
console.error("[ark-sdk] Background task failed:", error instanceof Error ? error.message : error);
|
|
92
|
-
return BackgroundTask.BackgroundTaskResult.Failed;
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Activate the OS-level background task scheduler.
|
|
98
|
-
*
|
|
99
|
-
* Call this after @see defineExpoBackgroundTask (typically inside
|
|
100
|
-
* @see ExpoWallet.setup or in a React component after wallet init).
|
|
101
|
-
*
|
|
102
|
-
* @param minimumInterval - Minimum interval in minutes (default 15).
|
|
103
|
-
*/
|
|
104
|
-
async function registerExpoBackgroundTask(taskName, options) {
|
|
105
|
-
const BackgroundTask = requireBackgroundTask();
|
|
106
|
-
await BackgroundTask.registerTaskAsync(taskName, {
|
|
107
|
-
minimumInterval: (options?.minimumInterval ?? 15) * 60,
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Unregister the background task from the OS scheduler.
|
|
112
|
-
*/
|
|
113
|
-
async function unregisterExpoBackgroundTask(taskName) {
|
|
114
|
-
const BackgroundTask = requireBackgroundTask();
|
|
115
|
-
await BackgroundTask.unregisterTaskAsync(taskName);
|
|
116
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.unregisterExpoBackgroundTask = exports.registerExpoBackgroundTask = exports.defineExpoBackgroundTask = exports.ExpoWallet = void 0;
|
|
4
|
-
var wallet_1 = require("./wallet");
|
|
5
|
-
Object.defineProperty(exports, "ExpoWallet", { enumerable: true, get: function () { return wallet_1.ExpoWallet; } });
|
|
6
|
-
var background_1 = require("./background");
|
|
7
|
-
Object.defineProperty(exports, "defineExpoBackgroundTask", { enumerable: true, get: function () { return background_1.defineExpoBackgroundTask; } });
|
|
8
|
-
Object.defineProperty(exports, "registerExpoBackgroundTask", { enumerable: true, get: function () { return background_1.registerExpoBackgroundTask; } });
|
|
9
|
-
Object.defineProperty(exports, "unregisterExpoBackgroundTask", { enumerable: true, get: function () { return background_1.unregisterExpoBackgroundTask; } });
|
|
@@ -1,230 +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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.ExpoWallet = void 0;
|
|
37
|
-
const base_1 = require("@scure/base");
|
|
38
|
-
const wallet_1 = require("../wallet");
|
|
39
|
-
const ark_1 = require("../../providers/ark");
|
|
40
|
-
const taskRunner_1 = require("../../worker/expo/taskRunner");
|
|
41
|
-
const processors_1 = require("../../worker/expo/processors");
|
|
42
|
-
const utils_1 = require("../utils");
|
|
43
|
-
const default_1 = require("../../script/default");
|
|
44
|
-
/**
|
|
45
|
-
* Expo/React Native wallet with built-in background task processing.
|
|
46
|
-
*
|
|
47
|
-
* Wraps a standard @see Wallet and adds a lightweight task queue
|
|
48
|
-
* for keeping contract/VTXO state fresh while the app is active and
|
|
49
|
-
* across Expo BackgroundTask wakes.
|
|
50
|
-
*
|
|
51
|
-
* @example
|
|
52
|
-
* ```ts
|
|
53
|
-
* import { ExpoWallet } from "@arkade-os/sdk/wallet/expo";
|
|
54
|
-
* import { AsyncStorageTaskQueue } from "@arkade-os/sdk/worker/expo";
|
|
55
|
-
*
|
|
56
|
-
* const wallet = await ExpoWallet.setup({
|
|
57
|
-
* identity: MnemonicIdentity.fromMnemonic('abandon abandon...'),
|
|
58
|
-
* arkServerUrl: 'https://arkade.computer',
|
|
59
|
-
* esploraUrl: 'https://mempool.space/api',
|
|
60
|
-
* storage: { ... },
|
|
61
|
-
* background: {
|
|
62
|
-
* taskName: "ark-background-poll",
|
|
63
|
-
* taskQueue: new AsyncStorageTaskQueue(AsyncStorage),
|
|
64
|
-
* foregroundIntervalMs: 20_000,
|
|
65
|
-
* minimumBackgroundInterval: 15,
|
|
66
|
-
* },
|
|
67
|
-
* });
|
|
68
|
-
*
|
|
69
|
-
* const balance = await wallet.getBalance();
|
|
70
|
-
* ```
|
|
71
|
-
*/
|
|
72
|
-
class ExpoWallet {
|
|
73
|
-
constructor(wallet, taskQueue, processors, deps, taskName, foregroundIntervalMs) {
|
|
74
|
-
this.wallet = wallet;
|
|
75
|
-
this.taskQueue = taskQueue;
|
|
76
|
-
this.processors = processors;
|
|
77
|
-
this.deps = deps;
|
|
78
|
-
this.identity = wallet.identity;
|
|
79
|
-
this.arkProvider = wallet.arkProvider;
|
|
80
|
-
this.indexerProvider = wallet.indexerProvider;
|
|
81
|
-
this.taskName = taskName;
|
|
82
|
-
if (foregroundIntervalMs && foregroundIntervalMs > 0) {
|
|
83
|
-
this.startForegroundPolling(foregroundIntervalMs);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Create an ExpoWallet with background task support.
|
|
88
|
-
*
|
|
89
|
-
* 1. Creates the inner @see Wallet via `Wallet.create()`.
|
|
90
|
-
* 2. Wires up processors (defaults to @see contractPollProcessor).
|
|
91
|
-
* 3. Persists background config for the background handler (if the queue supports it).
|
|
92
|
-
* 4. Seeds the task queue with a `contract-poll` task.
|
|
93
|
-
* 5. Registers the background task with the OS scheduler (if `minimumBackgroundInterval` is set).
|
|
94
|
-
* 6. Starts foreground polling if `foregroundIntervalMs` is set.
|
|
95
|
-
*/
|
|
96
|
-
static async setup(config) {
|
|
97
|
-
const wallet = await wallet_1.Wallet.create(config);
|
|
98
|
-
const processors = config.background.processors ?? [
|
|
99
|
-
processors_1.contractPollProcessor,
|
|
100
|
-
];
|
|
101
|
-
const deps = {
|
|
102
|
-
walletRepository: wallet.walletRepository,
|
|
103
|
-
contractRepository: wallet.contractRepository,
|
|
104
|
-
indexerProvider: wallet.indexerProvider,
|
|
105
|
-
arkProvider: wallet.arkProvider,
|
|
106
|
-
extendVtxo: (vtxo, contract) => (0, utils_1.extendVirtualCoinForContract)(vtxo, contract),
|
|
107
|
-
};
|
|
108
|
-
const { taskQueue } = config.background;
|
|
109
|
-
// Persist wallet params so the background handler can rehydrate
|
|
110
|
-
// without a network call. Only works with AsyncStorageTaskQueue.
|
|
111
|
-
if ("persistConfig" in taskQueue) {
|
|
112
|
-
const arkServerUrl = config.arkServerUrl ??
|
|
113
|
-
(wallet.arkProvider instanceof ark_1.RestArkProvider
|
|
114
|
-
? wallet.arkProvider.serverUrl
|
|
115
|
-
: undefined);
|
|
116
|
-
if (arkServerUrl) {
|
|
117
|
-
const timelock = wallet.offchainTapscript.options.csvTimelock ??
|
|
118
|
-
default_1.DefaultVtxo.Script.DEFAULT_TIMELOCK;
|
|
119
|
-
const bgConfig = {
|
|
120
|
-
arkServerUrl,
|
|
121
|
-
pubkeyHex: base_1.hex.encode(wallet.offchainTapscript.options.pubKey),
|
|
122
|
-
serverPubKeyHex: base_1.hex.encode(wallet.offchainTapscript.options.serverPubKey),
|
|
123
|
-
exitTimelockValue: timelock.value.toString(),
|
|
124
|
-
exitTimelockType: timelock.type,
|
|
125
|
-
};
|
|
126
|
-
await taskQueue.persistConfig(bgConfig);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
const expoWallet = new ExpoWallet(wallet, taskQueue, processors, deps, config.background.taskName, config.background.foregroundIntervalMs);
|
|
130
|
-
// Seed the queue so the first tick (or background wake) has work to do
|
|
131
|
-
await expoWallet.seedContractPollTask();
|
|
132
|
-
// Activate OS-level background scheduling
|
|
133
|
-
if (config.background.minimumBackgroundInterval) {
|
|
134
|
-
try {
|
|
135
|
-
const { registerExpoBackgroundTask } = await Promise.resolve().then(() => __importStar(require("./background")));
|
|
136
|
-
await registerExpoBackgroundTask(config.background.taskName, {
|
|
137
|
-
minimumInterval: config.background.minimumBackgroundInterval,
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
catch {
|
|
141
|
-
// expo-background-task not installed — foreground-only mode
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
return expoWallet;
|
|
145
|
-
}
|
|
146
|
-
// ── Foreground polling ───────────────────────────────────────────
|
|
147
|
-
startForegroundPolling(intervalMs) {
|
|
148
|
-
this.foregroundIntervalId = setInterval(() => {
|
|
149
|
-
this.runForegroundPoll().catch(console.error);
|
|
150
|
-
}, intervalMs);
|
|
151
|
-
}
|
|
152
|
-
async runForegroundPoll() {
|
|
153
|
-
await (0, taskRunner_1.runTasks)(this.taskQueue, this.processors, this.deps);
|
|
154
|
-
// Consume results immediately (no background handoff needed)
|
|
155
|
-
const results = await this.taskQueue.getResults();
|
|
156
|
-
if (results.length > 0) {
|
|
157
|
-
await this.taskQueue.acknowledgeResults(results.map((r) => r.id));
|
|
158
|
-
}
|
|
159
|
-
// Re-seed for the next tick
|
|
160
|
-
await this.seedContractPollTask();
|
|
161
|
-
}
|
|
162
|
-
async seedContractPollTask() {
|
|
163
|
-
const existing = await this.taskQueue.getTasks(processors_1.CONTRACT_POLL_TASK_TYPE);
|
|
164
|
-
if (existing.length > 0)
|
|
165
|
-
return;
|
|
166
|
-
const task = {
|
|
167
|
-
id: (0, utils_1.getRandomId)(),
|
|
168
|
-
type: processors_1.CONTRACT_POLL_TASK_TYPE,
|
|
169
|
-
data: {},
|
|
170
|
-
createdAt: Date.now(),
|
|
171
|
-
};
|
|
172
|
-
await this.taskQueue.addTask(task);
|
|
173
|
-
}
|
|
174
|
-
// ── Lifecycle ────────────────────────────────────────────────────
|
|
175
|
-
/**
|
|
176
|
-
* Stop foreground polling and unregister the background task.
|
|
177
|
-
*/
|
|
178
|
-
async dispose() {
|
|
179
|
-
if (this.foregroundIntervalId) {
|
|
180
|
-
clearInterval(this.foregroundIntervalId);
|
|
181
|
-
this.foregroundIntervalId = undefined;
|
|
182
|
-
}
|
|
183
|
-
try {
|
|
184
|
-
const { unregisterExpoBackgroundTask } = await Promise.resolve().then(() => __importStar(require("./background")));
|
|
185
|
-
await unregisterExpoBackgroundTask(this.taskName);
|
|
186
|
-
}
|
|
187
|
-
catch {
|
|
188
|
-
// expo-background-task not installed — nothing to unregister
|
|
189
|
-
}
|
|
190
|
-
await this.wallet.dispose();
|
|
191
|
-
}
|
|
192
|
-
// ── IWallet delegation ───────────────────────────────────────────
|
|
193
|
-
getAddress() {
|
|
194
|
-
return this.wallet.getAddress();
|
|
195
|
-
}
|
|
196
|
-
getBoardingAddress() {
|
|
197
|
-
return this.wallet.getBoardingAddress();
|
|
198
|
-
}
|
|
199
|
-
getBalance() {
|
|
200
|
-
return this.wallet.getBalance();
|
|
201
|
-
}
|
|
202
|
-
getVtxos(filter) {
|
|
203
|
-
return this.wallet.getVtxos(filter);
|
|
204
|
-
}
|
|
205
|
-
getBoardingUtxos() {
|
|
206
|
-
return this.wallet.getBoardingUtxos();
|
|
207
|
-
}
|
|
208
|
-
getTransactionHistory() {
|
|
209
|
-
return this.wallet.getTransactionHistory();
|
|
210
|
-
}
|
|
211
|
-
getContractManager() {
|
|
212
|
-
return this.wallet.getContractManager();
|
|
213
|
-
}
|
|
214
|
-
getDelegatorManager() {
|
|
215
|
-
return this.wallet.getDelegatorManager();
|
|
216
|
-
}
|
|
217
|
-
sendBitcoin(params) {
|
|
218
|
-
return this.wallet.sendBitcoin(params);
|
|
219
|
-
}
|
|
220
|
-
settle(params, eventCallback) {
|
|
221
|
-
return this.wallet.settle(params, eventCallback);
|
|
222
|
-
}
|
|
223
|
-
send(...recipients) {
|
|
224
|
-
return this.wallet.send(...recipients);
|
|
225
|
-
}
|
|
226
|
-
get assetManager() {
|
|
227
|
-
return this.wallet.assetManager;
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
exports.ExpoWallet = ExpoWallet;
|