@arkade-os/sdk 0.4.26 → 0.4.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +36 -125
- package/dist/adapters/asyncStorage.cjs +48 -0
- package/dist/adapters/asyncStorage.cjs.map +1 -0
- package/dist/adapters/asyncStorage.d.cts +16 -0
- package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
- package/dist/adapters/asyncStorage.js +46 -0
- package/dist/adapters/asyncStorage.js.map +1 -0
- package/dist/adapters/expo.cjs +19 -0
- package/dist/adapters/expo.cjs.map +1 -0
- package/dist/adapters/expo.d.cts +48 -0
- package/dist/adapters/expo.d.ts +48 -0
- package/dist/adapters/expo.js +6 -0
- package/dist/adapters/expo.js.map +1 -0
- package/dist/adapters/fileSystem.cjs +116 -0
- package/dist/adapters/fileSystem.cjs.map +1 -0
- package/dist/adapters/fileSystem.d.cts +17 -0
- package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
- package/dist/adapters/fileSystem.js +93 -0
- package/dist/adapters/fileSystem.js.map +1 -0
- package/dist/adapters/indexedDB.cjs +103 -0
- package/dist/adapters/indexedDB.cjs.map +1 -0
- package/dist/adapters/indexedDB.d.cts +18 -0
- package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
- package/dist/adapters/indexedDB.js +101 -0
- package/dist/adapters/indexedDB.js.map +1 -0
- package/dist/adapters/localStorage.cjs +50 -0
- package/dist/adapters/localStorage.cjs.map +1 -0
- package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
- package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
- package/dist/adapters/localStorage.js +48 -0
- package/dist/adapters/localStorage.js.map +1 -0
- package/dist/ark-TZ1gXAXU.d.cts +3880 -0
- package/dist/ark-TZ1gXAXU.d.ts +3880 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
- package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-5PG7DV7A.cjs +805 -0
- package/dist/chunk-5PG7DV7A.cjs.map +1 -0
- package/dist/chunk-A3EMF7RN.js +95 -0
- package/dist/chunk-A3EMF7RN.js.map +1 -0
- package/dist/chunk-ADV27S4N.cjs +2701 -0
- package/dist/chunk-ADV27S4N.cjs.map +1 -0
- package/dist/chunk-BQLHADL7.js +13805 -0
- package/dist/chunk-BQLHADL7.js.map +1 -0
- package/dist/chunk-CFZMTDWI.js +209 -0
- package/dist/chunk-CFZMTDWI.js.map +1 -0
- package/dist/chunk-FG5ACJJW.cjs +212 -0
- package/dist/chunk-FG5ACJJW.cjs.map +1 -0
- package/dist/chunk-HW3JJ323.js +768 -0
- package/dist/chunk-HW3JJ323.js.map +1 -0
- package/dist/chunk-I3DGUUCT.cjs +838 -0
- package/dist/chunk-I3DGUUCT.cjs.map +1 -0
- package/dist/chunk-IPX2R7FR.cjs +100 -0
- package/dist/chunk-IPX2R7FR.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-T64LAI7L.js +829 -0
- package/dist/chunk-T64LAI7L.js.map +1 -0
- package/dist/chunk-ZBUDLTBO.js +2671 -0
- package/dist/chunk-ZBUDLTBO.js.map +1 -0
- package/dist/chunk-ZLO6NETT.cjs +13910 -0
- package/dist/chunk-ZLO6NETT.cjs.map +1 -0
- package/dist/contracts/handlers/index.cjs +26 -0
- package/dist/contracts/handlers/index.cjs.map +1 -0
- package/dist/contracts/handlers/index.d.cts +7 -0
- package/dist/contracts/handlers/index.d.ts +7 -0
- package/dist/contracts/handlers/index.js +5 -0
- package/dist/contracts/handlers/index.js.map +1 -0
- package/dist/delegate-BFZs69hp.d.cts +84 -0
- package/dist/delegate-aaVGfWsV.d.ts +84 -0
- package/dist/index-B22cA64m.d.cts +199 -0
- package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
- package/dist/index-C0IanN1m.d.ts +11 -0
- package/dist/index-NDla_UoJ.d.ts +199 -0
- package/dist/index.cjs +480 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3343 -0
- package/dist/index.d.ts +3343 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/repositories/realm/index.cjs +513 -0
- package/dist/repositories/realm/index.cjs.map +1 -0
- package/dist/repositories/realm/index.d.cts +217 -0
- package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
- package/dist/repositories/realm/index.js +507 -0
- package/dist/repositories/realm/index.js.map +1 -0
- package/dist/repositories/sqlite/index.cjs +588 -0
- package/dist/repositories/sqlite/index.cjs.map +1 -0
- package/dist/repositories/sqlite/index.d.cts +118 -0
- package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
- package/dist/repositories/sqlite/index.js +585 -0
- package/dist/repositories/sqlite/index.js.map +1 -0
- package/dist/taskRunner-C6Ff4OaU.d.cts +114 -0
- package/dist/taskRunner-yvPN8Z0K.d.ts +114 -0
- package/dist/wallet/expo/background.cjs +93 -0
- package/dist/wallet/expo/background.cjs.map +1 -0
- package/dist/wallet/expo/background.d.cts +84 -0
- package/dist/wallet/expo/background.d.ts +84 -0
- package/dist/wallet/expo/background.js +68 -0
- package/dist/wallet/expo/background.js.map +1 -0
- package/dist/wallet/expo/index.cjs +171 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +122 -0
- package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
- package/dist/wallet/expo/index.js +169 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-AF-p-OWj.d.cts +774 -0
- package/dist/wallet-D9NBRqvC.d.ts +774 -0
- package/dist/worker/expo/index.cjs +140 -0
- package/dist/worker/expo/index.cjs.map +1 -0
- package/dist/worker/expo/index.d.cts +29 -0
- package/dist/worker/expo/index.d.ts +29 -0
- package/dist/worker/expo/index.js +121 -0
- package/dist/worker/expo/index.js.map +1 -0
- package/package.json +110 -76
- package/dist/cjs/adapters/asyncStorage.js +0 -5
- package/dist/cjs/adapters/expo.js +0 -8
- package/dist/cjs/adapters/fileSystem.js +0 -5
- package/dist/cjs/adapters/indexedDB.js +0 -5
- package/dist/cjs/adapters/localStorage.js +0 -5
- package/dist/cjs/arkfee/celenv.js +0 -43
- package/dist/cjs/arkfee/estimator.js +0 -143
- package/dist/cjs/arkfee/index.js +0 -5
- package/dist/cjs/arkfee/types.js +0 -26
- package/dist/cjs/arknote/index.js +0 -128
- package/dist/cjs/bip322/index.js +0 -270
- package/dist/cjs/contracts/arkcontract.js +0 -147
- package/dist/cjs/contracts/contractManager.js +0 -629
- package/dist/cjs/contracts/contractWatcher.js +0 -598
- package/dist/cjs/contracts/handlers/default.js +0 -93
- package/dist/cjs/contracts/handlers/delegate.js +0 -90
- package/dist/cjs/contracts/handlers/helpers.js +0 -115
- package/dist/cjs/contracts/handlers/index.js +0 -19
- package/dist/cjs/contracts/handlers/registry.js +0 -89
- package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
- package/dist/cjs/contracts/index.js +0 -41
- package/dist/cjs/contracts/types.js +0 -2
- package/dist/cjs/contracts/vtxoOwnership.js +0 -78
- package/dist/cjs/extension/asset/assetGroup.js +0 -228
- package/dist/cjs/extension/asset/assetId.js +0 -152
- package/dist/cjs/extension/asset/assetInput.js +0 -222
- package/dist/cjs/extension/asset/assetOutput.js +0 -174
- package/dist/cjs/extension/asset/assetRef.js +0 -148
- package/dist/cjs/extension/asset/index.js +0 -23
- package/dist/cjs/extension/asset/metadata.js +0 -187
- package/dist/cjs/extension/asset/packet.js +0 -114
- package/dist/cjs/extension/asset/types.js +0 -22
- package/dist/cjs/extension/asset/utils.js +0 -105
- package/dist/cjs/extension/index.js +0 -254
- package/dist/cjs/extension/packet.js +0 -20
- package/dist/cjs/forfeit.js +0 -45
- package/dist/cjs/identity/descriptor.js +0 -169
- package/dist/cjs/identity/descriptorProvider.js +0 -2
- package/dist/cjs/identity/hdCapableIdentity.js +0 -2
- package/dist/cjs/identity/index.js +0 -38
- package/dist/cjs/identity/seedIdentity.js +0 -461
- package/dist/cjs/identity/serialize.js +0 -171
- package/dist/cjs/identity/singleKey.js +0 -126
- package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
- package/dist/cjs/index.js +0 -200
- package/dist/cjs/intent/index.js +0 -259
- package/dist/cjs/musig2/index.js +0 -11
- package/dist/cjs/musig2/keys.js +0 -57
- package/dist/cjs/musig2/nonces.js +0 -48
- package/dist/cjs/musig2/sign.js +0 -102
- package/dist/cjs/networks.js +0 -26
- package/dist/cjs/package.json +0 -3
- package/dist/cjs/providers/ark.js +0 -577
- package/dist/cjs/providers/delegator.js +0 -85
- package/dist/cjs/providers/electrum.js +0 -869
- package/dist/cjs/providers/errors.js +0 -59
- package/dist/cjs/providers/expoArk.js +0 -82
- package/dist/cjs/providers/expoIndexer.js +0 -111
- package/dist/cjs/providers/expoUtils.js +0 -124
- package/dist/cjs/providers/indexer.js +0 -630
- package/dist/cjs/providers/onchain.js +0 -262
- package/dist/cjs/providers/utils.js +0 -121
- package/dist/cjs/repositories/contractRepository.js +0 -2
- package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
- package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
- package/dist/cjs/repositories/index.js +0 -34
- package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
- package/dist/cjs/repositories/indexedDB/db.js +0 -19
- package/dist/cjs/repositories/indexedDB/manager.js +0 -100
- package/dist/cjs/repositories/indexedDB/schema.js +0 -204
- package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
- package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
- package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
- package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
- package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
- package/dist/cjs/repositories/realm/contractRepository.js +0 -116
- package/dist/cjs/repositories/realm/index.js +0 -11
- package/dist/cjs/repositories/realm/schemas.js +0 -157
- package/dist/cjs/repositories/realm/types.js +0 -7
- package/dist/cjs/repositories/realm/walletRepository.js +0 -305
- package/dist/cjs/repositories/scriptFromAddress.js +0 -16
- package/dist/cjs/repositories/serialization.js +0 -82
- package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
- package/dist/cjs/repositories/sqlite/index.js +0 -7
- package/dist/cjs/repositories/sqlite/types.js +0 -2
- package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
- package/dist/cjs/repositories/walletRepository.js +0 -2
- package/dist/cjs/script/address.js +0 -108
- package/dist/cjs/script/base.js +0 -185
- package/dist/cjs/script/default.js +0 -57
- package/dist/cjs/script/delegate.js +0 -53
- package/dist/cjs/script/tapscript.js +0 -619
- package/dist/cjs/script/vhtlc.js +0 -170
- package/dist/cjs/storage/asyncStorage.js +0 -50
- package/dist/cjs/storage/fileSystem.js +0 -141
- package/dist/cjs/storage/inMemory.js +0 -24
- package/dist/cjs/storage/index.js +0 -2
- package/dist/cjs/storage/indexedDB.js +0 -101
- package/dist/cjs/storage/localStorage.js +0 -51
- package/dist/cjs/tree/signingSession.js +0 -229
- package/dist/cjs/tree/txTree.js +0 -192
- package/dist/cjs/tree/validation.js +0 -107
- package/dist/cjs/utils/anchor.js +0 -35
- package/dist/cjs/utils/arkTransaction.js +0 -271
- package/dist/cjs/utils/bip21.js +0 -127
- package/dist/cjs/utils/syncCursors.js +0 -128
- package/dist/cjs/utils/timelock.js +0 -59
- package/dist/cjs/utils/transaction.js +0 -28
- package/dist/cjs/utils/transactionHistory.js +0 -183
- package/dist/cjs/utils/txSizeEstimator.js +0 -132
- package/dist/cjs/utils/unknownFields.js +0 -174
- package/dist/cjs/wallet/asset-manager.js +0 -330
- package/dist/cjs/wallet/asset.js +0 -119
- package/dist/cjs/wallet/batch.js +0 -183
- package/dist/cjs/wallet/delegator.js +0 -302
- package/dist/cjs/wallet/expo/background.js +0 -116
- package/dist/cjs/wallet/expo/index.js +0 -9
- package/dist/cjs/wallet/expo/wallet.js +0 -230
- package/dist/cjs/wallet/hdDescriptorProvider.js +0 -159
- package/dist/cjs/wallet/index.js +0 -82
- package/dist/cjs/wallet/onchain.js +0 -290
- package/dist/cjs/wallet/ramps.js +0 -216
- package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
- package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1173
- package/dist/cjs/wallet/unroll.js +0 -289
- package/dist/cjs/wallet/utils.js +0 -111
- package/dist/cjs/wallet/validation.js +0 -154
- package/dist/cjs/wallet/vtxo-manager.js +0 -1142
- package/dist/cjs/wallet/wallet.js +0 -2049
- package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
- package/dist/cjs/worker/browser/utils.js +0 -67
- package/dist/cjs/worker/errors.js +0 -16
- package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
- package/dist/cjs/worker/expo/index.js +0 -13
- package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
- package/dist/cjs/worker/expo/processors/index.js +0 -6
- package/dist/cjs/worker/expo/taskQueue.js +0 -41
- package/dist/cjs/worker/expo/taskRunner.js +0 -73
- package/dist/cjs/worker/messageBus.js +0 -473
- package/dist/esm/adapters/asyncStorage.js +0 -1
- package/dist/esm/adapters/expo.js +0 -3
- package/dist/esm/adapters/fileSystem.js +0 -1
- package/dist/esm/adapters/indexedDB.js +0 -1
- package/dist/esm/adapters/localStorage.js +0 -1
- package/dist/esm/arkfee/celenv.js +0 -40
- package/dist/esm/arkfee/estimator.js +0 -139
- package/dist/esm/arkfee/index.js +0 -1
- package/dist/esm/arkfee/types.js +0 -22
- package/dist/esm/arknote/index.js +0 -124
- package/dist/esm/bip322/index.js +0 -267
- package/dist/esm/contracts/arkcontract.js +0 -140
- package/dist/esm/contracts/contractManager.js +0 -625
- package/dist/esm/contracts/contractWatcher.js +0 -594
- package/dist/esm/contracts/handlers/default.js +0 -90
- package/dist/esm/contracts/handlers/delegate.js +0 -87
- package/dist/esm/contracts/handlers/helpers.js +0 -110
- package/dist/esm/contracts/handlers/index.js +0 -12
- package/dist/esm/contracts/handlers/registry.js +0 -86
- package/dist/esm/contracts/handlers/vhtlc.js +0 -191
- package/dist/esm/contracts/index.js +0 -13
- package/dist/esm/contracts/types.js +0 -1
- package/dist/esm/contracts/vtxoOwnership.js +0 -69
- package/dist/esm/extension/asset/assetGroup.js +0 -224
- package/dist/esm/extension/asset/assetId.js +0 -148
- package/dist/esm/extension/asset/assetInput.js +0 -217
- package/dist/esm/extension/asset/assetOutput.js +0 -169
- package/dist/esm/extension/asset/assetRef.js +0 -144
- package/dist/esm/extension/asset/index.js +0 -8
- package/dist/esm/extension/asset/metadata.js +0 -182
- package/dist/esm/extension/asset/packet.js +0 -110
- package/dist/esm/extension/asset/types.js +0 -19
- package/dist/esm/extension/asset/utils.js +0 -99
- package/dist/esm/extension/index.js +0 -248
- package/dist/esm/extension/packet.js +0 -16
- package/dist/esm/forfeit.js +0 -41
- package/dist/esm/identity/descriptor.js +0 -161
- package/dist/esm/identity/descriptorProvider.js +0 -1
- package/dist/esm/identity/hdCapableIdentity.js +0 -1
- package/dist/esm/identity/index.js +0 -12
- package/dist/esm/identity/seedIdentity.js +0 -453
- package/dist/esm/identity/serialize.js +0 -164
- package/dist/esm/identity/singleKey.js +0 -121
- package/dist/esm/identity/staticDescriptorProvider.js +0 -61
- package/dist/esm/index.js +0 -87
- package/dist/esm/intent/index.js +0 -255
- package/dist/esm/musig2/index.js +0 -3
- package/dist/esm/musig2/keys.js +0 -21
- package/dist/esm/musig2/nonces.js +0 -11
- package/dist/esm/musig2/sign.js +0 -63
- package/dist/esm/networks.js +0 -22
- package/dist/esm/package.json +0 -3
- package/dist/esm/providers/ark.js +0 -572
- package/dist/esm/providers/delegator.js +0 -81
- package/dist/esm/providers/electrum.js +0 -864
- package/dist/esm/providers/errors.js +0 -54
- package/dist/esm/providers/expoArk.js +0 -78
- package/dist/esm/providers/expoIndexer.js +0 -107
- package/dist/esm/providers/expoUtils.js +0 -87
- package/dist/esm/providers/indexer.js +0 -626
- package/dist/esm/providers/onchain.js +0 -258
- package/dist/esm/providers/utils.js +0 -117
- package/dist/esm/repositories/contractRepository.js +0 -1
- package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
- package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
- package/dist/esm/repositories/index.js +0 -10
- package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
- package/dist/esm/repositories/indexedDB/db.js +0 -4
- package/dist/esm/repositories/indexedDB/manager.js +0 -95
- package/dist/esm/repositories/indexedDB/schema.js +0 -199
- package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
- package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
- package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
- package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
- package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
- package/dist/esm/repositories/realm/contractRepository.js +0 -112
- package/dist/esm/repositories/realm/index.js +0 -3
- package/dist/esm/repositories/realm/schemas.js +0 -153
- package/dist/esm/repositories/realm/types.js +0 -6
- package/dist/esm/repositories/realm/walletRepository.js +0 -301
- package/dist/esm/repositories/scriptFromAddress.js +0 -13
- package/dist/esm/repositories/serialization.js +0 -67
- package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
- package/dist/esm/repositories/sqlite/index.js +0 -2
- package/dist/esm/repositories/sqlite/types.js +0 -1
- package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
- package/dist/esm/repositories/walletRepository.js +0 -1
- package/dist/esm/script/address.js +0 -104
- package/dist/esm/script/base.js +0 -179
- package/dist/esm/script/default.js +0 -54
- package/dist/esm/script/delegate.js +0 -50
- package/dist/esm/script/tapscript.js +0 -615
- package/dist/esm/script/vhtlc.js +0 -167
- package/dist/esm/storage/asyncStorage.js +0 -46
- package/dist/esm/storage/fileSystem.js +0 -104
- package/dist/esm/storage/inMemory.js +0 -20
- package/dist/esm/storage/index.js +0 -1
- package/dist/esm/storage/indexedDB.js +0 -97
- package/dist/esm/storage/localStorage.js +0 -47
- package/dist/esm/tree/signingSession.js +0 -191
- package/dist/esm/tree/txTree.js +0 -188
- package/dist/esm/tree/validation.js +0 -101
- package/dist/esm/utils/anchor.js +0 -31
- package/dist/esm/utils/arkTransaction.js +0 -264
- package/dist/esm/utils/bip21.js +0 -123
- package/dist/esm/utils/syncCursors.js +0 -119
- package/dist/esm/utils/timelock.js +0 -22
- package/dist/esm/utils/transaction.js +0 -24
- package/dist/esm/utils/transactionHistory.js +0 -180
- package/dist/esm/utils/txSizeEstimator.js +0 -128
- package/dist/esm/utils/unknownFields.js +0 -169
- package/dist/esm/wallet/asset-manager.js +0 -325
- package/dist/esm/wallet/asset.js +0 -113
- package/dist/esm/wallet/batch.js +0 -180
- package/dist/esm/wallet/delegator.js +0 -297
- package/dist/esm/wallet/expo/background.js +0 -111
- package/dist/esm/wallet/expo/index.js +0 -2
- package/dist/esm/wallet/expo/wallet.js +0 -193
- package/dist/esm/wallet/hdDescriptorProvider.js +0 -155
- package/dist/esm/wallet/index.js +0 -75
- package/dist/esm/wallet/onchain.js +0 -285
- package/dist/esm/wallet/ramps.js +0 -212
- package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
- package/dist/esm/wallet/serviceWorker/wallet.js +0 -1168
- package/dist/esm/wallet/unroll.js +0 -285
- package/dist/esm/wallet/utils.js +0 -103
- package/dist/esm/wallet/validation.js +0 -142
- package/dist/esm/wallet/vtxo-manager.js +0 -1136
- package/dist/esm/wallet/wallet.js +0 -2041
- package/dist/esm/worker/browser/service-worker-manager.js +0 -177
- package/dist/esm/worker/browser/utils.js +0 -63
- package/dist/esm/worker/errors.js +0 -11
- package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
- package/dist/esm/worker/expo/index.js +0 -4
- package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
- package/dist/esm/worker/expo/processors/index.js +0 -1
- package/dist/esm/worker/expo/taskQueue.js +0 -37
- package/dist/esm/worker/expo/taskRunner.js +0 -69
- package/dist/esm/worker/messageBus.js +0 -469
- package/dist/types/adapters/asyncStorage.d.ts +0 -2
- package/dist/types/adapters/expo.d.ts +0 -4
- package/dist/types/adapters/fileSystem.d.ts +0 -2
- package/dist/types/adapters/indexedDB.d.ts +0 -2
- package/dist/types/adapters/localStorage.d.ts +0 -2
- package/dist/types/arkfee/celenv.d.ts +0 -25
- package/dist/types/arkfee/estimator.d.ts +0 -49
- package/dist/types/arkfee/index.d.ts +0 -2
- package/dist/types/arkfee/types.d.ts +0 -38
- package/dist/types/arknote/index.d.ts +0 -84
- package/dist/types/bip322/index.d.ts +0 -55
- package/dist/types/contracts/arkcontract.d.ts +0 -99
- package/dist/types/contracts/contractManager.d.ts +0 -381
- package/dist/types/contracts/contractWatcher.d.ts +0 -217
- package/dist/types/contracts/handlers/default.d.ts +0 -19
- package/dist/types/contracts/handlers/delegate.d.ts +0 -21
- package/dist/types/contracts/handlers/helpers.d.ts +0 -19
- package/dist/types/contracts/handlers/index.d.ts +0 -7
- package/dist/types/contracts/handlers/registry.d.ts +0 -65
- package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
- package/dist/types/contracts/index.d.ts +0 -14
- package/dist/types/contracts/types.d.ts +0 -233
- package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
- package/dist/types/extension/asset/assetGroup.d.ts +0 -119
- package/dist/types/extension/asset/assetId.d.ts +0 -83
- package/dist/types/extension/asset/assetInput.d.ts +0 -64
- package/dist/types/extension/asset/assetOutput.d.ts +0 -54
- package/dist/types/extension/asset/assetRef.d.ts +0 -91
- package/dist/types/extension/asset/index.d.ts +0 -8
- package/dist/types/extension/asset/metadata.d.ts +0 -52
- package/dist/types/extension/asset/packet.d.ts +0 -41
- package/dist/types/extension/asset/types.d.ts +0 -16
- package/dist/types/extension/asset/utils.d.ts +0 -21
- package/dist/types/extension/index.d.ts +0 -56
- package/dist/types/extension/packet.d.ts +0 -21
- package/dist/types/forfeit.d.ts +0 -18
- package/dist/types/identity/descriptor.d.ts +0 -61
- package/dist/types/identity/descriptorProvider.d.ts +0 -35
- package/dist/types/identity/hdCapableIdentity.d.ts +0 -44
- package/dist/types/identity/index.d.ts +0 -56
- package/dist/types/identity/seedIdentity.d.ts +0 -254
- package/dist/types/identity/serialize.d.ts +0 -96
- package/dist/types/identity/singleKey.d.ts +0 -62
- package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
- package/dist/types/index.d.ts +0 -59
- package/dist/types/intent/index.d.ts +0 -86
- package/dist/types/musig2/index.d.ts +0 -4
- package/dist/types/musig2/keys.d.ts +0 -9
- package/dist/types/musig2/nonces.d.ts +0 -14
- package/dist/types/musig2/sign.d.ts +0 -27
- package/dist/types/networks.d.ts +0 -16
- package/dist/types/providers/ark.d.ts +0 -369
- package/dist/types/providers/delegator.d.ts +0 -82
- package/dist/types/providers/electrum.d.ts +0 -312
- package/dist/types/providers/errors.d.ts +0 -13
- package/dist/types/providers/expoArk.d.ts +0 -22
- package/dist/types/providers/expoIndexer.d.ts +0 -18
- package/dist/types/providers/expoUtils.d.ts +0 -18
- package/dist/types/providers/indexer.d.ts +0 -301
- package/dist/types/providers/onchain.d.ts +0 -148
- package/dist/types/providers/utils.d.ts +0 -12
- package/dist/types/repositories/contractRepository.d.ts +0 -32
- package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
- package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
- package/dist/types/repositories/index.d.ts +0 -9
- package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
- package/dist/types/repositories/indexedDB/db.d.ts +0 -4
- package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
- package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
- package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
- package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
- package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
- package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
- package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
- package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
- package/dist/types/repositories/realm/index.d.ts +0 -4
- package/dist/types/repositories/realm/types.d.ts +0 -16
- package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
- package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
- package/dist/types/repositories/serialization.d.ts +0 -65
- package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
- package/dist/types/repositories/sqlite/index.d.ts +0 -3
- package/dist/types/repositories/sqlite/types.d.ts +0 -18
- package/dist/types/repositories/walletRepository.d.ts +0 -72
- package/dist/types/script/address.d.ts +0 -67
- package/dist/types/script/base.d.ts +0 -105
- package/dist/types/script/default.d.ts +0 -44
- package/dist/types/script/delegate.d.ts +0 -40
- package/dist/types/script/tapscript.d.ts +0 -169
- package/dist/types/script/vhtlc.d.ts +0 -66
- package/dist/types/tree/signingSession.d.ts +0 -37
- package/dist/types/tree/txTree.d.ts +0 -28
- package/dist/types/tree/validation.d.ts +0 -15
- package/dist/types/utils/anchor.d.ts +0 -19
- package/dist/types/utils/arkTransaction.d.ts +0 -49
- package/dist/types/utils/bip21.d.ts +0 -38
- package/dist/types/utils/syncCursors.d.ts +0 -60
- package/dist/types/utils/timelock.d.ts +0 -9
- package/dist/types/utils/transaction.d.ts +0 -13
- package/dist/types/utils/transactionHistory.d.ts +0 -15
- package/dist/types/utils/txSizeEstimator.d.ts +0 -40
- package/dist/types/utils/unknownFields.d.ts +0 -83
- package/dist/types/wallet/asset-manager.d.ts +0 -69
- package/dist/types/wallet/asset.d.ts +0 -21
- package/dist/types/wallet/batch.d.ts +0 -107
- package/dist/types/wallet/delegator.d.ts +0 -48
- package/dist/types/wallet/expo/background.d.ts +0 -66
- package/dist/types/wallet/expo/index.d.ts +0 -4
- package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -93
- package/dist/types/wallet/index.d.ts +0 -755
- package/dist/types/wallet/onchain.d.ts +0 -109
- package/dist/types/wallet/ramps.d.ts +0 -64
- package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
- package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -238
- package/dist/types/wallet/unroll.d.ts +0 -114
- package/dist/types/wallet/utils.d.ts +0 -36
- package/dist/types/wallet/validation.d.ts +0 -24
- package/dist/types/wallet/vtxo-manager.d.ts +0 -476
- package/dist/types/wallet/wallet.d.ts +0 -360
- package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
- package/dist/types/worker/browser/utils.d.ts +0 -17
- package/dist/types/worker/errors.d.ts +0 -7
- package/dist/types/worker/expo/index.d.ts +0 -7
- package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
- package/dist/types/worker/expo/processors/index.d.ts +0 -1
- package/dist/types/worker/expo/taskQueue.d.ts +0 -50
- package/dist/types/worker/expo/taskRunner.d.ts +0 -66
- package/dist/types/worker/messageBus.d.ts +0 -188
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DelegateContractHandler = void 0;
|
|
4
|
-
const base_1 = require("@scure/base");
|
|
5
|
-
const delegate_1 = require("../../script/delegate");
|
|
6
|
-
const default_1 = require("../../script/default");
|
|
7
|
-
const helpers_1 = require("./helpers");
|
|
8
|
-
const timelock_1 = require("../../utils/timelock");
|
|
9
|
-
/**
|
|
10
|
-
* Handler for delegate wallet virtual outputs.
|
|
11
|
-
*
|
|
12
|
-
* Delegate contracts extend the default tapscript with an additional delegate path:
|
|
13
|
-
* - forfeit: (Alice + Server) multisig for collaborative spending
|
|
14
|
-
* - exit: (Alice) + CSV timelock for unilateral exit
|
|
15
|
-
* - delegate: (Alice + Delegate + Server) multisig for delegated renewal
|
|
16
|
-
*/
|
|
17
|
-
exports.DelegateContractHandler = {
|
|
18
|
-
type: "delegate",
|
|
19
|
-
createScript(params) {
|
|
20
|
-
const typed = this.deserializeParams(params);
|
|
21
|
-
return new delegate_1.DelegateVtxo.Script(typed);
|
|
22
|
-
},
|
|
23
|
-
serializeParams(params) {
|
|
24
|
-
return {
|
|
25
|
-
pubKey: base_1.hex.encode(params.pubKey),
|
|
26
|
-
serverPubKey: base_1.hex.encode(params.serverPubKey),
|
|
27
|
-
delegatePubKey: base_1.hex.encode(params.delegatePubKey),
|
|
28
|
-
csvTimelock: (0, timelock_1.timelockToSequence)(params.csvTimelock).toString(),
|
|
29
|
-
};
|
|
30
|
-
},
|
|
31
|
-
deserializeParams(params) {
|
|
32
|
-
const csvTimelock = params.csvTimelock
|
|
33
|
-
? (0, timelock_1.sequenceToTimelock)(Number(params.csvTimelock))
|
|
34
|
-
: default_1.DefaultVtxo.Script.DEFAULT_TIMELOCK;
|
|
35
|
-
return {
|
|
36
|
-
pubKey: base_1.hex.decode(params.pubKey),
|
|
37
|
-
serverPubKey: base_1.hex.decode(params.serverPubKey),
|
|
38
|
-
delegatePubKey: base_1.hex.decode(params.delegatePubKey),
|
|
39
|
-
csvTimelock,
|
|
40
|
-
};
|
|
41
|
-
},
|
|
42
|
-
selectPath(script, contract, context) {
|
|
43
|
-
if (context.collaborative) {
|
|
44
|
-
return { leaf: script.forfeit() };
|
|
45
|
-
}
|
|
46
|
-
const sequence = contract.params.csvTimelock
|
|
47
|
-
? Number(contract.params.csvTimelock)
|
|
48
|
-
: undefined;
|
|
49
|
-
if (!(0, helpers_1.isCsvSpendable)(context, sequence)) {
|
|
50
|
-
return null;
|
|
51
|
-
}
|
|
52
|
-
return {
|
|
53
|
-
leaf: script.exit(),
|
|
54
|
-
sequence,
|
|
55
|
-
};
|
|
56
|
-
},
|
|
57
|
-
getAllSpendingPaths(script, contract, context) {
|
|
58
|
-
const paths = [];
|
|
59
|
-
if (context.collaborative) {
|
|
60
|
-
paths.push({ leaf: script.forfeit() });
|
|
61
|
-
}
|
|
62
|
-
const exitPath = { leaf: script.exit() };
|
|
63
|
-
if (contract.params.csvTimelock) {
|
|
64
|
-
exitPath.sequence = Number(contract.params.csvTimelock);
|
|
65
|
-
}
|
|
66
|
-
paths.push(exitPath);
|
|
67
|
-
// Delegate path (Alice + Delegate + Server) — collaborative only
|
|
68
|
-
if (context.collaborative) {
|
|
69
|
-
paths.push({ leaf: script.delegate() });
|
|
70
|
-
}
|
|
71
|
-
return paths;
|
|
72
|
-
},
|
|
73
|
-
getSpendablePaths(script, contract, context) {
|
|
74
|
-
const paths = [];
|
|
75
|
-
if (context.collaborative) {
|
|
76
|
-
paths.push({ leaf: script.forfeit() });
|
|
77
|
-
}
|
|
78
|
-
const exitSequence = contract.params.csvTimelock
|
|
79
|
-
? Number(contract.params.csvTimelock)
|
|
80
|
-
: undefined;
|
|
81
|
-
if ((0, helpers_1.isCsvSpendable)(context, exitSequence)) {
|
|
82
|
-
const exitPath = { leaf: script.exit() };
|
|
83
|
-
if (exitSequence !== undefined) {
|
|
84
|
-
exitPath.sequence = exitSequence;
|
|
85
|
-
}
|
|
86
|
-
paths.push(exitPath);
|
|
87
|
-
}
|
|
88
|
-
return paths;
|
|
89
|
-
},
|
|
90
|
-
};
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.resolveRole = resolveRole;
|
|
4
|
-
exports.isCltvSatisfied = isCltvSatisfied;
|
|
5
|
-
exports.isCsvSpendable = isCsvSpendable;
|
|
6
|
-
const timelock_1 = require("../../utils/timelock");
|
|
7
|
-
const descriptor_1 = require("../../identity/descriptor");
|
|
8
|
-
/**
|
|
9
|
-
* Extract raw hex pubkey from a value that may be a descriptor or raw hex.
|
|
10
|
-
* Returns undefined for HD descriptors or unparseable values so role
|
|
11
|
-
* resolution stays best-effort and never throws.
|
|
12
|
-
*/
|
|
13
|
-
function extractRawPubKey(value) {
|
|
14
|
-
if (!(0, descriptor_1.isDescriptor)(value)) {
|
|
15
|
-
return value.toLowerCase();
|
|
16
|
-
}
|
|
17
|
-
try {
|
|
18
|
-
return (0, descriptor_1.extractPubKey)(value).toLowerCase();
|
|
19
|
-
}
|
|
20
|
-
catch {
|
|
21
|
-
return undefined;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Resolve wallet's role from explicit role or by matching descriptor/pubkey.
|
|
26
|
-
*/
|
|
27
|
-
function resolveRole(contract, context) {
|
|
28
|
-
// Explicit role takes precedence
|
|
29
|
-
if (context.role === "sender" || context.role === "receiver") {
|
|
30
|
-
return context.role;
|
|
31
|
-
}
|
|
32
|
-
const senderKey = contract.params.sender
|
|
33
|
-
? extractRawPubKey(contract.params.sender)
|
|
34
|
-
: undefined;
|
|
35
|
-
const receiverKey = contract.params.receiver
|
|
36
|
-
? extractRawPubKey(contract.params.receiver)
|
|
37
|
-
: undefined;
|
|
38
|
-
const matchRole = (rawWalletKey) => {
|
|
39
|
-
if (!rawWalletKey)
|
|
40
|
-
return undefined;
|
|
41
|
-
if (senderKey && rawWalletKey === senderKey) {
|
|
42
|
-
return "sender";
|
|
43
|
-
}
|
|
44
|
-
if (receiverKey && rawWalletKey === receiverKey) {
|
|
45
|
-
return "receiver";
|
|
46
|
-
}
|
|
47
|
-
return undefined;
|
|
48
|
-
};
|
|
49
|
-
// Try the preferred descriptor first. If it cannot be resolved
|
|
50
|
-
// (for example an HD descriptor without derivation support), fall back
|
|
51
|
-
// to walletPubKey for backward compatibility.
|
|
52
|
-
if (context.walletDescriptor) {
|
|
53
|
-
const walletDescriptorKey = extractRawPubKey(context.walletDescriptor);
|
|
54
|
-
const matchedRole = matchRole(walletDescriptorKey);
|
|
55
|
-
if (matchedRole) {
|
|
56
|
-
return matchedRole;
|
|
57
|
-
}
|
|
58
|
-
if (!walletDescriptorKey && context.walletPubKey) {
|
|
59
|
-
return matchRole(extractRawPubKey(context.walletPubKey));
|
|
60
|
-
}
|
|
61
|
-
return undefined;
|
|
62
|
-
}
|
|
63
|
-
if (context.walletPubKey) {
|
|
64
|
-
return matchRole(extractRawPubKey(context.walletPubKey));
|
|
65
|
-
}
|
|
66
|
-
return undefined;
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* BIP65 threshold: locktime values below this are interpreted as block heights,
|
|
70
|
-
* values at or above are interpreted as Unix timestamps (seconds).
|
|
71
|
-
*/
|
|
72
|
-
const CLTV_HEIGHT_THRESHOLD = 500000000n;
|
|
73
|
-
/**
|
|
74
|
-
* Check if an absolute (CLTV) locktime is currently satisfied.
|
|
75
|
-
*
|
|
76
|
-
* Following the BIP65 convention:
|
|
77
|
-
* - locktime < 500_000_000 → interpreted as a block height; compared against `context.blockHeight`
|
|
78
|
-
* - locktime >= 500_000_000 → interpreted as a Unix timestamp (seconds); compared against `context.currentTime`
|
|
79
|
-
*
|
|
80
|
-
* Returns false if the relevant context field is missing.
|
|
81
|
-
*/
|
|
82
|
-
function isCltvSatisfied(context, locktime) {
|
|
83
|
-
if (locktime < CLTV_HEIGHT_THRESHOLD) {
|
|
84
|
-
if (context.blockHeight === undefined)
|
|
85
|
-
return false;
|
|
86
|
-
return BigInt(context.blockHeight) >= locktime;
|
|
87
|
-
}
|
|
88
|
-
const currentTimeSec = BigInt(Math.floor(context.currentTime / 1000));
|
|
89
|
-
return currentTimeSec >= locktime;
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Check if a CSV timelock is currently satisfied for the given context/virtual output.
|
|
93
|
-
*/
|
|
94
|
-
function isCsvSpendable(context, sequence) {
|
|
95
|
-
if (sequence === undefined)
|
|
96
|
-
return true;
|
|
97
|
-
if (!context.vtxo)
|
|
98
|
-
return false;
|
|
99
|
-
const timelock = (0, timelock_1.sequenceToTimelock)(sequence);
|
|
100
|
-
if (timelock.type === "blocks") {
|
|
101
|
-
if (context.blockHeight === undefined ||
|
|
102
|
-
context.vtxo.status.block_height === undefined) {
|
|
103
|
-
return false;
|
|
104
|
-
}
|
|
105
|
-
return (context.blockHeight - context.vtxo.status.block_height >=
|
|
106
|
-
Number(timelock.value));
|
|
107
|
-
}
|
|
108
|
-
if (timelock.type === "seconds") {
|
|
109
|
-
const blockTime = context.vtxo.status.block_time;
|
|
110
|
-
if (blockTime === undefined)
|
|
111
|
-
return false;
|
|
112
|
-
return context.currentTime / 1000 - blockTime >= Number(timelock.value);
|
|
113
|
-
}
|
|
114
|
-
return false;
|
|
115
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.VHTLCContractHandler = exports.DelegateContractHandler = exports.DefaultContractHandler = exports.contractHandlers = void 0;
|
|
4
|
-
var registry_1 = require("./registry");
|
|
5
|
-
Object.defineProperty(exports, "contractHandlers", { enumerable: true, get: function () { return registry_1.contractHandlers; } });
|
|
6
|
-
var default_1 = require("./default");
|
|
7
|
-
Object.defineProperty(exports, "DefaultContractHandler", { enumerable: true, get: function () { return default_1.DefaultContractHandler; } });
|
|
8
|
-
var delegate_1 = require("./delegate");
|
|
9
|
-
Object.defineProperty(exports, "DelegateContractHandler", { enumerable: true, get: function () { return delegate_1.DelegateContractHandler; } });
|
|
10
|
-
var vhtlc_1 = require("./vhtlc");
|
|
11
|
-
Object.defineProperty(exports, "VHTLCContractHandler", { enumerable: true, get: function () { return vhtlc_1.VHTLCContractHandler; } });
|
|
12
|
-
// Register built-in handlers
|
|
13
|
-
const registry_2 = require("./registry");
|
|
14
|
-
const default_2 = require("./default");
|
|
15
|
-
const delegate_2 = require("./delegate");
|
|
16
|
-
const vhtlc_2 = require("./vhtlc");
|
|
17
|
-
registry_2.contractHandlers.register(default_2.DefaultContractHandler);
|
|
18
|
-
registry_2.contractHandlers.register(delegate_2.DelegateContractHandler);
|
|
19
|
-
registry_2.contractHandlers.register(vhtlc_2.VHTLCContractHandler);
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.contractHandlers = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Registry for contract handlers.
|
|
6
|
-
*
|
|
7
|
-
* Each contract type ("default", "vhtlc", etc.) has a handler that knows
|
|
8
|
-
* how to create VtxoScripts, serialize params, and select spending paths.
|
|
9
|
-
*
|
|
10
|
-
* @example
|
|
11
|
-
* ```typescript
|
|
12
|
-
* // Register a custom handler
|
|
13
|
-
* contractHandlers.register(myCustomHandler);
|
|
14
|
-
*
|
|
15
|
-
* // Get handler for a type
|
|
16
|
-
* const handler = contractHandlers.get("vhtlc");
|
|
17
|
-
* const script = handler.createScript(contract.params);
|
|
18
|
-
* ```
|
|
19
|
-
*/
|
|
20
|
-
class ContractHandlerRegistry {
|
|
21
|
-
constructor() {
|
|
22
|
-
this.handlers = new Map();
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Register a contract handler.
|
|
26
|
-
*
|
|
27
|
-
* @param handler - The handler to register
|
|
28
|
-
* @throws If a handler for this type is already registered
|
|
29
|
-
*/
|
|
30
|
-
register(handler) {
|
|
31
|
-
if (this.handlers.has(handler.type)) {
|
|
32
|
-
throw new Error(`Contract handler for type '${handler.type}' is already registered`);
|
|
33
|
-
}
|
|
34
|
-
this.handlers.set(handler.type, handler);
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Get a handler by type.
|
|
38
|
-
*
|
|
39
|
-
* @param type - The contract type
|
|
40
|
-
* @returns The handler, or undefined if not found
|
|
41
|
-
*/
|
|
42
|
-
get(type) {
|
|
43
|
-
return this.handlers.get(type);
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Get a handler by type, throwing if not found.
|
|
47
|
-
*
|
|
48
|
-
* @param type - The contract type
|
|
49
|
-
* @returns The handler
|
|
50
|
-
* @throws If no handler is registered for this type
|
|
51
|
-
*/
|
|
52
|
-
getOrThrow(type) {
|
|
53
|
-
const handler = this.get(type);
|
|
54
|
-
if (!handler) {
|
|
55
|
-
throw new Error(`No contract handler registered for type '${type}'`);
|
|
56
|
-
}
|
|
57
|
-
return handler;
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* Check if a handler is registered.
|
|
61
|
-
*
|
|
62
|
-
* @param type - The contract type
|
|
63
|
-
*/
|
|
64
|
-
has(type) {
|
|
65
|
-
return this.handlers.has(type);
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Get all registered types.
|
|
69
|
-
*/
|
|
70
|
-
getRegisteredTypes() {
|
|
71
|
-
return Array.from(this.handlers.keys());
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Unregister a handler (mainly for testing).
|
|
75
|
-
*/
|
|
76
|
-
unregister(type) {
|
|
77
|
-
return this.handlers.delete(type);
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Clear all handlers (mainly for testing).
|
|
81
|
-
*/
|
|
82
|
-
clear() {
|
|
83
|
-
this.handlers.clear();
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Global registry of contract handlers.
|
|
88
|
-
*/
|
|
89
|
-
exports.contractHandlers = new ContractHandlerRegistry();
|
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.VHTLCContractHandler = void 0;
|
|
4
|
-
const base_1 = require("@scure/base");
|
|
5
|
-
const vhtlc_1 = require("../../script/vhtlc");
|
|
6
|
-
const helpers_1 = require("./helpers");
|
|
7
|
-
const timelock_1 = require("../../utils/timelock");
|
|
8
|
-
/**
|
|
9
|
-
* Handler for Virtual Hash Time Lock Contract (VHTLC).
|
|
10
|
-
*
|
|
11
|
-
* VHTLC supports multiple spending paths:
|
|
12
|
-
*
|
|
13
|
-
* Collaborative paths (with server):
|
|
14
|
-
* - claim: Receiver + Server with preimage
|
|
15
|
-
* - refund: Sender + Receiver + Server
|
|
16
|
-
* - refundWithoutReceiver: Sender + Server after CLTV locktime
|
|
17
|
-
*
|
|
18
|
-
* Unilateral paths (without server):
|
|
19
|
-
* - unilateralClaim: Receiver with preimage after CSV delay
|
|
20
|
-
* - unilateralRefund: Sender + Receiver after CSV delay
|
|
21
|
-
* - unilateralRefundWithoutReceiver: Sender after CSV delay
|
|
22
|
-
*/
|
|
23
|
-
exports.VHTLCContractHandler = {
|
|
24
|
-
type: "vhtlc",
|
|
25
|
-
createScript(params) {
|
|
26
|
-
const typed = this.deserializeParams(params);
|
|
27
|
-
return new vhtlc_1.VHTLC.Script(typed);
|
|
28
|
-
},
|
|
29
|
-
serializeParams(params) {
|
|
30
|
-
return {
|
|
31
|
-
sender: base_1.hex.encode(params.sender),
|
|
32
|
-
receiver: base_1.hex.encode(params.receiver),
|
|
33
|
-
server: base_1.hex.encode(params.server),
|
|
34
|
-
hash: base_1.hex.encode(params.preimageHash),
|
|
35
|
-
refundLocktime: params.refundLocktime.toString(),
|
|
36
|
-
claimDelay: (0, timelock_1.timelockToSequence)(params.unilateralClaimDelay).toString(),
|
|
37
|
-
refundDelay: (0, timelock_1.timelockToSequence)(params.unilateralRefundDelay).toString(),
|
|
38
|
-
refundNoReceiverDelay: (0, timelock_1.timelockToSequence)(params.unilateralRefundWithoutReceiverDelay).toString(),
|
|
39
|
-
};
|
|
40
|
-
},
|
|
41
|
-
deserializeParams(params) {
|
|
42
|
-
return {
|
|
43
|
-
sender: base_1.hex.decode(params.sender),
|
|
44
|
-
receiver: base_1.hex.decode(params.receiver),
|
|
45
|
-
server: base_1.hex.decode(params.server),
|
|
46
|
-
preimageHash: base_1.hex.decode(params.hash),
|
|
47
|
-
refundLocktime: BigInt(params.refundLocktime),
|
|
48
|
-
unilateralClaimDelay: (0, timelock_1.sequenceToTimelock)(Number(params.claimDelay)),
|
|
49
|
-
unilateralRefundDelay: (0, timelock_1.sequenceToTimelock)(Number(params.refundDelay)),
|
|
50
|
-
unilateralRefundWithoutReceiverDelay: (0, timelock_1.sequenceToTimelock)(Number(params.refundNoReceiverDelay)),
|
|
51
|
-
};
|
|
52
|
-
},
|
|
53
|
-
/**
|
|
54
|
-
* Select spending path based on context.
|
|
55
|
-
*
|
|
56
|
-
* Role is determined from `context.role` or by matching
|
|
57
|
-
* `context.walletDescriptor` (preferred) / `context.walletPubKey`
|
|
58
|
-
* against sender/receiver in contract params.
|
|
59
|
-
*/
|
|
60
|
-
selectPath(script, contract, context) {
|
|
61
|
-
const role = (0, helpers_1.resolveRole)(contract, context);
|
|
62
|
-
const preimage = contract.params?.preimage;
|
|
63
|
-
const refundLocktime = BigInt(contract.params.refundLocktime);
|
|
64
|
-
if (!role) {
|
|
65
|
-
return null;
|
|
66
|
-
}
|
|
67
|
-
if (context.collaborative) {
|
|
68
|
-
if (role === "receiver" && preimage) {
|
|
69
|
-
return {
|
|
70
|
-
leaf: script.claim(),
|
|
71
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
if (role === "sender" && (0, helpers_1.isCltvSatisfied)(context, refundLocktime)) {
|
|
75
|
-
return {
|
|
76
|
-
leaf: script.refundWithoutReceiver(),
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
return null;
|
|
80
|
-
}
|
|
81
|
-
// Unilateral paths
|
|
82
|
-
if (role === "receiver" && preimage) {
|
|
83
|
-
const sequence = Number(contract.params.claimDelay);
|
|
84
|
-
if (!(0, helpers_1.isCsvSpendable)(context, sequence))
|
|
85
|
-
return null;
|
|
86
|
-
return {
|
|
87
|
-
leaf: script.unilateralClaim(),
|
|
88
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
89
|
-
sequence,
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
if (role === "sender") {
|
|
93
|
-
const sequence = Number(contract.params.refundNoReceiverDelay);
|
|
94
|
-
if (!(0, helpers_1.isCsvSpendable)(context, sequence))
|
|
95
|
-
return null;
|
|
96
|
-
return {
|
|
97
|
-
leaf: script.unilateralRefundWithoutReceiver(),
|
|
98
|
-
sequence,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
return null;
|
|
102
|
-
},
|
|
103
|
-
/**
|
|
104
|
-
* Get all possible spending paths (no timelock checks).
|
|
105
|
-
*
|
|
106
|
-
* Role is determined from `context.role` or by matching
|
|
107
|
-
* `context.walletDescriptor` (preferred) / `context.walletPubKey`
|
|
108
|
-
* against sender/receiver in contract params.
|
|
109
|
-
*/
|
|
110
|
-
getAllSpendingPaths(script, contract, context) {
|
|
111
|
-
const role = (0, helpers_1.resolveRole)(contract, context);
|
|
112
|
-
const paths = [];
|
|
113
|
-
if (!role) {
|
|
114
|
-
return paths;
|
|
115
|
-
}
|
|
116
|
-
const preimage = contract.params?.preimage;
|
|
117
|
-
if (context.collaborative) {
|
|
118
|
-
// Collaborative paths (no timelock checks)
|
|
119
|
-
if (role === "receiver" && preimage) {
|
|
120
|
-
paths.push({
|
|
121
|
-
leaf: script.claim(),
|
|
122
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
if (role === "sender") {
|
|
126
|
-
paths.push({
|
|
127
|
-
leaf: script.refundWithoutReceiver(),
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
// Unilateral paths (no timelock checks)
|
|
133
|
-
if (role === "receiver" && preimage) {
|
|
134
|
-
const sequence = Number(contract.params.claimDelay);
|
|
135
|
-
paths.push({
|
|
136
|
-
leaf: script.unilateralClaim(),
|
|
137
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
138
|
-
sequence,
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
if (role === "sender") {
|
|
142
|
-
const sequence = Number(contract.params.refundNoReceiverDelay);
|
|
143
|
-
paths.push({
|
|
144
|
-
leaf: script.unilateralRefundWithoutReceiver(),
|
|
145
|
-
sequence,
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return paths;
|
|
150
|
-
},
|
|
151
|
-
getSpendablePaths(script, contract, context) {
|
|
152
|
-
const role = (0, helpers_1.resolveRole)(contract, context);
|
|
153
|
-
const paths = [];
|
|
154
|
-
if (!role) {
|
|
155
|
-
return paths;
|
|
156
|
-
}
|
|
157
|
-
const preimage = contract.params?.preimage;
|
|
158
|
-
const refundLocktime = BigInt(contract.params.refundLocktime);
|
|
159
|
-
if (context.collaborative) {
|
|
160
|
-
if (role === "receiver" && preimage) {
|
|
161
|
-
paths.push({
|
|
162
|
-
leaf: script.claim(),
|
|
163
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
164
|
-
});
|
|
165
|
-
}
|
|
166
|
-
if (role === "sender" && (0, helpers_1.isCltvSatisfied)(context, refundLocktime)) {
|
|
167
|
-
paths.push({
|
|
168
|
-
leaf: script.refundWithoutReceiver(),
|
|
169
|
-
});
|
|
170
|
-
}
|
|
171
|
-
return paths;
|
|
172
|
-
}
|
|
173
|
-
if (role === "receiver" && preimage) {
|
|
174
|
-
const sequence = Number(contract.params.claimDelay);
|
|
175
|
-
if ((0, helpers_1.isCsvSpendable)(context, sequence)) {
|
|
176
|
-
paths.push({
|
|
177
|
-
leaf: script.unilateralClaim(),
|
|
178
|
-
extraWitness: [base_1.hex.decode(preimage)],
|
|
179
|
-
sequence,
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
if (role === "sender") {
|
|
184
|
-
const sequence = Number(contract.params.refundNoReceiverDelay);
|
|
185
|
-
if ((0, helpers_1.isCsvSpendable)(context, sequence)) {
|
|
186
|
-
paths.push({
|
|
187
|
-
leaf: script.unilateralRefundWithoutReceiver(),
|
|
188
|
-
sequence,
|
|
189
|
-
});
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
return paths;
|
|
193
|
-
},
|
|
194
|
-
};
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.ContractManager = exports.ContractWatcher = exports.isArkContract = exports.contractFromArkContractWithAddress = exports.contractFromArkContract = exports.decodeArkContract = exports.encodeArkContract = exports.VHTLCContractHandler = exports.DelegateContractHandler = exports.DefaultContractHandler = exports.contractHandlers = void 0;
|
|
18
|
-
// Types
|
|
19
|
-
__exportStar(require("./types"), exports);
|
|
20
|
-
// Contract handlers
|
|
21
|
-
var handlers_1 = require("./handlers");
|
|
22
|
-
Object.defineProperty(exports, "contractHandlers", { enumerable: true, get: function () { return handlers_1.contractHandlers; } });
|
|
23
|
-
var handlers_2 = require("./handlers");
|
|
24
|
-
Object.defineProperty(exports, "DefaultContractHandler", { enumerable: true, get: function () { return handlers_2.DefaultContractHandler; } });
|
|
25
|
-
var handlers_3 = require("./handlers");
|
|
26
|
-
Object.defineProperty(exports, "DelegateContractHandler", { enumerable: true, get: function () { return handlers_3.DelegateContractHandler; } });
|
|
27
|
-
var handlers_4 = require("./handlers");
|
|
28
|
-
Object.defineProperty(exports, "VHTLCContractHandler", { enumerable: true, get: function () { return handlers_4.VHTLCContractHandler; } });
|
|
29
|
-
// arkcontract string codec
|
|
30
|
-
var arkcontract_1 = require("./arkcontract");
|
|
31
|
-
Object.defineProperty(exports, "encodeArkContract", { enumerable: true, get: function () { return arkcontract_1.encodeArkContract; } });
|
|
32
|
-
Object.defineProperty(exports, "decodeArkContract", { enumerable: true, get: function () { return arkcontract_1.decodeArkContract; } });
|
|
33
|
-
Object.defineProperty(exports, "contractFromArkContract", { enumerable: true, get: function () { return arkcontract_1.contractFromArkContract; } });
|
|
34
|
-
Object.defineProperty(exports, "contractFromArkContractWithAddress", { enumerable: true, get: function () { return arkcontract_1.contractFromArkContractWithAddress; } });
|
|
35
|
-
Object.defineProperty(exports, "isArkContract", { enumerable: true, get: function () { return arkcontract_1.isArkContract; } });
|
|
36
|
-
// Contract watcher
|
|
37
|
-
var contractWatcher_1 = require("./contractWatcher");
|
|
38
|
-
Object.defineProperty(exports, "ContractWatcher", { enumerable: true, get: function () { return contractWatcher_1.ContractWatcher; } });
|
|
39
|
-
// Contract manager
|
|
40
|
-
var contractManager_1 = require("./contractManager");
|
|
41
|
-
Object.defineProperty(exports, "ContractManager", { enumerable: true, get: function () { return contractManager_1.ContractManager; } });
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.vtxoOutpoint = vtxoOutpoint;
|
|
4
|
-
exports.isVtxoForScript = isVtxoForScript;
|
|
5
|
-
exports.filterVtxosForScript = filterVtxosForScript;
|
|
6
|
-
exports.warnAndFilterVtxosForScript = warnAndFilterVtxosForScript;
|
|
7
|
-
exports.validateVtxosForScript = validateVtxosForScript;
|
|
8
|
-
exports.getVtxosForContract = getVtxosForContract;
|
|
9
|
-
exports.saveVtxosForContract = saveVtxosForContract;
|
|
10
|
-
/**
|
|
11
|
-
* Tier 1 helpers that enforce VTXO ownership at call sites that already know
|
|
12
|
-
* the intended contract script. Address-keyed repositories may still hand back
|
|
13
|
-
* legacy duplicate rows under the wrong bucket; these helpers gate reads and
|
|
14
|
-
* writes so a wrong-script row never wins.
|
|
15
|
-
*
|
|
16
|
-
* `script` is the authoritative ownership key. Equality is strict: a missing
|
|
17
|
-
* or empty `vtxo.script` never matches.
|
|
18
|
-
*/
|
|
19
|
-
function vtxoOutpoint(vtxo) {
|
|
20
|
-
return `${vtxo.txid}:${vtxo.vout}`;
|
|
21
|
-
}
|
|
22
|
-
function isVtxoForScript(vtxo, script) {
|
|
23
|
-
return !!vtxo.script && vtxo.script === script;
|
|
24
|
-
}
|
|
25
|
-
function filterVtxosForScript(vtxos, script) {
|
|
26
|
-
return vtxos.filter((v) => isVtxoForScript(v, script));
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Background/indexer sync flavour: drop wrong-script rows and log enough
|
|
30
|
-
* context to identify each rejection. Returns only matching rows so the
|
|
31
|
-
* caller can keep going.
|
|
32
|
-
*/
|
|
33
|
-
function warnAndFilterVtxosForScript(vtxos, script, context) {
|
|
34
|
-
const matches = [];
|
|
35
|
-
const rejected = [];
|
|
36
|
-
for (const v of vtxos) {
|
|
37
|
-
if (isVtxoForScript(v, script)) {
|
|
38
|
-
matches.push(v);
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
rejected.push(`${vtxoOutpoint(v)}(script=${v.script ?? ""})`);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
if (rejected.length > 0) {
|
|
45
|
-
console.warn(`${context}: dropped ${rejected.length} wrong-script VTXO(s) for script ${script}: ${rejected.join(", ")}`);
|
|
46
|
-
}
|
|
47
|
-
return matches;
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* User-initiated transaction/signing flavour: throw before persisting or
|
|
51
|
-
* signing inconsistent ownership state. Silently skipping here would hide a
|
|
52
|
-
* serious bug in the wallet's spend path.
|
|
53
|
-
*/
|
|
54
|
-
function validateVtxosForScript(vtxos, script, context) {
|
|
55
|
-
const mismatches = vtxos.filter((v) => !isVtxoForScript(v, script));
|
|
56
|
-
if (mismatches.length === 0)
|
|
57
|
-
return;
|
|
58
|
-
const detail = mismatches
|
|
59
|
-
.map((v) => `${vtxoOutpoint(v)}(script=${v.script ?? ""})`)
|
|
60
|
-
.join(", ");
|
|
61
|
-
throw new Error(`${context}: refusing to persist ${mismatches.length} VTXO(s) whose script does not match ${script}: ${detail}`);
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Tier 2 dispatch helpers: route to script-scoped repository methods when
|
|
65
|
-
* available, falling back to Tier 1 address-based filtering otherwise.
|
|
66
|
-
*/
|
|
67
|
-
async function getVtxosForContract(repo, contract) {
|
|
68
|
-
return repo.getVtxosForScript
|
|
69
|
-
? repo.getVtxosForScript(contract.script)
|
|
70
|
-
: filterVtxosForScript(await repo.getVtxos(contract.address), contract.script);
|
|
71
|
-
}
|
|
72
|
-
async function saveVtxosForContract(repo, contract, vtxos) {
|
|
73
|
-
if (repo.saveVtxosForScript) {
|
|
74
|
-
return repo.saveVtxosForScript({ script: contract.script, address: contract.address }, vtxos);
|
|
75
|
-
}
|
|
76
|
-
validateVtxosForScript(vtxos, contract.script, "saveVtxosForContract");
|
|
77
|
-
return repo.saveVtxos(contract.address, vtxos);
|
|
78
|
-
}
|