@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,330 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AssetManager = exports.ReadonlyAssetManager = void 0;
|
|
4
|
-
const asset_1 = require("../extension/asset");
|
|
5
|
-
const address_1 = require("../script/address");
|
|
6
|
-
const asset_2 = require("./asset");
|
|
7
|
-
const extension_1 = require("../extension");
|
|
8
|
-
const wallet_1 = require("./wallet");
|
|
9
|
-
class ReadonlyAssetManager {
|
|
10
|
-
constructor(indexer) {
|
|
11
|
-
this.indexer = indexer;
|
|
12
|
-
}
|
|
13
|
-
async getAssetDetails(assetId) {
|
|
14
|
-
// TODO: rely on db, and fallback to indexer if not found
|
|
15
|
-
return this.indexer.getAssetDetails(assetId);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
exports.ReadonlyAssetManager = ReadonlyAssetManager;
|
|
19
|
-
class AssetManager extends ReadonlyAssetManager {
|
|
20
|
-
constructor(wallet) {
|
|
21
|
-
super(wallet.indexerProvider);
|
|
22
|
-
this.wallet = wallet;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Issue a new asset.
|
|
26
|
-
* @param params - Parameters for asset issuance
|
|
27
|
-
* @param params.amount - Amount of asset units to issue
|
|
28
|
-
* @param params.controlAssetId - Optional control asset ID (for reissuable assets)
|
|
29
|
-
* @param params.metadata - Optional metadata to attach to the asset
|
|
30
|
-
* @returns Promise resolving to the Arkade transaction ID and asset ID
|
|
31
|
-
*
|
|
32
|
-
* @example
|
|
33
|
-
* ```typescript
|
|
34
|
-
* // Issue a simple non-reissuable asset
|
|
35
|
-
* const result = await wallet.assetManager.issue({ amount: 1000 });
|
|
36
|
-
* console.log('Asset ID:', result.assetId);
|
|
37
|
-
*
|
|
38
|
-
* // Issue a reissuable asset with an existing control asset
|
|
39
|
-
* const result = await wallet.assetManager.issue({
|
|
40
|
-
* amount: 1000,
|
|
41
|
-
* controlAssetId: 'existingControlAssetId'
|
|
42
|
-
* });
|
|
43
|
-
* console.log('Asset ID:', result.assetId);
|
|
44
|
-
* ```
|
|
45
|
-
*/
|
|
46
|
-
async issue(params) {
|
|
47
|
-
if (params.amount <= 0n) {
|
|
48
|
-
throw new Error(`Issue amount must be greater than 0, got ${params.amount}`);
|
|
49
|
-
}
|
|
50
|
-
const metadata = castMetadata(params.metadata);
|
|
51
|
-
const virtualCoins = await this.wallet.getVtxos({
|
|
52
|
-
withRecoverable: false,
|
|
53
|
-
});
|
|
54
|
-
const controlAssetRef = params.controlAssetId
|
|
55
|
-
? asset_1.AssetRef.fromId(asset_1.AssetId.fromString(params.controlAssetId))
|
|
56
|
-
: null;
|
|
57
|
-
const coinSelection = (0, wallet_1.selectVirtualCoins)(virtualCoins, Number(this.wallet.dustAmount));
|
|
58
|
-
let totalBtcSelected = 0n;
|
|
59
|
-
// keep track of asset changes
|
|
60
|
-
const assetChanges = new Map();
|
|
61
|
-
for (const coin of coinSelection.inputs) {
|
|
62
|
-
totalBtcSelected += BigInt(coin.value);
|
|
63
|
-
if (!coin.assets)
|
|
64
|
-
continue;
|
|
65
|
-
for (const { assetId, amount } of coin.assets) {
|
|
66
|
-
const existing = assetChanges.get(assetId) ?? 0n;
|
|
67
|
-
assetChanges.set(assetId, existing + amount);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
const groups = [];
|
|
71
|
-
// issued asset group
|
|
72
|
-
const issuedAssetOutput = asset_1.AssetOutput.create(0, params.amount);
|
|
73
|
-
const issuedAssetGroup = asset_1.AssetGroup.create(null, controlAssetRef, [], [issuedAssetOutput], metadata);
|
|
74
|
-
groups.push(issuedAssetGroup);
|
|
75
|
-
// add asset groups for each asset change
|
|
76
|
-
if (assetChanges.size > 0) {
|
|
77
|
-
const assetInputs = (0, asset_2.selectedCoinsToAssetInputs)(coinSelection.inputs);
|
|
78
|
-
for (const [assetId, amount] of assetChanges) {
|
|
79
|
-
const changeInputs = [];
|
|
80
|
-
// collect all inputs for the asset change
|
|
81
|
-
for (const [inputIndex, assets] of assetInputs) {
|
|
82
|
-
for (const asset of assets) {
|
|
83
|
-
if (asset.assetId !== assetId)
|
|
84
|
-
continue;
|
|
85
|
-
changeInputs.push(asset_1.AssetInput.create(inputIndex, asset.amount));
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
// add the change asset group
|
|
89
|
-
groups.push(asset_1.AssetGroup.create(asset_1.AssetId.fromString(assetId), null, changeInputs, [asset_1.AssetOutput.create(0, amount)], []));
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
// build transaction outputs
|
|
93
|
-
const address = await this.wallet.getAddress();
|
|
94
|
-
const outputAddress = address_1.ArkAddress.decode(address);
|
|
95
|
-
const outputs = [
|
|
96
|
-
{
|
|
97
|
-
script: outputAddress.pkScript,
|
|
98
|
-
amount: BigInt(totalBtcSelected),
|
|
99
|
-
},
|
|
100
|
-
extension_1.Extension.create([asset_1.Packet.create(groups)]).txOut(),
|
|
101
|
-
];
|
|
102
|
-
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(coinSelection.inputs, outputs);
|
|
103
|
-
return {
|
|
104
|
-
arkTxId: arkTxid,
|
|
105
|
-
assetId: asset_1.AssetId.create(arkTxid, 0).toString(),
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
/**
|
|
109
|
-
* Reissue more units of an existing asset.
|
|
110
|
-
* Requires ownership of the control asset.
|
|
111
|
-
*
|
|
112
|
-
* @param params - Parameters for asset reissuance
|
|
113
|
-
* @param params.assetId - The asset ID to reissue (control asset ID is resolved via getAssetDetails)
|
|
114
|
-
* @param params.amount - Amount of additional units to issue
|
|
115
|
-
* @returns Promise resolving to the Arkade transaction ID
|
|
116
|
-
*
|
|
117
|
-
* @example
|
|
118
|
-
* ```typescript
|
|
119
|
-
* const txid = await wallet.assetManager.reissue({
|
|
120
|
-
* assetId: 'def456...',
|
|
121
|
-
* amount: 500
|
|
122
|
-
* });
|
|
123
|
-
* ```
|
|
124
|
-
*/
|
|
125
|
-
async reissue(params) {
|
|
126
|
-
if (params.amount <= 0n) {
|
|
127
|
-
throw new Error(`Reissuance amount must be greater than 0, got ${params.amount}`);
|
|
128
|
-
}
|
|
129
|
-
const { controlAssetId } = await this.getAssetDetails(params.assetId);
|
|
130
|
-
if (!controlAssetId) {
|
|
131
|
-
throw new Error(`Asset ${params.assetId} is not reissuable`);
|
|
132
|
-
}
|
|
133
|
-
const virtualCoins = await this.wallet.getVtxos({
|
|
134
|
-
withRecoverable: false,
|
|
135
|
-
});
|
|
136
|
-
const assetChanges = new Map();
|
|
137
|
-
// select control asset inputs
|
|
138
|
-
const { selected: controlCoins } = (0, asset_2.selectCoinsWithAsset)(virtualCoins, controlAssetId, 1n);
|
|
139
|
-
let selectedCoins = [...controlCoins];
|
|
140
|
-
let assetToReissueAmount = 0n;
|
|
141
|
-
// all control inputs assets go to asset changes, including the control asset itself
|
|
142
|
-
for (const coin of controlCoins) {
|
|
143
|
-
if (!coin.assets)
|
|
144
|
-
continue;
|
|
145
|
-
for (const { assetId, amount } of coin.assets) {
|
|
146
|
-
if (assetId === params.assetId) {
|
|
147
|
-
assetToReissueAmount += amount;
|
|
148
|
-
continue;
|
|
149
|
-
}
|
|
150
|
-
const existing = assetChanges.get(assetId) ?? 0n;
|
|
151
|
-
assetChanges.set(assetId, existing + amount);
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
// select at least dust amount
|
|
155
|
-
const minBtcNeeded = Number(this.wallet.dustAmount);
|
|
156
|
-
let totalBtcSelected = selectedCoins.reduce((sum, c) => sum + c.value, 0);
|
|
157
|
-
if (totalBtcSelected < minBtcNeeded) {
|
|
158
|
-
const remainingCoins = virtualCoins.filter((c) => !selectedCoins.find((sc) => sc.txid === c.txid && sc.vout === c.vout));
|
|
159
|
-
const additional = (0, wallet_1.selectVirtualCoins)(remainingCoins, minBtcNeeded - totalBtcSelected);
|
|
160
|
-
for (const coin of additional.inputs) {
|
|
161
|
-
// additional inputs assets go to asset changes
|
|
162
|
-
if (!coin.assets)
|
|
163
|
-
continue;
|
|
164
|
-
for (const { assetId, amount } of coin.assets) {
|
|
165
|
-
if (assetId === params.assetId) {
|
|
166
|
-
assetToReissueAmount += amount;
|
|
167
|
-
continue;
|
|
168
|
-
}
|
|
169
|
-
const existing = assetChanges.get(assetId) ?? 0n;
|
|
170
|
-
assetChanges.set(assetId, existing + amount);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
selectedCoins = [...selectedCoins, ...additional.inputs];
|
|
174
|
-
totalBtcSelected += additional.inputs.reduce((sum, c) => sum + c.value, 0);
|
|
175
|
-
}
|
|
176
|
-
const assetInputs = (0, asset_2.selectedCoinsToAssetInputs)(selectedCoins);
|
|
177
|
-
// collect all inputs for the asset to reissue
|
|
178
|
-
const reissueInputs = [];
|
|
179
|
-
for (const [inputIndex, assets] of assetInputs) {
|
|
180
|
-
for (const asset of assets) {
|
|
181
|
-
if (asset.assetId !== params.assetId)
|
|
182
|
-
continue;
|
|
183
|
-
reissueInputs.push(asset_1.AssetInput.create(inputIndex, asset.amount));
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
// the total output amount of the asset to reissue = new + (optional) selected amount
|
|
187
|
-
const totalAssetAmount = assetToReissueAmount + params.amount;
|
|
188
|
-
const reissueAssetIdObj = asset_1.AssetId.fromString(params.assetId);
|
|
189
|
-
// create the reissuance asset group
|
|
190
|
-
const reissueAssetGroup = asset_1.AssetGroup.create(reissueAssetIdObj, null, reissueInputs, [asset_1.AssetOutput.create(0, totalAssetAmount)], []);
|
|
191
|
-
const groups = [reissueAssetGroup];
|
|
192
|
-
// for each asset change, create a new asset group
|
|
193
|
-
for (const [assetId, amount] of assetChanges) {
|
|
194
|
-
const changeInputs = [];
|
|
195
|
-
for (const [inputIndex, assets] of assetInputs) {
|
|
196
|
-
for (const asset of assets) {
|
|
197
|
-
if (asset.assetId !== assetId)
|
|
198
|
-
continue;
|
|
199
|
-
changeInputs.push(asset_1.AssetInput.create(inputIndex, asset.amount));
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
groups.push(asset_1.AssetGroup.create(asset_1.AssetId.fromString(assetId), null, changeInputs, [asset_1.AssetOutput.create(0, amount)], []));
|
|
203
|
-
}
|
|
204
|
-
// build transaction outputs
|
|
205
|
-
const address = await this.wallet.getAddress();
|
|
206
|
-
const outputAddress = address_1.ArkAddress.decode(address);
|
|
207
|
-
const outputs = [
|
|
208
|
-
{
|
|
209
|
-
script: outputAddress.pkScript,
|
|
210
|
-
amount: BigInt(totalBtcSelected),
|
|
211
|
-
},
|
|
212
|
-
extension_1.Extension.create([asset_1.Packet.create(groups)]).txOut(),
|
|
213
|
-
];
|
|
214
|
-
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(selectedCoins, outputs);
|
|
215
|
-
return arkTxid;
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* Burn assets.
|
|
219
|
-
* @param params - Parameters for burning
|
|
220
|
-
* @param params.assetId - The asset ID to burn
|
|
221
|
-
* @param params.amount - Amount of units to burn
|
|
222
|
-
* @returns Promise resolving to the Arkade transaction ID
|
|
223
|
-
*
|
|
224
|
-
* @example
|
|
225
|
-
* ```typescript
|
|
226
|
-
* const txid = await wallet.assetManager.burn({
|
|
227
|
-
* assetId: 'abc123...',
|
|
228
|
-
* amount: 100
|
|
229
|
-
* });
|
|
230
|
-
* ```
|
|
231
|
-
*/
|
|
232
|
-
async burn(params) {
|
|
233
|
-
if (params.amount <= 0n) {
|
|
234
|
-
throw new Error(`Burn amount must be greater than 0, got ${params.amount}`);
|
|
235
|
-
}
|
|
236
|
-
const virtualCoins = await this.wallet.getVtxos({
|
|
237
|
-
withRecoverable: false,
|
|
238
|
-
});
|
|
239
|
-
const assetChanges = new Map();
|
|
240
|
-
// select virtual outputs with the asset to burn
|
|
241
|
-
const { selected: assetCoins } = (0, asset_2.selectCoinsWithAsset)(virtualCoins, params.assetId, params.amount);
|
|
242
|
-
const selectedCoins = [...assetCoins];
|
|
243
|
-
let totalBtcSelected = 0;
|
|
244
|
-
// add the selected coins to asset changes, including the asset to burn
|
|
245
|
-
for (const coin of assetCoins) {
|
|
246
|
-
totalBtcSelected += coin.value;
|
|
247
|
-
if (!coin.assets)
|
|
248
|
-
continue;
|
|
249
|
-
for (const { assetId, amount } of coin.assets) {
|
|
250
|
-
const existing = assetChanges.get(assetId) ?? 0n;
|
|
251
|
-
assetChanges.set(assetId, existing + amount);
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
// subtract the amount to burn from the asset change
|
|
255
|
-
assetChanges.set(params.assetId, (assetChanges.get(params.assetId) ?? 0n) - params.amount);
|
|
256
|
-
const minBtcNeeded = Number(this.wallet.dustAmount);
|
|
257
|
-
// we need to ensure at least dust amount is selected
|
|
258
|
-
// if not, select additional coins
|
|
259
|
-
if (totalBtcSelected < minBtcNeeded) {
|
|
260
|
-
const remainingCoins = virtualCoins.filter((c) => !selectedCoins.find((sc) => sc.txid === c.txid && sc.vout === c.vout));
|
|
261
|
-
const additional = (0, wallet_1.selectVirtualCoins)(remainingCoins, minBtcNeeded - totalBtcSelected);
|
|
262
|
-
// additional inputs assets go to asset changes
|
|
263
|
-
for (const coin of additional.inputs) {
|
|
264
|
-
totalBtcSelected += coin.value;
|
|
265
|
-
if (!coin.assets)
|
|
266
|
-
continue;
|
|
267
|
-
for (const { assetId, amount } of coin.assets) {
|
|
268
|
-
const existing = assetChanges.get(assetId) ?? 0n;
|
|
269
|
-
assetChanges.set(assetId, existing + amount);
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
selectedCoins.push(...additional.inputs);
|
|
273
|
-
}
|
|
274
|
-
const groups = [];
|
|
275
|
-
const assetInputs = (0, asset_2.selectedCoinsToAssetInputs)(selectedCoins);
|
|
276
|
-
// for each asset, create a new asset group
|
|
277
|
-
for (const [assetId, amount] of assetChanges) {
|
|
278
|
-
const changeInputs = [];
|
|
279
|
-
for (const [inputIndex, assets] of assetInputs) {
|
|
280
|
-
for (const asset of assets) {
|
|
281
|
-
if (asset.assetId !== assetId)
|
|
282
|
-
continue;
|
|
283
|
-
changeInputs.push(asset_1.AssetInput.create(inputIndex, asset.amount));
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
groups.push(asset_1.AssetGroup.create(asset_1.AssetId.fromString(assetId), null, changeInputs, amount > 0n ? [asset_1.AssetOutput.create(0, amount)] : [], []));
|
|
287
|
-
}
|
|
288
|
-
// build transaction outputs
|
|
289
|
-
const address = await this.wallet.getAddress();
|
|
290
|
-
const outputAddress = address_1.ArkAddress.decode(address);
|
|
291
|
-
const outputs = [
|
|
292
|
-
{
|
|
293
|
-
script: outputAddress.pkScript,
|
|
294
|
-
amount: BigInt(totalBtcSelected),
|
|
295
|
-
},
|
|
296
|
-
extension_1.Extension.create([asset_1.Packet.create(groups)]).txOut(),
|
|
297
|
-
];
|
|
298
|
-
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(selectedCoins, outputs);
|
|
299
|
-
return arkTxid;
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
exports.AssetManager = AssetManager;
|
|
303
|
-
function castMetadata(metadata) {
|
|
304
|
-
if (!metadata) {
|
|
305
|
-
return [];
|
|
306
|
-
}
|
|
307
|
-
const md = [];
|
|
308
|
-
const textEncoder = new TextEncoder();
|
|
309
|
-
for (const [key, value] of Object.entries(metadata)) {
|
|
310
|
-
// convert value to bytes
|
|
311
|
-
let valueBytes;
|
|
312
|
-
if (typeof value === "string") {
|
|
313
|
-
valueBytes = textEncoder.encode(value);
|
|
314
|
-
}
|
|
315
|
-
else if (typeof value === "number") {
|
|
316
|
-
valueBytes = textEncoder.encode(String(value));
|
|
317
|
-
}
|
|
318
|
-
else if (value instanceof Uint8Array) {
|
|
319
|
-
valueBytes = value;
|
|
320
|
-
}
|
|
321
|
-
else if (value instanceof ArrayBuffer) {
|
|
322
|
-
valueBytes = new Uint8Array(value);
|
|
323
|
-
}
|
|
324
|
-
else {
|
|
325
|
-
throw new Error("Invalid metadata value type");
|
|
326
|
-
}
|
|
327
|
-
md.push(asset_1.Metadata.create(textEncoder.encode(key), valueBytes));
|
|
328
|
-
}
|
|
329
|
-
return md;
|
|
330
|
-
}
|
package/dist/cjs/wallet/asset.js
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createAssetPacket = createAssetPacket;
|
|
4
|
-
exports.selectCoinsWithAsset = selectCoinsWithAsset;
|
|
5
|
-
exports.computeAssetChange = computeAssetChange;
|
|
6
|
-
exports.selectedCoinsToAssetInputs = selectedCoinsToAssetInputs;
|
|
7
|
-
const asset_1 = require("../extension/asset");
|
|
8
|
-
/**
|
|
9
|
-
* Creates an asset packet from asset inputs and receivers.
|
|
10
|
-
* Groups inputs and outputs by asset ID and creates the Packet object
|
|
11
|
-
* @param assetInputs - map input index -> assets
|
|
12
|
-
* @param receivers - array of recipients with their asset allocations
|
|
13
|
-
* @param changeReceiver - (optional) change receiver containing remaining assets
|
|
14
|
-
* @returns packet containing all asset groups
|
|
15
|
-
*/
|
|
16
|
-
function createAssetPacket(assetInputs, receivers, changeReceiver) {
|
|
17
|
-
// map inputs by asset id
|
|
18
|
-
const inputsByAssetId = new Map();
|
|
19
|
-
for (const [inputIndex, assets] of assetInputs) {
|
|
20
|
-
for (const asset of assets) {
|
|
21
|
-
const existing = inputsByAssetId.get(asset.assetId);
|
|
22
|
-
inputsByAssetId.set(asset.assetId, [
|
|
23
|
-
...(existing ?? []),
|
|
24
|
-
asset_1.AssetInput.create(inputIndex, asset.amount),
|
|
25
|
-
]);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
// map outputs by asset id
|
|
29
|
-
const outputsByAssetId = new Map();
|
|
30
|
-
// track tx output index
|
|
31
|
-
let outputIndex = 0;
|
|
32
|
-
for (const receiver of receivers) {
|
|
33
|
-
if (receiver.assets) {
|
|
34
|
-
for (const asset of receiver.assets) {
|
|
35
|
-
const existing = outputsByAssetId.get(asset.assetId);
|
|
36
|
-
outputsByAssetId.set(asset.assetId, [
|
|
37
|
-
...(existing ?? []),
|
|
38
|
-
asset_1.AssetOutput.create(outputIndex, asset.amount),
|
|
39
|
-
]);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
outputIndex++;
|
|
43
|
-
}
|
|
44
|
-
// add change receiver assets if present
|
|
45
|
-
if (changeReceiver?.assets) {
|
|
46
|
-
for (const asset of changeReceiver.assets) {
|
|
47
|
-
const existing = outputsByAssetId.get(asset.assetId);
|
|
48
|
-
outputsByAssetId.set(asset.assetId, [
|
|
49
|
-
...(existing ?? []),
|
|
50
|
-
asset_1.AssetOutput.create(outputIndex, asset.amount),
|
|
51
|
-
]);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
const groups = [];
|
|
55
|
-
// get all unique asset ids from both inputs and outputs
|
|
56
|
-
const allAssetIds = new Set([
|
|
57
|
-
...inputsByAssetId.keys(),
|
|
58
|
-
...outputsByAssetId.keys(),
|
|
59
|
-
]);
|
|
60
|
-
for (const assetIdStr of allAssetIds) {
|
|
61
|
-
const inputs = inputsByAssetId.get(assetIdStr);
|
|
62
|
-
const outputs = outputsByAssetId.get(assetIdStr);
|
|
63
|
-
const assetId = asset_1.AssetId.fromString(assetIdStr);
|
|
64
|
-
const group = asset_1.AssetGroup.create(assetId, null, inputs ?? [], outputs ?? [], []);
|
|
65
|
-
groups.push(group);
|
|
66
|
-
}
|
|
67
|
-
return asset_1.Packet.create(groups);
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Selects coins that contain a specific asset.
|
|
71
|
-
* Returns coins sorted by amount (smallest first for better coin selection).
|
|
72
|
-
*/
|
|
73
|
-
function selectCoinsWithAsset(coins, assetId, requiredAmount) {
|
|
74
|
-
// filter only coins that have the specified asset
|
|
75
|
-
const coinsWithAsset = coins.filter((coin) => coin.assets?.some((a) => a.assetId === assetId));
|
|
76
|
-
// sort by asset amount (smallest first for better selection)
|
|
77
|
-
coinsWithAsset.sort((a, b) => {
|
|
78
|
-
const amountA = a.assets?.find((asset) => asset.assetId === assetId)?.amount ?? 0n;
|
|
79
|
-
const amountB = b.assets?.find((asset) => asset.assetId === assetId)?.amount ?? 0n;
|
|
80
|
-
// Array.sort callback returns number; reduce the bigint diff to
|
|
81
|
-
// -1/0/1 (the only thing sort actually consults).
|
|
82
|
-
return amountA < amountB ? -1 : amountA > amountB ? 1 : 0;
|
|
83
|
-
});
|
|
84
|
-
const selected = [];
|
|
85
|
-
let totalAssetAmount = 0n;
|
|
86
|
-
for (const coin of coinsWithAsset) {
|
|
87
|
-
if (totalAssetAmount >= requiredAmount)
|
|
88
|
-
break;
|
|
89
|
-
selected.push(coin);
|
|
90
|
-
const assetAmount = coin.assets?.find((a) => a.assetId === assetId)?.amount ?? 0n;
|
|
91
|
-
totalAssetAmount += assetAmount;
|
|
92
|
-
}
|
|
93
|
-
if (totalAssetAmount < requiredAmount) {
|
|
94
|
-
throw new Error(`Insufficient asset balance: have ${totalAssetAmount}, need ${requiredAmount}`);
|
|
95
|
-
}
|
|
96
|
-
return { selected, totalAssetAmount };
|
|
97
|
-
}
|
|
98
|
-
function computeAssetChange(inputAssets, outputAssets) {
|
|
99
|
-
const change = new Map();
|
|
100
|
-
for (const [assetId, inputAmount] of inputAssets) {
|
|
101
|
-
const outputAmount = outputAssets.get(assetId) ?? 0n;
|
|
102
|
-
const changeAmount = inputAmount - outputAmount;
|
|
103
|
-
if (changeAmount > 0n) {
|
|
104
|
-
change.set(assetId, changeAmount);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
return change;
|
|
108
|
-
}
|
|
109
|
-
function selectedCoinsToAssetInputs(selectedCoins) {
|
|
110
|
-
const assetInputs = new Map();
|
|
111
|
-
for (let inputIndex = 0; inputIndex < selectedCoins.length; inputIndex++) {
|
|
112
|
-
const coin = selectedCoins[inputIndex];
|
|
113
|
-
if (!coin.assets || coin.assets.length === 0) {
|
|
114
|
-
continue;
|
|
115
|
-
}
|
|
116
|
-
assetInputs.set(inputIndex, coin.assets);
|
|
117
|
-
}
|
|
118
|
-
return assetInputs;
|
|
119
|
-
}
|
package/dist/cjs/wallet/batch.js
DELETED
|
@@ -1,183 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Batch = void 0;
|
|
4
|
-
const ark_1 = require("../providers/ark");
|
|
5
|
-
const txTree_1 = require("../tree/txTree");
|
|
6
|
-
const base_1 = require("@scure/base");
|
|
7
|
-
/**
|
|
8
|
-
* Batch namespace provides utilities for joining and processing batch session.
|
|
9
|
-
* The batch settlement process involves multiple events, this namespace provides abstractions and types to handle them.
|
|
10
|
-
* @see https://docs.arkadeos.com/learn/pillars/batch-swaps
|
|
11
|
-
* @example
|
|
12
|
-
* ```typescript
|
|
13
|
-
* // use wallet handler or create a custom one
|
|
14
|
-
* const handler = wallet.createBatchHandler(intentId, inputs, expectedRecipients, musig2session);
|
|
15
|
-
*
|
|
16
|
-
* const abortController = new AbortController();
|
|
17
|
-
* // Get event stream from the Arkade provider
|
|
18
|
-
* const eventStream = arkProvider.getEventStream(
|
|
19
|
-
* abortController.signal,
|
|
20
|
-
* ['your-topic-1', 'your-topic-2']
|
|
21
|
-
* );
|
|
22
|
-
*
|
|
23
|
-
* // Join the batch and process events
|
|
24
|
-
* try {
|
|
25
|
-
* const commitmentTxid = await Batch.join(eventStream, handler);
|
|
26
|
-
* console.log('Batch completed with commitment:', commitmentTxid);
|
|
27
|
-
* } catch (error) {
|
|
28
|
-
* console.error('Batch processing failed:', error);
|
|
29
|
-
* } finally {
|
|
30
|
-
* abortController.abort();
|
|
31
|
-
* }
|
|
32
|
-
* ```
|
|
33
|
-
*/
|
|
34
|
-
var Batch;
|
|
35
|
-
(function (Batch) {
|
|
36
|
-
// State machine steps for batch session
|
|
37
|
-
let Step;
|
|
38
|
-
(function (Step) {
|
|
39
|
-
Step["Start"] = "start";
|
|
40
|
-
Step["BatchStarted"] = "batch_started";
|
|
41
|
-
Step["TreeSigningStarted"] = "tree_signing_started";
|
|
42
|
-
Step["TreeNoncesAggregated"] = "tree_nonces_aggregated";
|
|
43
|
-
Step["BatchFinalization"] = "batch_finalization";
|
|
44
|
-
})(Step || (Step = {}));
|
|
45
|
-
/**
|
|
46
|
-
* Start the state machine that will process the batch events and join a batch.
|
|
47
|
-
* @param eventIterator - The events stream to process.
|
|
48
|
-
* @param handler - How to react to events.
|
|
49
|
-
* @param options - Options.
|
|
50
|
-
*/
|
|
51
|
-
async function join(eventIterator, handler, options = {}) {
|
|
52
|
-
const { abortController, skipVtxoTreeSigning = false, eventCallback, } = options;
|
|
53
|
-
let step = Step.Start;
|
|
54
|
-
// keep track of tree transactions as they arrive
|
|
55
|
-
const flatVtxoTree = [];
|
|
56
|
-
const flatConnectorTree = [];
|
|
57
|
-
// once everything is collected, the TxTree objects are created
|
|
58
|
-
let vtxoTree = undefined;
|
|
59
|
-
let connectorTree = undefined;
|
|
60
|
-
for await (const event of eventIterator) {
|
|
61
|
-
if (abortController?.signal.aborted) {
|
|
62
|
-
throw new Error("canceled");
|
|
63
|
-
}
|
|
64
|
-
if (eventCallback) {
|
|
65
|
-
// don't wait for the callback to complete and ignore errors
|
|
66
|
-
eventCallback(event).catch(() => { });
|
|
67
|
-
}
|
|
68
|
-
switch (event.type) {
|
|
69
|
-
case ark_1.SettlementEventType.BatchStarted: {
|
|
70
|
-
const e = event;
|
|
71
|
-
const { skip } = await handler.onBatchStarted(e);
|
|
72
|
-
if (!skip) {
|
|
73
|
-
step = Step.BatchStarted;
|
|
74
|
-
if (skipVtxoTreeSigning) {
|
|
75
|
-
// skip TxTree events and musig2 signatures and nonces
|
|
76
|
-
step = Step.TreeNoncesAggregated;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
continue;
|
|
80
|
-
}
|
|
81
|
-
case ark_1.SettlementEventType.BatchFinalized: {
|
|
82
|
-
if (step !== Step.BatchFinalization) {
|
|
83
|
-
continue;
|
|
84
|
-
}
|
|
85
|
-
if (handler.onBatchFinalized) {
|
|
86
|
-
await handler.onBatchFinalized(event);
|
|
87
|
-
}
|
|
88
|
-
return event.commitmentTxid;
|
|
89
|
-
}
|
|
90
|
-
case ark_1.SettlementEventType.BatchFailed: {
|
|
91
|
-
if (handler.onBatchFailed) {
|
|
92
|
-
await handler.onBatchFailed(event);
|
|
93
|
-
continue;
|
|
94
|
-
}
|
|
95
|
-
throw new Error(event.reason);
|
|
96
|
-
}
|
|
97
|
-
case ark_1.SettlementEventType.TreeTx: {
|
|
98
|
-
if (step !== Step.BatchStarted &&
|
|
99
|
-
step !== Step.TreeNoncesAggregated) {
|
|
100
|
-
continue;
|
|
101
|
-
}
|
|
102
|
-
// batchIndex 0 = virtual output tree, batchIndex 1 = connector tree
|
|
103
|
-
if (event.batchIndex === 0) {
|
|
104
|
-
flatVtxoTree.push(event.chunk);
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
flatConnectorTree.push(event.chunk);
|
|
108
|
-
}
|
|
109
|
-
if (handler.onTreeTxEvent) {
|
|
110
|
-
await handler.onTreeTxEvent(event);
|
|
111
|
-
}
|
|
112
|
-
continue;
|
|
113
|
-
}
|
|
114
|
-
case ark_1.SettlementEventType.TreeSignature: {
|
|
115
|
-
if (step !== Step.TreeNoncesAggregated) {
|
|
116
|
-
continue;
|
|
117
|
-
}
|
|
118
|
-
if (!vtxoTree) {
|
|
119
|
-
throw new Error("vtxo tree not initialized");
|
|
120
|
-
}
|
|
121
|
-
// push signature to the virtual output tree
|
|
122
|
-
const tapKeySig = base_1.hex.decode(event.signature);
|
|
123
|
-
vtxoTree.update(event.txid, (tx) => {
|
|
124
|
-
tx.updateInput(0, {
|
|
125
|
-
tapKeySig,
|
|
126
|
-
});
|
|
127
|
-
});
|
|
128
|
-
if (handler.onTreeSignatureEvent) {
|
|
129
|
-
await handler.onTreeSignatureEvent(event);
|
|
130
|
-
}
|
|
131
|
-
continue;
|
|
132
|
-
}
|
|
133
|
-
case ark_1.SettlementEventType.TreeSigningStarted: {
|
|
134
|
-
if (step !== Step.BatchStarted) {
|
|
135
|
-
continue;
|
|
136
|
-
}
|
|
137
|
-
// create virtual output tree from collected chunks
|
|
138
|
-
vtxoTree = txTree_1.TxTree.create(flatVtxoTree);
|
|
139
|
-
const { skip } = await handler.onTreeSigningStarted(event, vtxoTree);
|
|
140
|
-
if (!skip) {
|
|
141
|
-
step = Step.TreeSigningStarted;
|
|
142
|
-
}
|
|
143
|
-
continue;
|
|
144
|
-
}
|
|
145
|
-
case ark_1.SettlementEventType.TreeNonces: {
|
|
146
|
-
if (step !== Step.TreeSigningStarted) {
|
|
147
|
-
continue;
|
|
148
|
-
}
|
|
149
|
-
const { fullySigned } = await handler.onTreeNonces(event);
|
|
150
|
-
if (fullySigned) {
|
|
151
|
-
step = Step.TreeNoncesAggregated;
|
|
152
|
-
}
|
|
153
|
-
continue;
|
|
154
|
-
}
|
|
155
|
-
case ark_1.SettlementEventType.BatchFinalization: {
|
|
156
|
-
if (step !== Step.TreeNoncesAggregated) {
|
|
157
|
-
continue;
|
|
158
|
-
}
|
|
159
|
-
// Build virtual output tree if it hasn't been built yet
|
|
160
|
-
if (!vtxoTree && flatVtxoTree.length > 0) {
|
|
161
|
-
vtxoTree = txTree_1.TxTree.create(flatVtxoTree);
|
|
162
|
-
}
|
|
163
|
-
if (!vtxoTree && !skipVtxoTreeSigning) {
|
|
164
|
-
throw new Error("vtxo tree not initialized");
|
|
165
|
-
}
|
|
166
|
-
// Build connector tree if we have chunks
|
|
167
|
-
if (flatConnectorTree.length > 0) {
|
|
168
|
-
connectorTree = txTree_1.TxTree.create(flatConnectorTree);
|
|
169
|
-
}
|
|
170
|
-
await handler.onBatchFinalization(event, vtxoTree, connectorTree);
|
|
171
|
-
step = Step.BatchFinalization;
|
|
172
|
-
continue;
|
|
173
|
-
}
|
|
174
|
-
default:
|
|
175
|
-
// unknown event type, continue
|
|
176
|
-
continue;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
// iterator closed without finalization, something went wrong
|
|
180
|
-
throw new Error("event stream closed");
|
|
181
|
-
}
|
|
182
|
-
Batch.join = join;
|
|
183
|
-
})(Batch || (exports.Batch = Batch = {}));
|