@arkade-os/sdk 0.4.27 → 0.4.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +31 -100
- package/dist/adapters/asyncStorage.cjs +48 -0
- package/dist/adapters/asyncStorage.cjs.map +1 -0
- package/dist/adapters/asyncStorage.d.cts +16 -0
- package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
- package/dist/adapters/asyncStorage.js +46 -0
- package/dist/adapters/asyncStorage.js.map +1 -0
- package/dist/adapters/expo.cjs +19 -0
- package/dist/adapters/expo.cjs.map +1 -0
- package/dist/adapters/expo.d.cts +48 -0
- package/dist/adapters/expo.d.ts +48 -0
- package/dist/adapters/expo.js +6 -0
- package/dist/adapters/expo.js.map +1 -0
- package/dist/adapters/fileSystem.cjs +116 -0
- package/dist/adapters/fileSystem.cjs.map +1 -0
- package/dist/adapters/fileSystem.d.cts +17 -0
- package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
- package/dist/adapters/fileSystem.js +93 -0
- package/dist/adapters/fileSystem.js.map +1 -0
- package/dist/adapters/indexedDB.cjs +103 -0
- package/dist/adapters/indexedDB.cjs.map +1 -0
- package/dist/adapters/indexedDB.d.cts +18 -0
- package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
- package/dist/adapters/indexedDB.js +101 -0
- package/dist/adapters/indexedDB.js.map +1 -0
- package/dist/adapters/localStorage.cjs +50 -0
- package/dist/adapters/localStorage.cjs.map +1 -0
- package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
- package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
- package/dist/adapters/localStorage.js +48 -0
- package/dist/adapters/localStorage.js.map +1 -0
- package/dist/ark-TZ1gXAXU.d.cts +3880 -0
- package/dist/ark-TZ1gXAXU.d.ts +3880 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
- package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-5PG7DV7A.cjs +805 -0
- package/dist/chunk-5PG7DV7A.cjs.map +1 -0
- package/dist/chunk-A3EMF7RN.js +95 -0
- package/dist/chunk-A3EMF7RN.js.map +1 -0
- package/dist/chunk-ADV27S4N.cjs +2701 -0
- package/dist/chunk-ADV27S4N.cjs.map +1 -0
- package/dist/chunk-BQLHADL7.js +13805 -0
- package/dist/chunk-BQLHADL7.js.map +1 -0
- package/dist/chunk-CFZMTDWI.js +209 -0
- package/dist/chunk-CFZMTDWI.js.map +1 -0
- package/dist/chunk-FG5ACJJW.cjs +212 -0
- package/dist/chunk-FG5ACJJW.cjs.map +1 -0
- package/dist/chunk-HW3JJ323.js +768 -0
- package/dist/chunk-HW3JJ323.js.map +1 -0
- package/dist/chunk-I3DGUUCT.cjs +838 -0
- package/dist/chunk-I3DGUUCT.cjs.map +1 -0
- package/dist/chunk-IPX2R7FR.cjs +100 -0
- package/dist/chunk-IPX2R7FR.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-T64LAI7L.js +829 -0
- package/dist/chunk-T64LAI7L.js.map +1 -0
- package/dist/chunk-ZBUDLTBO.js +2671 -0
- package/dist/chunk-ZBUDLTBO.js.map +1 -0
- package/dist/chunk-ZLO6NETT.cjs +13910 -0
- package/dist/chunk-ZLO6NETT.cjs.map +1 -0
- package/dist/contracts/handlers/index.cjs +26 -0
- package/dist/contracts/handlers/index.cjs.map +1 -0
- package/dist/contracts/handlers/index.d.cts +7 -0
- package/dist/contracts/handlers/index.d.ts +7 -0
- package/dist/contracts/handlers/index.js +5 -0
- package/dist/contracts/handlers/index.js.map +1 -0
- package/dist/delegate-BFZs69hp.d.cts +84 -0
- package/dist/delegate-aaVGfWsV.d.ts +84 -0
- package/dist/index-B22cA64m.d.cts +199 -0
- package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
- package/dist/index-C0IanN1m.d.ts +11 -0
- package/dist/index-NDla_UoJ.d.ts +199 -0
- package/dist/index.cjs +480 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3343 -0
- package/dist/index.d.ts +3343 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/repositories/realm/index.cjs +513 -0
- package/dist/repositories/realm/index.cjs.map +1 -0
- package/dist/repositories/realm/index.d.cts +217 -0
- package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
- package/dist/repositories/realm/index.js +507 -0
- package/dist/repositories/realm/index.js.map +1 -0
- package/dist/repositories/sqlite/index.cjs +588 -0
- package/dist/repositories/sqlite/index.cjs.map +1 -0
- package/dist/repositories/sqlite/index.d.cts +118 -0
- package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
- package/dist/repositories/sqlite/index.js +585 -0
- package/dist/repositories/sqlite/index.js.map +1 -0
- package/dist/taskRunner-C6Ff4OaU.d.cts +114 -0
- package/dist/taskRunner-yvPN8Z0K.d.ts +114 -0
- package/dist/wallet/expo/background.cjs +93 -0
- package/dist/wallet/expo/background.cjs.map +1 -0
- package/dist/wallet/expo/background.d.cts +84 -0
- package/dist/wallet/expo/background.d.ts +84 -0
- package/dist/wallet/expo/background.js +68 -0
- package/dist/wallet/expo/background.js.map +1 -0
- package/dist/wallet/expo/index.cjs +171 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +122 -0
- package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
- package/dist/wallet/expo/index.js +169 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-AF-p-OWj.d.cts +774 -0
- package/dist/wallet-D9NBRqvC.d.ts +774 -0
- package/dist/worker/expo/index.cjs +140 -0
- package/dist/worker/expo/index.cjs.map +1 -0
- package/dist/worker/expo/index.d.cts +29 -0
- package/dist/worker/expo/index.d.ts +29 -0
- package/dist/worker/expo/index.js +121 -0
- package/dist/worker/expo/index.js.map +1 -0
- package/package.json +110 -76
- package/dist/cjs/adapters/asyncStorage.js +0 -5
- package/dist/cjs/adapters/expo.js +0 -8
- package/dist/cjs/adapters/fileSystem.js +0 -5
- package/dist/cjs/adapters/indexedDB.js +0 -5
- package/dist/cjs/adapters/localStorage.js +0 -5
- package/dist/cjs/arkfee/celenv.js +0 -43
- package/dist/cjs/arkfee/estimator.js +0 -143
- package/dist/cjs/arkfee/index.js +0 -5
- package/dist/cjs/arkfee/types.js +0 -26
- package/dist/cjs/arknote/index.js +0 -128
- package/dist/cjs/bip322/index.js +0 -270
- package/dist/cjs/contracts/arkcontract.js +0 -147
- package/dist/cjs/contracts/contractManager.js +0 -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/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
package/dist/esm/wallet/batch.js
DELETED
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
import { SettlementEventType } from "../providers/ark.js";
|
|
2
|
-
import { TxTree } from "../tree/txTree.js";
|
|
3
|
-
import { hex } from "@scure/base";
|
|
4
|
-
/**
|
|
5
|
-
* Batch namespace provides utilities for joining and processing batch session.
|
|
6
|
-
* The batch settlement process involves multiple events, this namespace provides abstractions and types to handle them.
|
|
7
|
-
* @see https://docs.arkadeos.com/learn/pillars/batch-swaps
|
|
8
|
-
* @example
|
|
9
|
-
* ```typescript
|
|
10
|
-
* // use wallet handler or create a custom one
|
|
11
|
-
* const handler = wallet.createBatchHandler(intentId, inputs, expectedRecipients, musig2session);
|
|
12
|
-
*
|
|
13
|
-
* const abortController = new AbortController();
|
|
14
|
-
* // Get event stream from the Arkade provider
|
|
15
|
-
* const eventStream = arkProvider.getEventStream(
|
|
16
|
-
* abortController.signal,
|
|
17
|
-
* ['your-topic-1', 'your-topic-2']
|
|
18
|
-
* );
|
|
19
|
-
*
|
|
20
|
-
* // Join the batch and process events
|
|
21
|
-
* try {
|
|
22
|
-
* const commitmentTxid = await Batch.join(eventStream, handler);
|
|
23
|
-
* console.log('Batch completed with commitment:', commitmentTxid);
|
|
24
|
-
* } catch (error) {
|
|
25
|
-
* console.error('Batch processing failed:', error);
|
|
26
|
-
* } finally {
|
|
27
|
-
* abortController.abort();
|
|
28
|
-
* }
|
|
29
|
-
* ```
|
|
30
|
-
*/
|
|
31
|
-
export var Batch;
|
|
32
|
-
(function (Batch) {
|
|
33
|
-
// State machine steps for batch session
|
|
34
|
-
let Step;
|
|
35
|
-
(function (Step) {
|
|
36
|
-
Step["Start"] = "start";
|
|
37
|
-
Step["BatchStarted"] = "batch_started";
|
|
38
|
-
Step["TreeSigningStarted"] = "tree_signing_started";
|
|
39
|
-
Step["TreeNoncesAggregated"] = "tree_nonces_aggregated";
|
|
40
|
-
Step["BatchFinalization"] = "batch_finalization";
|
|
41
|
-
})(Step || (Step = {}));
|
|
42
|
-
/**
|
|
43
|
-
* Start the state machine that will process the batch events and join a batch.
|
|
44
|
-
* @param eventIterator - The events stream to process.
|
|
45
|
-
* @param handler - How to react to events.
|
|
46
|
-
* @param options - Options.
|
|
47
|
-
*/
|
|
48
|
-
async function join(eventIterator, handler, options = {}) {
|
|
49
|
-
const { abortController, skipVtxoTreeSigning = false, eventCallback, } = options;
|
|
50
|
-
let step = Step.Start;
|
|
51
|
-
// keep track of tree transactions as they arrive
|
|
52
|
-
const flatVtxoTree = [];
|
|
53
|
-
const flatConnectorTree = [];
|
|
54
|
-
// once everything is collected, the TxTree objects are created
|
|
55
|
-
let vtxoTree = undefined;
|
|
56
|
-
let connectorTree = undefined;
|
|
57
|
-
for await (const event of eventIterator) {
|
|
58
|
-
if (abortController?.signal.aborted) {
|
|
59
|
-
throw new Error("canceled");
|
|
60
|
-
}
|
|
61
|
-
if (eventCallback) {
|
|
62
|
-
// don't wait for the callback to complete and ignore errors
|
|
63
|
-
eventCallback(event).catch(() => { });
|
|
64
|
-
}
|
|
65
|
-
switch (event.type) {
|
|
66
|
-
case SettlementEventType.BatchStarted: {
|
|
67
|
-
const e = event;
|
|
68
|
-
const { skip } = await handler.onBatchStarted(e);
|
|
69
|
-
if (!skip) {
|
|
70
|
-
step = Step.BatchStarted;
|
|
71
|
-
if (skipVtxoTreeSigning) {
|
|
72
|
-
// skip TxTree events and musig2 signatures and nonces
|
|
73
|
-
step = Step.TreeNoncesAggregated;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
continue;
|
|
77
|
-
}
|
|
78
|
-
case SettlementEventType.BatchFinalized: {
|
|
79
|
-
if (step !== Step.BatchFinalization) {
|
|
80
|
-
continue;
|
|
81
|
-
}
|
|
82
|
-
if (handler.onBatchFinalized) {
|
|
83
|
-
await handler.onBatchFinalized(event);
|
|
84
|
-
}
|
|
85
|
-
return event.commitmentTxid;
|
|
86
|
-
}
|
|
87
|
-
case SettlementEventType.BatchFailed: {
|
|
88
|
-
if (handler.onBatchFailed) {
|
|
89
|
-
await handler.onBatchFailed(event);
|
|
90
|
-
continue;
|
|
91
|
-
}
|
|
92
|
-
throw new Error(event.reason);
|
|
93
|
-
}
|
|
94
|
-
case SettlementEventType.TreeTx: {
|
|
95
|
-
if (step !== Step.BatchStarted &&
|
|
96
|
-
step !== Step.TreeNoncesAggregated) {
|
|
97
|
-
continue;
|
|
98
|
-
}
|
|
99
|
-
// batchIndex 0 = virtual output tree, batchIndex 1 = connector tree
|
|
100
|
-
if (event.batchIndex === 0) {
|
|
101
|
-
flatVtxoTree.push(event.chunk);
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
flatConnectorTree.push(event.chunk);
|
|
105
|
-
}
|
|
106
|
-
if (handler.onTreeTxEvent) {
|
|
107
|
-
await handler.onTreeTxEvent(event);
|
|
108
|
-
}
|
|
109
|
-
continue;
|
|
110
|
-
}
|
|
111
|
-
case SettlementEventType.TreeSignature: {
|
|
112
|
-
if (step !== Step.TreeNoncesAggregated) {
|
|
113
|
-
continue;
|
|
114
|
-
}
|
|
115
|
-
if (!vtxoTree) {
|
|
116
|
-
throw new Error("vtxo tree not initialized");
|
|
117
|
-
}
|
|
118
|
-
// push signature to the virtual output tree
|
|
119
|
-
const tapKeySig = hex.decode(event.signature);
|
|
120
|
-
vtxoTree.update(event.txid, (tx) => {
|
|
121
|
-
tx.updateInput(0, {
|
|
122
|
-
tapKeySig,
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
if (handler.onTreeSignatureEvent) {
|
|
126
|
-
await handler.onTreeSignatureEvent(event);
|
|
127
|
-
}
|
|
128
|
-
continue;
|
|
129
|
-
}
|
|
130
|
-
case SettlementEventType.TreeSigningStarted: {
|
|
131
|
-
if (step !== Step.BatchStarted) {
|
|
132
|
-
continue;
|
|
133
|
-
}
|
|
134
|
-
// create virtual output tree from collected chunks
|
|
135
|
-
vtxoTree = TxTree.create(flatVtxoTree);
|
|
136
|
-
const { skip } = await handler.onTreeSigningStarted(event, vtxoTree);
|
|
137
|
-
if (!skip) {
|
|
138
|
-
step = Step.TreeSigningStarted;
|
|
139
|
-
}
|
|
140
|
-
continue;
|
|
141
|
-
}
|
|
142
|
-
case SettlementEventType.TreeNonces: {
|
|
143
|
-
if (step !== Step.TreeSigningStarted) {
|
|
144
|
-
continue;
|
|
145
|
-
}
|
|
146
|
-
const { fullySigned } = await handler.onTreeNonces(event);
|
|
147
|
-
if (fullySigned) {
|
|
148
|
-
step = Step.TreeNoncesAggregated;
|
|
149
|
-
}
|
|
150
|
-
continue;
|
|
151
|
-
}
|
|
152
|
-
case SettlementEventType.BatchFinalization: {
|
|
153
|
-
if (step !== Step.TreeNoncesAggregated) {
|
|
154
|
-
continue;
|
|
155
|
-
}
|
|
156
|
-
// Build virtual output tree if it hasn't been built yet
|
|
157
|
-
if (!vtxoTree && flatVtxoTree.length > 0) {
|
|
158
|
-
vtxoTree = TxTree.create(flatVtxoTree);
|
|
159
|
-
}
|
|
160
|
-
if (!vtxoTree && !skipVtxoTreeSigning) {
|
|
161
|
-
throw new Error("vtxo tree not initialized");
|
|
162
|
-
}
|
|
163
|
-
// Build connector tree if we have chunks
|
|
164
|
-
if (flatConnectorTree.length > 0) {
|
|
165
|
-
connectorTree = TxTree.create(flatConnectorTree);
|
|
166
|
-
}
|
|
167
|
-
await handler.onBatchFinalization(event, vtxoTree, connectorTree);
|
|
168
|
-
step = Step.BatchFinalization;
|
|
169
|
-
continue;
|
|
170
|
-
}
|
|
171
|
-
default:
|
|
172
|
-
// unknown event type, continue
|
|
173
|
-
continue;
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
// iterator closed without finalization, something went wrong
|
|
177
|
-
throw new Error("event stream closed");
|
|
178
|
-
}
|
|
179
|
-
Batch.join = join;
|
|
180
|
-
})(Batch || (Batch = {}));
|
|
@@ -1,303 +0,0 @@
|
|
|
1
|
-
import { ArkAddress, decodeTapscript, Estimator, Intent, isRecoverable, MultisigTapscript, VtxoScript, } from "../index.js";
|
|
2
|
-
import { base64, hex } from "@scure/base";
|
|
3
|
-
import { scriptFromTapLeafScript } from "../script/base.js";
|
|
4
|
-
import { buildForfeitTxWithOutput } from "../forfeit.js";
|
|
5
|
-
import { Address, OutScript, SigHash } from "@scure/btc-signer";
|
|
6
|
-
import { equalBytes } from "@scure/btc-signer/utils.js";
|
|
7
|
-
import { getNetwork } from "../networks.js";
|
|
8
|
-
import { createAssetPacket } from "./asset.js";
|
|
9
|
-
import { Extension } from "../extension/index.js";
|
|
10
|
-
export class DelegatorManagerImpl {
|
|
11
|
-
/** Create a delegator manager from the configured provider, Arkade info source, and wallet identity. */
|
|
12
|
-
constructor(delegatorProvider, arkInfoProvider, identity) {
|
|
13
|
-
this.delegatorProvider = delegatorProvider;
|
|
14
|
-
this.arkInfoProvider = arkInfoProvider;
|
|
15
|
-
this.identity = identity;
|
|
16
|
-
}
|
|
17
|
-
async getDelegateInfo() {
|
|
18
|
-
return this.delegatorProvider.getDelegateInfo();
|
|
19
|
-
}
|
|
20
|
-
async delegate(vtxos, destination, delegateAt) {
|
|
21
|
-
if (vtxos.length === 0) {
|
|
22
|
-
return { delegated: [], failed: [] };
|
|
23
|
-
}
|
|
24
|
-
const destinationScript = ArkAddress.decode(destination).pkScript;
|
|
25
|
-
// fetch server and delegator info once, shared across all groups
|
|
26
|
-
const arkInfo = await this.arkInfoProvider.getInfo();
|
|
27
|
-
const delegateInfo = await this.delegatorProvider.getDelegateInfo();
|
|
28
|
-
// keep only vtxos that can be signed by the delegate. The guard
|
|
29
|
-
// narrows ContractVtxo (with optional taproot fields) to the
|
|
30
|
-
// ExtendedVirtualCoin shape required by makeDelegateForfeitTx.
|
|
31
|
-
const eligible = vtxos.filter((v) => isAnnotated(v) &&
|
|
32
|
-
findDelegateTapLeaf(v, delegateInfo.pubkey) !== undefined);
|
|
33
|
-
if (eligible.length === 0) {
|
|
34
|
-
return { delegated: [], failed: [] };
|
|
35
|
-
}
|
|
36
|
-
// if explicit delegateAt is provided, delegate all virtual outputs at once without sorting
|
|
37
|
-
if (delegateAt) {
|
|
38
|
-
try {
|
|
39
|
-
await delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, eligible, destinationScript, delegateAt);
|
|
40
|
-
}
|
|
41
|
-
catch (error) {
|
|
42
|
-
return {
|
|
43
|
-
delegated: [],
|
|
44
|
-
failed: [{ outpoints: eligible, error }],
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
return { delegated: eligible, failed: [] };
|
|
48
|
-
}
|
|
49
|
-
// if no explicit delegateAt is provided, sort virtual outputs by expiry and delegate in groups of the same expiry day
|
|
50
|
-
const groupByExpiry = new Map();
|
|
51
|
-
let recoverableVtxos = [];
|
|
52
|
-
for (const vtxo of eligible) {
|
|
53
|
-
if (isRecoverable(vtxo)) {
|
|
54
|
-
recoverableVtxos.push(vtxo);
|
|
55
|
-
continue;
|
|
56
|
-
}
|
|
57
|
-
const expiry = vtxo.virtualStatus.batchExpiry;
|
|
58
|
-
if (!expiry)
|
|
59
|
-
continue;
|
|
60
|
-
const dayKey = getDayTimestamp(expiry);
|
|
61
|
-
groupByExpiry.set(dayKey, [
|
|
62
|
-
...(groupByExpiry.get(dayKey) ?? []),
|
|
63
|
-
vtxo,
|
|
64
|
-
]);
|
|
65
|
-
}
|
|
66
|
-
// if no groups, it means we only need to delegate the recoverable virtual outputs
|
|
67
|
-
if (groupByExpiry.size === 0) {
|
|
68
|
-
try {
|
|
69
|
-
await delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, recoverableVtxos, destinationScript, delegateAt);
|
|
70
|
-
}
|
|
71
|
-
catch (error) {
|
|
72
|
-
return {
|
|
73
|
-
delegated: [],
|
|
74
|
-
failed: [{ outpoints: recoverableVtxos, error }],
|
|
75
|
-
};
|
|
76
|
-
}
|
|
77
|
-
return { delegated: recoverableVtxos, failed: [] };
|
|
78
|
-
}
|
|
79
|
-
// search for the earliest group, include recoverable virtual outputs into it
|
|
80
|
-
const earliestGroup = Math.min(...groupByExpiry.keys());
|
|
81
|
-
groupByExpiry.set(earliestGroup, [
|
|
82
|
-
...(groupByExpiry.get(earliestGroup) ?? []),
|
|
83
|
-
...recoverableVtxos,
|
|
84
|
-
]);
|
|
85
|
-
const groupsList = Array.from(groupByExpiry.entries());
|
|
86
|
-
const result = await Promise.allSettled(groupsList.map(async ([, vtxosGroup]) => delegate(this.identity, this.delegatorProvider, arkInfo, delegateInfo, vtxosGroup, destinationScript)));
|
|
87
|
-
const delegated = [];
|
|
88
|
-
const failed = [];
|
|
89
|
-
for (const [index, resultItem] of result.entries()) {
|
|
90
|
-
const vtxos = groupsList[index][1];
|
|
91
|
-
if (resultItem.status === "rejected") {
|
|
92
|
-
failed.push({ outpoints: vtxos, error: resultItem.reason });
|
|
93
|
-
continue;
|
|
94
|
-
}
|
|
95
|
-
delegated.push(...vtxos);
|
|
96
|
-
}
|
|
97
|
-
return { delegated, failed };
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Delegates virtual outputs to a delegation service, allowing them to manage their renewal
|
|
102
|
-
* on behalf of the wallet owner.
|
|
103
|
-
* @param vtxos - Array of extended virtual outputs to delegate. Must not be empty.
|
|
104
|
-
* @param delegateAt - Optional Date specifying when the delegation
|
|
105
|
-
* should occur. If not provided, defaults to 12 hours before the earliest
|
|
106
|
-
* expiry time of the provided vtxos.
|
|
107
|
-
*/
|
|
108
|
-
async function delegate(identity, delegatorProvider, arkInfo, delegateInfo, vtxos, destinationScript, delegateAt) {
|
|
109
|
-
if (vtxos.length === 0) {
|
|
110
|
-
throw new Error("unable to delegate: no vtxos provided");
|
|
111
|
-
}
|
|
112
|
-
if (!delegatorProvider) {
|
|
113
|
-
throw new Error("unable to delegate: delegator provider not configured");
|
|
114
|
-
}
|
|
115
|
-
if (!delegateAt) {
|
|
116
|
-
const expiryTimestamp = vtxos
|
|
117
|
-
.filter((coin) => !isRecoverable(coin) && coin.virtualStatus.batchExpiry)
|
|
118
|
-
.reduce((min, coin) => Math.min(min, coin.virtualStatus.batchExpiry), Number.MAX_SAFE_INTEGER);
|
|
119
|
-
if (!expiryTimestamp || expiryTimestamp === Number.MAX_SAFE_INTEGER) {
|
|
120
|
-
// if no expiry (recoverable virtual outputs), delegate 1 minute from now
|
|
121
|
-
delegateAt = new Date(Date.now() + 1 * 60 * 1000);
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
const remainingTimeMs = expiryTimestamp - Date.now();
|
|
125
|
-
if (remainingTimeMs <= 0) {
|
|
126
|
-
delegateAt = new Date(Date.now() + 1 * 60 * 1000);
|
|
127
|
-
}
|
|
128
|
-
else {
|
|
129
|
-
// delegate 10% before the expiry
|
|
130
|
-
delegateAt = new Date(expiryTimestamp - remainingTimeMs * 0.1);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
const { fees, dust, forfeitAddress, network } = arkInfo;
|
|
135
|
-
const delegateAtSeconds = delegateAt.getTime() / 1000;
|
|
136
|
-
const estimator = new Estimator({
|
|
137
|
-
...fees.intentFee,
|
|
138
|
-
// replace now() function with the delegateAt timestamp
|
|
139
|
-
offchainInput: fees.intentFee.offchainInput?.replace("now()", `double(${delegateAtSeconds})`),
|
|
140
|
-
offchainOutput: fees.intentFee.offchainOutput?.replace("now()", `double(${delegateAtSeconds})`),
|
|
141
|
-
});
|
|
142
|
-
let amount = 0n;
|
|
143
|
-
for (const coin of vtxos) {
|
|
144
|
-
const inputFee = estimator.evalOffchainInput({
|
|
145
|
-
amount: BigInt(coin.value),
|
|
146
|
-
type: "vtxo",
|
|
147
|
-
weight: 0,
|
|
148
|
-
birth: coin.createdAt,
|
|
149
|
-
expiry: coin.virtualStatus.batchExpiry
|
|
150
|
-
? new Date(coin.virtualStatus.batchExpiry)
|
|
151
|
-
: undefined,
|
|
152
|
-
});
|
|
153
|
-
if (inputFee.value >= coin.value) {
|
|
154
|
-
continue;
|
|
155
|
-
}
|
|
156
|
-
amount += BigInt(coin.value) - BigInt(inputFee.value);
|
|
157
|
-
}
|
|
158
|
-
const { delegatorAddress, pubkey, fee } = delegateInfo;
|
|
159
|
-
const outputs = [];
|
|
160
|
-
const delegatorFee = BigInt(Number(fee));
|
|
161
|
-
if (delegatorFee > 0n) {
|
|
162
|
-
outputs.push({
|
|
163
|
-
script: ArkAddress.decode(delegatorAddress).pkScript,
|
|
164
|
-
amount: delegatorFee,
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
const outputFee = outputs.reduce((fee, output) => {
|
|
168
|
-
if (!output.amount || !output.script)
|
|
169
|
-
return fee;
|
|
170
|
-
return (fee +
|
|
171
|
-
estimator.evalOffchainOutput({
|
|
172
|
-
amount: output.amount,
|
|
173
|
-
script: hex.encode(output.script),
|
|
174
|
-
}).satoshis);
|
|
175
|
-
}, 0);
|
|
176
|
-
if (amount - BigInt(outputFee) <= dust) {
|
|
177
|
-
throw new Error("Amount is below dust limit, cannot delegate");
|
|
178
|
-
}
|
|
179
|
-
amount -= BigInt(outputFee);
|
|
180
|
-
amount -= delegatorFee;
|
|
181
|
-
if (amount <= dust) {
|
|
182
|
-
throw new Error("Amount is below dust limit, cannot delegate");
|
|
183
|
-
}
|
|
184
|
-
outputs.push({
|
|
185
|
-
script: destinationScript,
|
|
186
|
-
amount: amount,
|
|
187
|
-
});
|
|
188
|
-
const registerIntent = await makeSignedDelegateIntent(identity, vtxos, outputs, [], [pubkey], delegateAtSeconds, destinationScript);
|
|
189
|
-
const forfeitOutputScript = OutScript.encode(Address(getNetwork(network)).decode(forfeitAddress));
|
|
190
|
-
const forfeits = await Promise.all(vtxos
|
|
191
|
-
.filter((v) => !isRecoverable(v))
|
|
192
|
-
.map(async (coin) => {
|
|
193
|
-
const forfeit = await makeDelegateForfeitTx(coin, dust, pubkey, forfeitOutputScript, identity);
|
|
194
|
-
return base64.encode(forfeit.toPSBT());
|
|
195
|
-
}));
|
|
196
|
-
await delegatorProvider.delegate(registerIntent, forfeits);
|
|
197
|
-
}
|
|
198
|
-
async function makeDelegateForfeitTx(input, connectorAmount, delegatePubkey, forfeitOutputScript, identity) {
|
|
199
|
-
const delegateTapLeaf = findDelegateTapLeaf(input, delegatePubkey);
|
|
200
|
-
if (!delegateTapLeaf) {
|
|
201
|
-
throw new Error(`delegate tap leaf not found for input: ${input.txid}:${input.vout}`);
|
|
202
|
-
}
|
|
203
|
-
const tx = buildForfeitTxWithOutput([
|
|
204
|
-
{
|
|
205
|
-
txid: input.txid,
|
|
206
|
-
index: input.vout,
|
|
207
|
-
witnessUtxo: {
|
|
208
|
-
amount: BigInt(input.value),
|
|
209
|
-
script: VtxoScript.decode(input.tapTree).pkScript,
|
|
210
|
-
},
|
|
211
|
-
sighashType: SigHash.ALL_ANYONECANPAY,
|
|
212
|
-
tapLeafScript: [delegateTapLeaf],
|
|
213
|
-
},
|
|
214
|
-
], {
|
|
215
|
-
script: forfeitOutputScript,
|
|
216
|
-
amount: BigInt(input.value) + connectorAmount,
|
|
217
|
-
});
|
|
218
|
-
return identity.sign(tx);
|
|
219
|
-
}
|
|
220
|
-
async function makeSignedDelegateIntent(identity, coins, outputs, onchainOutputsIndexes, cosignerPubKeys, validAt, destinationScript) {
|
|
221
|
-
// if some of the inputs hold assets, build the asset packet and append as output
|
|
222
|
-
// in the intent proof tx, there is a "fake" input at index 0
|
|
223
|
-
// so the real coin indices are offset by +1
|
|
224
|
-
const assetInputs = new Map();
|
|
225
|
-
for (let i = 0; i < coins.length; i++) {
|
|
226
|
-
if ("assets" in coins[i]) {
|
|
227
|
-
const assets = coins[i].assets;
|
|
228
|
-
if (assets && assets.length > 0) {
|
|
229
|
-
assetInputs.set(i + 1, assets);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
let outputAssets;
|
|
234
|
-
const assetOutputIndex = findDestinationOutputIndex(outputs, destinationScript);
|
|
235
|
-
if (assetInputs.size > 0) {
|
|
236
|
-
if (assetOutputIndex === -1) {
|
|
237
|
-
throw new Error("Cannot assign assets: no output matches the destination address");
|
|
238
|
-
}
|
|
239
|
-
// collect all input assets and assign them to the first offchain output
|
|
240
|
-
const allAssets = new Map();
|
|
241
|
-
for (const [, assets] of assetInputs) {
|
|
242
|
-
for (const asset of assets) {
|
|
243
|
-
const existing = allAssets.get(asset.assetId) ?? 0n;
|
|
244
|
-
allAssets.set(asset.assetId, existing + asset.amount);
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
outputAssets = [];
|
|
248
|
-
for (const [assetId, amount] of allAssets) {
|
|
249
|
-
outputAssets.push({ assetId, amount });
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
const recipients = outputs.map((output, i) => ({
|
|
253
|
-
address: "", // not needed for asset packet creation
|
|
254
|
-
amount: Number(output.amount),
|
|
255
|
-
assets: i === assetOutputIndex ? outputAssets : undefined,
|
|
256
|
-
}));
|
|
257
|
-
if (outputAssets && outputAssets.length > 0) {
|
|
258
|
-
const assetPacket = createAssetPacket(assetInputs, recipients);
|
|
259
|
-
outputs.push(Extension.create([assetPacket]).txOut());
|
|
260
|
-
}
|
|
261
|
-
const message = {
|
|
262
|
-
type: "register",
|
|
263
|
-
onchain_output_indexes: onchainOutputsIndexes,
|
|
264
|
-
valid_at: Math.floor(validAt),
|
|
265
|
-
expire_at: 0,
|
|
266
|
-
cosigners_public_keys: cosignerPubKeys,
|
|
267
|
-
};
|
|
268
|
-
const proof = Intent.create(message, coins, outputs);
|
|
269
|
-
const signedProof = await identity.sign(proof);
|
|
270
|
-
return {
|
|
271
|
-
proof: base64.encode(signedProof.toPSBT()),
|
|
272
|
-
message,
|
|
273
|
-
};
|
|
274
|
-
}
|
|
275
|
-
/**
|
|
276
|
-
* Finds the index of the output whose script matches the destination script.
|
|
277
|
-
* Returns -1 if no match is found.
|
|
278
|
-
*/
|
|
279
|
-
export function findDestinationOutputIndex(outputs, destinationScript) {
|
|
280
|
-
return outputs.findIndex((o) => o.script && equalBytes(o.script, destinationScript));
|
|
281
|
-
}
|
|
282
|
-
function getDayTimestamp(timestamp) {
|
|
283
|
-
const date = new Date(timestamp);
|
|
284
|
-
date.setUTCHours(0, 0, 0, 0);
|
|
285
|
-
return date.getTime();
|
|
286
|
-
}
|
|
287
|
-
function findDelegateTapLeaf(vtxo, delegatePubkey) {
|
|
288
|
-
if (!vtxo.tapTree)
|
|
289
|
-
return undefined;
|
|
290
|
-
const pk = delegatePubkey.length === 66 ? delegatePubkey.slice(2) : delegatePubkey;
|
|
291
|
-
const vtxoScript = VtxoScript.decode(vtxo.tapTree);
|
|
292
|
-
return vtxoScript.leaves.find((tapLeaf) => {
|
|
293
|
-
const arkTapscript = decodeTapscript(scriptFromTapLeafScript(tapLeaf));
|
|
294
|
-
if (!MultisigTapscript.is(arkTapscript))
|
|
295
|
-
return false;
|
|
296
|
-
return arkTapscript.params.pubkeys.map(hex.encode).includes(pk);
|
|
297
|
-
});
|
|
298
|
-
}
|
|
299
|
-
function isAnnotated(v) {
|
|
300
|
-
return (v.tapTree !== undefined &&
|
|
301
|
-
v.forfeitTapLeafScript !== undefined &&
|
|
302
|
-
v.intentTapLeafScript !== undefined);
|
|
303
|
-
}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { runTasks, createTaskDependencies } from "../../worker/expo/taskRunner.js";
|
|
2
|
-
import { contractPollProcessor, CONTRACT_POLL_TASK_TYPE, } from "../../worker/expo/processors/index.js";
|
|
3
|
-
import { ExpoArkProvider } from "../../providers/expoArk.js";
|
|
4
|
-
import { ExpoIndexerProvider } from "../../providers/expoIndexer.js";
|
|
5
|
-
import { getRandomId } from "../utils.js";
|
|
6
|
-
function requireTaskManager() {
|
|
7
|
-
try {
|
|
8
|
-
return require("expo-task-manager");
|
|
9
|
-
}
|
|
10
|
-
catch {
|
|
11
|
-
throw new Error("expo-task-manager is required for background tasks. " +
|
|
12
|
-
"Install it with: npx expo install expo-task-manager");
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
function requireBackgroundTask() {
|
|
16
|
-
try {
|
|
17
|
-
return require("expo-background-task");
|
|
18
|
-
}
|
|
19
|
-
catch {
|
|
20
|
-
throw new Error("expo-background-task is required for background tasks. " +
|
|
21
|
-
"Install it with: npx expo install expo-background-task");
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Define the Expo background task handler.
|
|
26
|
-
*
|
|
27
|
-
* **Must be called at module/global scope** (before React mounts).
|
|
28
|
-
* Internally calls `TaskManager.defineTask()`.
|
|
29
|
-
*
|
|
30
|
-
* @example
|
|
31
|
-
* ```ts
|
|
32
|
-
* // At the top of your app entry file
|
|
33
|
-
* import { defineExpoBackgroundTask } from "@arkade-os/sdk/wallet/expo";
|
|
34
|
-
* import { AsyncStorageTaskQueue } from "@arkade-os/sdk/worker/expo";
|
|
35
|
-
* import AsyncStorage from "@react-native-async-storage/async-storage";
|
|
36
|
-
*
|
|
37
|
-
* const taskQueue = new AsyncStorageTaskQueue(AsyncStorage);
|
|
38
|
-
* defineExpoBackgroundTask("ark-background-poll", {
|
|
39
|
-
* taskQueue,
|
|
40
|
-
* walletRepository: new IndexedDBWalletRepository(),
|
|
41
|
-
* contractRepository: new IndexedDBContractRepository(),
|
|
42
|
-
* });
|
|
43
|
-
* ```
|
|
44
|
-
*/
|
|
45
|
-
export function defineExpoBackgroundTask(taskName, options) {
|
|
46
|
-
const TaskManager = requireTaskManager();
|
|
47
|
-
const BackgroundTask = requireBackgroundTask();
|
|
48
|
-
const { taskQueue, walletRepository, contractRepository, processors = [contractPollProcessor], } = options;
|
|
49
|
-
TaskManager.defineTask(taskName, async () => {
|
|
50
|
-
try {
|
|
51
|
-
const config = await taskQueue.loadConfig();
|
|
52
|
-
if (!config) {
|
|
53
|
-
// No config persisted yet — ExpoWallet.setup() hasn't run.
|
|
54
|
-
// Nothing to do.
|
|
55
|
-
return BackgroundTask.BackgroundTaskResult.Success;
|
|
56
|
-
}
|
|
57
|
-
// Reconstruct providers
|
|
58
|
-
const indexerProvider = new ExpoIndexerProvider(config.arkServerUrl);
|
|
59
|
-
const arkProvider = new ExpoArkProvider(config.arkServerUrl);
|
|
60
|
-
const deps = createTaskDependencies({
|
|
61
|
-
walletRepository,
|
|
62
|
-
contractRepository,
|
|
63
|
-
indexerProvider,
|
|
64
|
-
arkProvider,
|
|
65
|
-
});
|
|
66
|
-
await runTasks(taskQueue, processors, deps);
|
|
67
|
-
// Acknowledge outbox results (no foreground to consume them)
|
|
68
|
-
const results = await taskQueue.getResults();
|
|
69
|
-
if (results.length > 0) {
|
|
70
|
-
await taskQueue.acknowledgeResults(results.map((r) => r.id));
|
|
71
|
-
}
|
|
72
|
-
// Re-seed the contract-poll task for the next OS wake
|
|
73
|
-
const existing = await taskQueue.getTasks(CONTRACT_POLL_TASK_TYPE);
|
|
74
|
-
if (existing.length === 0) {
|
|
75
|
-
const task = {
|
|
76
|
-
id: getRandomId(),
|
|
77
|
-
type: CONTRACT_POLL_TASK_TYPE,
|
|
78
|
-
data: {},
|
|
79
|
-
createdAt: Date.now(),
|
|
80
|
-
};
|
|
81
|
-
await taskQueue.addTask(task);
|
|
82
|
-
}
|
|
83
|
-
return BackgroundTask.BackgroundTaskResult.Success;
|
|
84
|
-
}
|
|
85
|
-
catch (error) {
|
|
86
|
-
console.error("[ark-sdk] Background task failed:", error instanceof Error ? error.message : error);
|
|
87
|
-
return BackgroundTask.BackgroundTaskResult.Failed;
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Activate the OS-level background task scheduler.
|
|
93
|
-
*
|
|
94
|
-
* Call this after @see defineExpoBackgroundTask (typically inside
|
|
95
|
-
* @see ExpoWallet.setup or in a React component after wallet init).
|
|
96
|
-
*
|
|
97
|
-
* @param minimumInterval - Minimum interval in minutes (default 15).
|
|
98
|
-
*/
|
|
99
|
-
export async function registerExpoBackgroundTask(taskName, options) {
|
|
100
|
-
const BackgroundTask = requireBackgroundTask();
|
|
101
|
-
await BackgroundTask.registerTaskAsync(taskName, {
|
|
102
|
-
minimumInterval: (options?.minimumInterval ?? 15) * 60,
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Unregister the background task from the OS scheduler.
|
|
107
|
-
*/
|
|
108
|
-
export async function unregisterExpoBackgroundTask(taskName) {
|
|
109
|
-
const BackgroundTask = requireBackgroundTask();
|
|
110
|
-
await BackgroundTask.unregisterTaskAsync(taskName);
|
|
111
|
-
}
|