@arkade-os/sdk 0.4.27 → 0.4.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +31 -100
- package/dist/adapters/asyncStorage.cjs +48 -0
- package/dist/adapters/asyncStorage.cjs.map +1 -0
- package/dist/adapters/asyncStorage.d.cts +16 -0
- package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
- package/dist/adapters/asyncStorage.js +46 -0
- package/dist/adapters/asyncStorage.js.map +1 -0
- package/dist/adapters/expo.cjs +19 -0
- package/dist/adapters/expo.cjs.map +1 -0
- package/dist/adapters/expo.d.cts +48 -0
- package/dist/adapters/expo.d.ts +48 -0
- package/dist/adapters/expo.js +6 -0
- package/dist/adapters/expo.js.map +1 -0
- package/dist/adapters/fileSystem.cjs +116 -0
- package/dist/adapters/fileSystem.cjs.map +1 -0
- package/dist/adapters/fileSystem.d.cts +17 -0
- package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
- package/dist/adapters/fileSystem.js +93 -0
- package/dist/adapters/fileSystem.js.map +1 -0
- package/dist/adapters/indexedDB.cjs +103 -0
- package/dist/adapters/indexedDB.cjs.map +1 -0
- package/dist/adapters/indexedDB.d.cts +18 -0
- package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
- package/dist/adapters/indexedDB.js +101 -0
- package/dist/adapters/indexedDB.js.map +1 -0
- package/dist/adapters/localStorage.cjs +50 -0
- package/dist/adapters/localStorage.cjs.map +1 -0
- package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
- package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
- package/dist/adapters/localStorage.js +48 -0
- package/dist/adapters/localStorage.js.map +1 -0
- package/dist/ark-TZ1gXAXU.d.cts +3880 -0
- package/dist/ark-TZ1gXAXU.d.ts +3880 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
- package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-5PG7DV7A.cjs +805 -0
- package/dist/chunk-5PG7DV7A.cjs.map +1 -0
- package/dist/chunk-A3EMF7RN.js +95 -0
- package/dist/chunk-A3EMF7RN.js.map +1 -0
- package/dist/chunk-ADV27S4N.cjs +2701 -0
- package/dist/chunk-ADV27S4N.cjs.map +1 -0
- package/dist/chunk-BQLHADL7.js +13805 -0
- package/dist/chunk-BQLHADL7.js.map +1 -0
- package/dist/chunk-CFZMTDWI.js +209 -0
- package/dist/chunk-CFZMTDWI.js.map +1 -0
- package/dist/chunk-FG5ACJJW.cjs +212 -0
- package/dist/chunk-FG5ACJJW.cjs.map +1 -0
- package/dist/chunk-HW3JJ323.js +768 -0
- package/dist/chunk-HW3JJ323.js.map +1 -0
- package/dist/chunk-I3DGUUCT.cjs +838 -0
- package/dist/chunk-I3DGUUCT.cjs.map +1 -0
- package/dist/chunk-IPX2R7FR.cjs +100 -0
- package/dist/chunk-IPX2R7FR.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-T64LAI7L.js +829 -0
- package/dist/chunk-T64LAI7L.js.map +1 -0
- package/dist/chunk-ZBUDLTBO.js +2671 -0
- package/dist/chunk-ZBUDLTBO.js.map +1 -0
- package/dist/chunk-ZLO6NETT.cjs +13910 -0
- package/dist/chunk-ZLO6NETT.cjs.map +1 -0
- package/dist/contracts/handlers/index.cjs +26 -0
- package/dist/contracts/handlers/index.cjs.map +1 -0
- package/dist/contracts/handlers/index.d.cts +7 -0
- package/dist/contracts/handlers/index.d.ts +7 -0
- package/dist/contracts/handlers/index.js +5 -0
- package/dist/contracts/handlers/index.js.map +1 -0
- package/dist/delegate-BFZs69hp.d.cts +84 -0
- package/dist/delegate-aaVGfWsV.d.ts +84 -0
- package/dist/index-B22cA64m.d.cts +199 -0
- package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
- package/dist/index-C0IanN1m.d.ts +11 -0
- package/dist/index-NDla_UoJ.d.ts +199 -0
- package/dist/index.cjs +480 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3343 -0
- package/dist/index.d.ts +3343 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/repositories/realm/index.cjs +513 -0
- package/dist/repositories/realm/index.cjs.map +1 -0
- package/dist/repositories/realm/index.d.cts +217 -0
- package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
- package/dist/repositories/realm/index.js +507 -0
- package/dist/repositories/realm/index.js.map +1 -0
- package/dist/repositories/sqlite/index.cjs +588 -0
- package/dist/repositories/sqlite/index.cjs.map +1 -0
- package/dist/repositories/sqlite/index.d.cts +118 -0
- package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
- package/dist/repositories/sqlite/index.js +585 -0
- package/dist/repositories/sqlite/index.js.map +1 -0
- package/dist/taskRunner-C6Ff4OaU.d.cts +114 -0
- package/dist/taskRunner-yvPN8Z0K.d.ts +114 -0
- package/dist/wallet/expo/background.cjs +93 -0
- package/dist/wallet/expo/background.cjs.map +1 -0
- package/dist/wallet/expo/background.d.cts +84 -0
- package/dist/wallet/expo/background.d.ts +84 -0
- package/dist/wallet/expo/background.js +68 -0
- package/dist/wallet/expo/background.js.map +1 -0
- package/dist/wallet/expo/index.cjs +171 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +122 -0
- package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
- package/dist/wallet/expo/index.js +169 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-AF-p-OWj.d.cts +774 -0
- package/dist/wallet-D9NBRqvC.d.ts +774 -0
- package/dist/worker/expo/index.cjs +140 -0
- package/dist/worker/expo/index.cjs.map +1 -0
- package/dist/worker/expo/index.d.cts +29 -0
- package/dist/worker/expo/index.d.ts +29 -0
- package/dist/worker/expo/index.js +121 -0
- package/dist/worker/expo/index.js.map +1 -0
- package/package.json +110 -76
- package/dist/cjs/adapters/asyncStorage.js +0 -5
- package/dist/cjs/adapters/expo.js +0 -8
- package/dist/cjs/adapters/fileSystem.js +0 -5
- package/dist/cjs/adapters/indexedDB.js +0 -5
- package/dist/cjs/adapters/localStorage.js +0 -5
- package/dist/cjs/arkfee/celenv.js +0 -43
- package/dist/cjs/arkfee/estimator.js +0 -143
- package/dist/cjs/arkfee/index.js +0 -5
- package/dist/cjs/arkfee/types.js +0 -26
- package/dist/cjs/arknote/index.js +0 -128
- package/dist/cjs/bip322/index.js +0 -270
- package/dist/cjs/contracts/arkcontract.js +0 -147
- package/dist/cjs/contracts/contractManager.js +0 -649
- package/dist/cjs/contracts/contractWatcher.js +0 -598
- package/dist/cjs/contracts/handlers/default.js +0 -93
- package/dist/cjs/contracts/handlers/delegate.js +0 -90
- package/dist/cjs/contracts/handlers/helpers.js +0 -115
- package/dist/cjs/contracts/handlers/index.js +0 -19
- package/dist/cjs/contracts/handlers/registry.js +0 -89
- package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
- package/dist/cjs/contracts/index.js +0 -41
- package/dist/cjs/contracts/types.js +0 -2
- package/dist/cjs/contracts/vtxoOwnership.js +0 -78
- package/dist/cjs/extension/asset/assetGroup.js +0 -228
- package/dist/cjs/extension/asset/assetId.js +0 -152
- package/dist/cjs/extension/asset/assetInput.js +0 -222
- package/dist/cjs/extension/asset/assetOutput.js +0 -174
- package/dist/cjs/extension/asset/assetRef.js +0 -148
- package/dist/cjs/extension/asset/index.js +0 -23
- package/dist/cjs/extension/asset/metadata.js +0 -187
- package/dist/cjs/extension/asset/packet.js +0 -114
- package/dist/cjs/extension/asset/types.js +0 -22
- package/dist/cjs/extension/asset/utils.js +0 -105
- package/dist/cjs/extension/index.js +0 -254
- package/dist/cjs/extension/packet.js +0 -20
- package/dist/cjs/forfeit.js +0 -45
- package/dist/cjs/identity/descriptor.js +0 -169
- package/dist/cjs/identity/descriptorProvider.js +0 -2
- package/dist/cjs/identity/hdCapableIdentity.js +0 -20
- package/dist/cjs/identity/index.js +0 -40
- package/dist/cjs/identity/seedIdentity.js +0 -477
- package/dist/cjs/identity/serialize.js +0 -171
- package/dist/cjs/identity/singleKey.js +0 -126
- package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
- package/dist/cjs/index.js +0 -202
- package/dist/cjs/intent/index.js +0 -259
- package/dist/cjs/musig2/index.js +0 -11
- package/dist/cjs/musig2/keys.js +0 -57
- package/dist/cjs/musig2/nonces.js +0 -48
- package/dist/cjs/musig2/sign.js +0 -102
- package/dist/cjs/networks.js +0 -26
- package/dist/cjs/package.json +0 -3
- package/dist/cjs/providers/ark.js +0 -577
- package/dist/cjs/providers/delegator.js +0 -85
- package/dist/cjs/providers/electrum.js +0 -869
- package/dist/cjs/providers/errors.js +0 -59
- package/dist/cjs/providers/expoArk.js +0 -82
- package/dist/cjs/providers/expoIndexer.js +0 -111
- package/dist/cjs/providers/expoUtils.js +0 -124
- package/dist/cjs/providers/indexer.js +0 -630
- package/dist/cjs/providers/onchain.js +0 -262
- package/dist/cjs/providers/utils.js +0 -121
- package/dist/cjs/repositories/contractRepository.js +0 -2
- package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
- package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
- package/dist/cjs/repositories/index.js +0 -34
- package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
- package/dist/cjs/repositories/indexedDB/db.js +0 -19
- package/dist/cjs/repositories/indexedDB/manager.js +0 -100
- package/dist/cjs/repositories/indexedDB/schema.js +0 -204
- package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
- package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
- package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
- package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
- package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
- package/dist/cjs/repositories/realm/contractRepository.js +0 -116
- package/dist/cjs/repositories/realm/index.js +0 -11
- package/dist/cjs/repositories/realm/schemas.js +0 -157
- package/dist/cjs/repositories/realm/types.js +0 -7
- package/dist/cjs/repositories/realm/walletRepository.js +0 -305
- package/dist/cjs/repositories/scriptFromAddress.js +0 -16
- package/dist/cjs/repositories/serialization.js +0 -82
- package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
- package/dist/cjs/repositories/sqlite/index.js +0 -7
- package/dist/cjs/repositories/sqlite/types.js +0 -2
- package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
- package/dist/cjs/repositories/walletRepository.js +0 -2
- package/dist/cjs/script/address.js +0 -108
- package/dist/cjs/script/base.js +0 -185
- package/dist/cjs/script/default.js +0 -57
- package/dist/cjs/script/delegate.js +0 -53
- package/dist/cjs/script/tapscript.js +0 -619
- package/dist/cjs/script/vhtlc.js +0 -170
- package/dist/cjs/storage/asyncStorage.js +0 -50
- package/dist/cjs/storage/fileSystem.js +0 -141
- package/dist/cjs/storage/inMemory.js +0 -24
- package/dist/cjs/storage/index.js +0 -2
- package/dist/cjs/storage/indexedDB.js +0 -101
- package/dist/cjs/storage/localStorage.js +0 -51
- package/dist/cjs/tree/signingSession.js +0 -229
- package/dist/cjs/tree/txTree.js +0 -192
- package/dist/cjs/tree/validation.js +0 -107
- package/dist/cjs/utils/anchor.js +0 -35
- package/dist/cjs/utils/arkTransaction.js +0 -271
- package/dist/cjs/utils/bip21.js +0 -127
- package/dist/cjs/utils/syncCursors.js +0 -128
- package/dist/cjs/utils/timelock.js +0 -59
- package/dist/cjs/utils/transaction.js +0 -28
- package/dist/cjs/utils/transactionHistory.js +0 -183
- package/dist/cjs/utils/txSizeEstimator.js +0 -132
- package/dist/cjs/utils/unknownFields.js +0 -174
- package/dist/cjs/wallet/asset-manager.js +0 -330
- package/dist/cjs/wallet/asset.js +0 -119
- package/dist/cjs/wallet/batch.js +0 -183
- package/dist/cjs/wallet/delegator.js +0 -308
- package/dist/cjs/wallet/expo/background.js +0 -116
- package/dist/cjs/wallet/expo/index.js +0 -9
- package/dist/cjs/wallet/expo/wallet.js +0 -230
- package/dist/cjs/wallet/hdDescriptorProvider.js +0 -188
- package/dist/cjs/wallet/index.js +0 -82
- package/dist/cjs/wallet/inputSignerRouter.js +0 -98
- package/dist/cjs/wallet/onchain.js +0 -290
- package/dist/cjs/wallet/ramps.js +0 -216
- package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
- package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1174
- package/dist/cjs/wallet/signingErrors.js +0 -32
- package/dist/cjs/wallet/unroll.js +0 -293
- package/dist/cjs/wallet/utils.js +0 -111
- package/dist/cjs/wallet/validation.js +0 -154
- package/dist/cjs/wallet/vtxo-manager.js +0 -1142
- package/dist/cjs/wallet/wallet.js +0 -2195
- package/dist/cjs/wallet/walletReceiveRotator.js +0 -547
- package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
- package/dist/cjs/worker/browser/utils.js +0 -67
- package/dist/cjs/worker/errors.js +0 -16
- package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
- package/dist/cjs/worker/expo/index.js +0 -13
- package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
- package/dist/cjs/worker/expo/processors/index.js +0 -6
- package/dist/cjs/worker/expo/taskQueue.js +0 -41
- package/dist/cjs/worker/expo/taskRunner.js +0 -73
- package/dist/cjs/worker/messageBus.js +0 -474
- package/dist/esm/adapters/asyncStorage.js +0 -1
- package/dist/esm/adapters/expo.js +0 -3
- package/dist/esm/adapters/fileSystem.js +0 -1
- package/dist/esm/adapters/indexedDB.js +0 -1
- package/dist/esm/adapters/localStorage.js +0 -1
- package/dist/esm/arkfee/celenv.js +0 -40
- package/dist/esm/arkfee/estimator.js +0 -139
- package/dist/esm/arkfee/index.js +0 -1
- package/dist/esm/arkfee/types.js +0 -22
- package/dist/esm/arknote/index.js +0 -124
- package/dist/esm/bip322/index.js +0 -267
- package/dist/esm/contracts/arkcontract.js +0 -140
- package/dist/esm/contracts/contractManager.js +0 -645
- package/dist/esm/contracts/contractWatcher.js +0 -594
- package/dist/esm/contracts/handlers/default.js +0 -90
- package/dist/esm/contracts/handlers/delegate.js +0 -87
- package/dist/esm/contracts/handlers/helpers.js +0 -110
- package/dist/esm/contracts/handlers/index.js +0 -12
- package/dist/esm/contracts/handlers/registry.js +0 -86
- package/dist/esm/contracts/handlers/vhtlc.js +0 -191
- package/dist/esm/contracts/index.js +0 -13
- package/dist/esm/contracts/types.js +0 -1
- package/dist/esm/contracts/vtxoOwnership.js +0 -69
- package/dist/esm/extension/asset/assetGroup.js +0 -224
- package/dist/esm/extension/asset/assetId.js +0 -148
- package/dist/esm/extension/asset/assetInput.js +0 -217
- package/dist/esm/extension/asset/assetOutput.js +0 -169
- package/dist/esm/extension/asset/assetRef.js +0 -144
- package/dist/esm/extension/asset/index.js +0 -8
- package/dist/esm/extension/asset/metadata.js +0 -182
- package/dist/esm/extension/asset/packet.js +0 -110
- package/dist/esm/extension/asset/types.js +0 -19
- package/dist/esm/extension/asset/utils.js +0 -99
- package/dist/esm/extension/index.js +0 -248
- package/dist/esm/extension/packet.js +0 -16
- package/dist/esm/forfeit.js +0 -41
- package/dist/esm/identity/descriptor.js +0 -161
- package/dist/esm/identity/descriptorProvider.js +0 -1
- package/dist/esm/identity/hdCapableIdentity.js +0 -17
- package/dist/esm/identity/index.js +0 -13
- package/dist/esm/identity/seedIdentity.js +0 -469
- package/dist/esm/identity/serialize.js +0 -164
- package/dist/esm/identity/singleKey.js +0 -121
- package/dist/esm/identity/staticDescriptorProvider.js +0 -61
- package/dist/esm/index.js +0 -87
- package/dist/esm/intent/index.js +0 -255
- package/dist/esm/musig2/index.js +0 -3
- package/dist/esm/musig2/keys.js +0 -21
- package/dist/esm/musig2/nonces.js +0 -11
- package/dist/esm/musig2/sign.js +0 -63
- package/dist/esm/networks.js +0 -22
- package/dist/esm/package.json +0 -3
- package/dist/esm/providers/ark.js +0 -572
- package/dist/esm/providers/delegator.js +0 -81
- package/dist/esm/providers/electrum.js +0 -864
- package/dist/esm/providers/errors.js +0 -54
- package/dist/esm/providers/expoArk.js +0 -78
- package/dist/esm/providers/expoIndexer.js +0 -107
- package/dist/esm/providers/expoUtils.js +0 -87
- package/dist/esm/providers/indexer.js +0 -626
- package/dist/esm/providers/onchain.js +0 -258
- package/dist/esm/providers/utils.js +0 -117
- package/dist/esm/repositories/contractRepository.js +0 -1
- package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
- package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
- package/dist/esm/repositories/index.js +0 -10
- package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
- package/dist/esm/repositories/indexedDB/db.js +0 -4
- package/dist/esm/repositories/indexedDB/manager.js +0 -95
- package/dist/esm/repositories/indexedDB/schema.js +0 -199
- package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
- package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
- package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
- package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
- package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
- package/dist/esm/repositories/realm/contractRepository.js +0 -112
- package/dist/esm/repositories/realm/index.js +0 -3
- package/dist/esm/repositories/realm/schemas.js +0 -153
- package/dist/esm/repositories/realm/types.js +0 -6
- package/dist/esm/repositories/realm/walletRepository.js +0 -301
- package/dist/esm/repositories/scriptFromAddress.js +0 -13
- package/dist/esm/repositories/serialization.js +0 -67
- package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
- package/dist/esm/repositories/sqlite/index.js +0 -2
- package/dist/esm/repositories/sqlite/types.js +0 -1
- package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
- package/dist/esm/repositories/walletRepository.js +0 -1
- package/dist/esm/script/address.js +0 -104
- package/dist/esm/script/base.js +0 -179
- package/dist/esm/script/default.js +0 -54
- package/dist/esm/script/delegate.js +0 -50
- package/dist/esm/script/tapscript.js +0 -615
- package/dist/esm/script/vhtlc.js +0 -167
- package/dist/esm/storage/asyncStorage.js +0 -46
- package/dist/esm/storage/fileSystem.js +0 -104
- package/dist/esm/storage/inMemory.js +0 -20
- package/dist/esm/storage/index.js +0 -1
- package/dist/esm/storage/indexedDB.js +0 -97
- package/dist/esm/storage/localStorage.js +0 -47
- package/dist/esm/tree/signingSession.js +0 -191
- package/dist/esm/tree/txTree.js +0 -188
- package/dist/esm/tree/validation.js +0 -101
- package/dist/esm/utils/anchor.js +0 -31
- package/dist/esm/utils/arkTransaction.js +0 -264
- package/dist/esm/utils/bip21.js +0 -123
- package/dist/esm/utils/syncCursors.js +0 -119
- package/dist/esm/utils/timelock.js +0 -22
- package/dist/esm/utils/transaction.js +0 -24
- package/dist/esm/utils/transactionHistory.js +0 -180
- package/dist/esm/utils/txSizeEstimator.js +0 -128
- package/dist/esm/utils/unknownFields.js +0 -169
- package/dist/esm/wallet/asset-manager.js +0 -325
- package/dist/esm/wallet/asset.js +0 -113
- package/dist/esm/wallet/batch.js +0 -180
- package/dist/esm/wallet/delegator.js +0 -303
- package/dist/esm/wallet/expo/background.js +0 -111
- package/dist/esm/wallet/expo/index.js +0 -2
- package/dist/esm/wallet/expo/wallet.js +0 -193
- package/dist/esm/wallet/hdDescriptorProvider.js +0 -184
- package/dist/esm/wallet/index.js +0 -75
- package/dist/esm/wallet/inputSignerRouter.js +0 -94
- package/dist/esm/wallet/onchain.js +0 -285
- package/dist/esm/wallet/ramps.js +0 -212
- package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
- package/dist/esm/wallet/serviceWorker/wallet.js +0 -1169
- package/dist/esm/wallet/signingErrors.js +0 -27
- package/dist/esm/wallet/unroll.js +0 -289
- package/dist/esm/wallet/utils.js +0 -103
- package/dist/esm/wallet/validation.js +0 -142
- package/dist/esm/wallet/vtxo-manager.js +0 -1136
- package/dist/esm/wallet/wallet.js +0 -2186
- package/dist/esm/wallet/walletReceiveRotator.js +0 -540
- package/dist/esm/worker/browser/service-worker-manager.js +0 -177
- package/dist/esm/worker/browser/utils.js +0 -63
- package/dist/esm/worker/errors.js +0 -11
- package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
- package/dist/esm/worker/expo/index.js +0 -4
- package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
- package/dist/esm/worker/expo/processors/index.js +0 -1
- package/dist/esm/worker/expo/taskQueue.js +0 -37
- package/dist/esm/worker/expo/taskRunner.js +0 -69
- package/dist/esm/worker/messageBus.js +0 -470
- package/dist/types/adapters/asyncStorage.d.ts +0 -2
- package/dist/types/adapters/expo.d.ts +0 -4
- package/dist/types/adapters/fileSystem.d.ts +0 -2
- package/dist/types/adapters/indexedDB.d.ts +0 -2
- package/dist/types/adapters/localStorage.d.ts +0 -2
- package/dist/types/arkfee/celenv.d.ts +0 -25
- package/dist/types/arkfee/estimator.d.ts +0 -49
- package/dist/types/arkfee/index.d.ts +0 -2
- package/dist/types/arkfee/types.d.ts +0 -38
- package/dist/types/arknote/index.d.ts +0 -84
- package/dist/types/bip322/index.d.ts +0 -55
- package/dist/types/contracts/arkcontract.d.ts +0 -99
- package/dist/types/contracts/contractManager.d.ts +0 -411
- package/dist/types/contracts/contractWatcher.d.ts +0 -217
- package/dist/types/contracts/handlers/default.d.ts +0 -19
- package/dist/types/contracts/handlers/delegate.d.ts +0 -21
- package/dist/types/contracts/handlers/helpers.d.ts +0 -19
- package/dist/types/contracts/handlers/index.d.ts +0 -7
- package/dist/types/contracts/handlers/registry.d.ts +0 -65
- package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
- package/dist/types/contracts/index.d.ts +0 -14
- package/dist/types/contracts/types.d.ts +0 -250
- package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
- package/dist/types/extension/asset/assetGroup.d.ts +0 -119
- package/dist/types/extension/asset/assetId.d.ts +0 -83
- package/dist/types/extension/asset/assetInput.d.ts +0 -64
- package/dist/types/extension/asset/assetOutput.d.ts +0 -54
- package/dist/types/extension/asset/assetRef.d.ts +0 -91
- package/dist/types/extension/asset/index.d.ts +0 -8
- package/dist/types/extension/asset/metadata.d.ts +0 -52
- package/dist/types/extension/asset/packet.d.ts +0 -41
- package/dist/types/extension/asset/types.d.ts +0 -16
- package/dist/types/extension/asset/utils.d.ts +0 -21
- package/dist/types/extension/index.d.ts +0 -56
- package/dist/types/extension/packet.d.ts +0 -21
- package/dist/types/forfeit.d.ts +0 -18
- package/dist/types/identity/descriptor.d.ts +0 -61
- package/dist/types/identity/descriptorProvider.d.ts +0 -42
- package/dist/types/identity/hdCapableIdentity.d.ts +0 -71
- package/dist/types/identity/index.d.ts +0 -57
- package/dist/types/identity/seedIdentity.d.ts +0 -270
- package/dist/types/identity/serialize.d.ts +0 -96
- package/dist/types/identity/singleKey.d.ts +0 -62
- package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
- package/dist/types/index.d.ts +0 -59
- package/dist/types/intent/index.d.ts +0 -86
- package/dist/types/musig2/index.d.ts +0 -4
- package/dist/types/musig2/keys.d.ts +0 -9
- package/dist/types/musig2/nonces.d.ts +0 -14
- package/dist/types/musig2/sign.d.ts +0 -27
- package/dist/types/networks.d.ts +0 -16
- package/dist/types/providers/ark.d.ts +0 -369
- package/dist/types/providers/delegator.d.ts +0 -82
- package/dist/types/providers/electrum.d.ts +0 -312
- package/dist/types/providers/errors.d.ts +0 -13
- package/dist/types/providers/expoArk.d.ts +0 -22
- package/dist/types/providers/expoIndexer.d.ts +0 -18
- package/dist/types/providers/expoUtils.d.ts +0 -18
- package/dist/types/providers/indexer.d.ts +0 -301
- package/dist/types/providers/onchain.d.ts +0 -148
- package/dist/types/providers/utils.d.ts +0 -12
- package/dist/types/repositories/contractRepository.d.ts +0 -32
- package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
- package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
- package/dist/types/repositories/index.d.ts +0 -9
- package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
- package/dist/types/repositories/indexedDB/db.d.ts +0 -4
- package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
- package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
- package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
- package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
- package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
- package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
- package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
- package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
- package/dist/types/repositories/realm/index.d.ts +0 -4
- package/dist/types/repositories/realm/types.d.ts +0 -16
- package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
- package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
- package/dist/types/repositories/serialization.d.ts +0 -65
- package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
- package/dist/types/repositories/sqlite/index.d.ts +0 -3
- package/dist/types/repositories/sqlite/types.d.ts +0 -18
- package/dist/types/repositories/walletRepository.d.ts +0 -72
- package/dist/types/script/address.d.ts +0 -67
- package/dist/types/script/base.d.ts +0 -105
- package/dist/types/script/default.d.ts +0 -44
- package/dist/types/script/delegate.d.ts +0 -40
- package/dist/types/script/tapscript.d.ts +0 -169
- package/dist/types/script/vhtlc.d.ts +0 -66
- package/dist/types/tree/signingSession.d.ts +0 -37
- package/dist/types/tree/txTree.d.ts +0 -28
- package/dist/types/tree/validation.d.ts +0 -15
- package/dist/types/utils/anchor.d.ts +0 -19
- package/dist/types/utils/arkTransaction.d.ts +0 -49
- package/dist/types/utils/bip21.d.ts +0 -38
- package/dist/types/utils/syncCursors.d.ts +0 -60
- package/dist/types/utils/timelock.d.ts +0 -9
- package/dist/types/utils/transaction.d.ts +0 -13
- package/dist/types/utils/transactionHistory.d.ts +0 -15
- package/dist/types/utils/txSizeEstimator.d.ts +0 -40
- package/dist/types/utils/unknownFields.d.ts +0 -83
- package/dist/types/wallet/asset-manager.d.ts +0 -69
- package/dist/types/wallet/asset.d.ts +0 -21
- package/dist/types/wallet/batch.d.ts +0 -107
- package/dist/types/wallet/delegator.d.ts +0 -48
- package/dist/types/wallet/expo/background.d.ts +0 -66
- package/dist/types/wallet/expo/index.d.ts +0 -4
- package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -114
- package/dist/types/wallet/index.d.ts +0 -789
- package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
- package/dist/types/wallet/onchain.d.ts +0 -109
- package/dist/types/wallet/ramps.d.ts +0 -64
- package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
- package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -248
- package/dist/types/wallet/signingErrors.d.ts +0 -19
- package/dist/types/wallet/unroll.d.ts +0 -114
- package/dist/types/wallet/utils.d.ts +0 -36
- package/dist/types/wallet/validation.d.ts +0 -24
- package/dist/types/wallet/vtxo-manager.d.ts +0 -476
- package/dist/types/wallet/wallet.d.ts +0 -409
- package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
- package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
- package/dist/types/worker/browser/utils.d.ts +0 -17
- package/dist/types/worker/errors.d.ts +0 -7
- package/dist/types/worker/expo/index.d.ts +0 -7
- package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
- package/dist/types/worker/expo/processors/index.d.ts +0 -1
- package/dist/types/worker/expo/taskQueue.d.ts +0 -50
- package/dist/types/worker/expo/taskRunner.d.ts +0 -66
- package/dist/types/worker/messageBus.d.ts +0 -189
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AssetOutputs = exports.AssetOutput = void 0;
|
|
4
|
-
const base_1 = require("@scure/base");
|
|
5
|
-
const utils_1 = require("./utils");
|
|
6
|
-
/**
|
|
7
|
-
* AssetOutput references a real transaction output and specify the amount in satoshis.
|
|
8
|
-
* it must be present in an AssetGroup.
|
|
9
|
-
*
|
|
10
|
-
* @param vout - the output index in the transaction
|
|
11
|
-
* @param amount - asset amount in satoshis
|
|
12
|
-
*/
|
|
13
|
-
class AssetOutput {
|
|
14
|
-
constructor(vout, amount) {
|
|
15
|
-
this.vout = vout;
|
|
16
|
-
this.amount = amount;
|
|
17
|
-
}
|
|
18
|
-
/** Create a local asset output referencing a transaction output index. */
|
|
19
|
-
static create(vout, amount) {
|
|
20
|
-
const output = new AssetOutput(vout, typeof amount === "number" ? BigInt(amount) : amount);
|
|
21
|
-
output.validate();
|
|
22
|
-
return output;
|
|
23
|
-
}
|
|
24
|
-
/** Decode an asset output from its hex string form. */
|
|
25
|
-
static fromString(s) {
|
|
26
|
-
let buf;
|
|
27
|
-
try {
|
|
28
|
-
buf = base_1.hex.decode(s);
|
|
29
|
-
}
|
|
30
|
-
catch {
|
|
31
|
-
throw new Error("invalid asset output format, must be hex");
|
|
32
|
-
}
|
|
33
|
-
return AssetOutput.fromBytes(buf);
|
|
34
|
-
}
|
|
35
|
-
/** Decode an asset output from its serialized bytes. */
|
|
36
|
-
static fromBytes(buf) {
|
|
37
|
-
if (!buf || buf.length === 0) {
|
|
38
|
-
throw new Error("missing asset output");
|
|
39
|
-
}
|
|
40
|
-
const reader = new utils_1.BufferReader(buf);
|
|
41
|
-
const output = AssetOutput.fromReader(reader);
|
|
42
|
-
output.validate();
|
|
43
|
-
return output;
|
|
44
|
-
}
|
|
45
|
-
/** Serialize the asset output to raw bytes. */
|
|
46
|
-
serialize() {
|
|
47
|
-
const writer = new utils_1.BufferWriter();
|
|
48
|
-
this.serializeTo(writer);
|
|
49
|
-
return writer.toBytes();
|
|
50
|
-
}
|
|
51
|
-
/** Encode the asset output to a hex string. */
|
|
52
|
-
toString() {
|
|
53
|
-
return base_1.hex.encode(this.serialize());
|
|
54
|
-
}
|
|
55
|
-
/** Validate the asset output fields. */
|
|
56
|
-
validate() {
|
|
57
|
-
if (!Number.isInteger(this.vout) ||
|
|
58
|
-
this.vout < 0 ||
|
|
59
|
-
this.vout > 0xffff) {
|
|
60
|
-
throw new Error("asset output vout must be an integer in range [0, 65535]");
|
|
61
|
-
}
|
|
62
|
-
if (this.amount <= 0n) {
|
|
63
|
-
throw new Error("asset output amount must be greater than 0");
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
/** Decode an asset output from a buffer reader. */
|
|
67
|
-
static fromReader(reader) {
|
|
68
|
-
if (reader.remaining() < 2) {
|
|
69
|
-
throw new Error("invalid asset output vout length");
|
|
70
|
-
}
|
|
71
|
-
const type = reader.readByte();
|
|
72
|
-
if (type !== AssetOutput.TYPE_LOCAL) {
|
|
73
|
-
if (type === 0x00) {
|
|
74
|
-
throw new Error("output type unspecified");
|
|
75
|
-
}
|
|
76
|
-
throw new Error("unknown asset output type");
|
|
77
|
-
}
|
|
78
|
-
let vout;
|
|
79
|
-
try {
|
|
80
|
-
vout = reader.readUint16LE();
|
|
81
|
-
}
|
|
82
|
-
catch {
|
|
83
|
-
throw new Error("invalid asset output vout length");
|
|
84
|
-
}
|
|
85
|
-
const amount = reader.readVarUint();
|
|
86
|
-
return new AssetOutput(vout, amount);
|
|
87
|
-
}
|
|
88
|
-
/** Serialize the asset output into an existing buffer writer. */
|
|
89
|
-
serializeTo(writer) {
|
|
90
|
-
writer.writeByte(0x01);
|
|
91
|
-
writer.writeUint16LE(this.vout);
|
|
92
|
-
writer.writeVarUint(this.amount);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
exports.AssetOutput = AssetOutput;
|
|
96
|
-
// 0x01 means local output, there is only 1 local output type currently
|
|
97
|
-
// however we serialize it for future upgrades
|
|
98
|
-
AssetOutput.TYPE_LOCAL = 0x01;
|
|
99
|
-
/**
|
|
100
|
-
* AssetOutputs is a list of AssetOutput references.
|
|
101
|
-
* it must be present in an AssetGroup.
|
|
102
|
-
*
|
|
103
|
-
* @param outputs - the list of asset outputs
|
|
104
|
-
*/
|
|
105
|
-
class AssetOutputs {
|
|
106
|
-
constructor(outputs) {
|
|
107
|
-
this.outputs = outputs;
|
|
108
|
-
}
|
|
109
|
-
/** Create a validated list of asset outputs. */
|
|
110
|
-
static create(outputs) {
|
|
111
|
-
const list = new AssetOutputs(outputs);
|
|
112
|
-
list.validate();
|
|
113
|
-
return list;
|
|
114
|
-
}
|
|
115
|
-
/** Decode an asset output list from its hex string form. */
|
|
116
|
-
static fromString(s) {
|
|
117
|
-
if (!s || s.length === 0) {
|
|
118
|
-
throw new Error("missing asset outputs");
|
|
119
|
-
}
|
|
120
|
-
let buf;
|
|
121
|
-
try {
|
|
122
|
-
buf = base_1.hex.decode(s);
|
|
123
|
-
}
|
|
124
|
-
catch {
|
|
125
|
-
throw new Error("invalid asset outputs format, must be hex");
|
|
126
|
-
}
|
|
127
|
-
const reader = new utils_1.BufferReader(buf);
|
|
128
|
-
return AssetOutputs.fromReader(reader);
|
|
129
|
-
}
|
|
130
|
-
/** Serialize the asset output list to raw bytes. */
|
|
131
|
-
serialize() {
|
|
132
|
-
const writer = new utils_1.BufferWriter();
|
|
133
|
-
this.serializeTo(writer);
|
|
134
|
-
return writer.toBytes();
|
|
135
|
-
}
|
|
136
|
-
/** Encode the asset output list to a hex string. */
|
|
137
|
-
toString() {
|
|
138
|
-
return base_1.hex.encode(this.serialize());
|
|
139
|
-
}
|
|
140
|
-
/** Validate the asset output list. */
|
|
141
|
-
validate() {
|
|
142
|
-
const seen = new Set();
|
|
143
|
-
for (const output of this.outputs) {
|
|
144
|
-
output.validate();
|
|
145
|
-
if (seen.has(output.vout)) {
|
|
146
|
-
throw new Error(`duplicated output vout ${output.vout}`);
|
|
147
|
-
}
|
|
148
|
-
seen.add(output.vout);
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
/** Decode an asset output list from a buffer reader. */
|
|
152
|
-
static fromReader(reader) {
|
|
153
|
-
const count = Number(reader.readVarUint());
|
|
154
|
-
if (count === 0) {
|
|
155
|
-
return new AssetOutputs([]);
|
|
156
|
-
}
|
|
157
|
-
const outputs = [];
|
|
158
|
-
for (let i = 0; i < count; i++) {
|
|
159
|
-
outputs.push(AssetOutput.fromReader(reader));
|
|
160
|
-
}
|
|
161
|
-
const result = new AssetOutputs(outputs);
|
|
162
|
-
result.validate();
|
|
163
|
-
return result;
|
|
164
|
-
}
|
|
165
|
-
/** Serialize the asset output list into an existing buffer writer. */
|
|
166
|
-
serializeTo(writer) {
|
|
167
|
-
this.validate();
|
|
168
|
-
writer.writeVarUint(this.outputs.length);
|
|
169
|
-
for (const output of this.outputs) {
|
|
170
|
-
output.serializeTo(writer);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
exports.AssetOutputs = AssetOutputs;
|
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AssetRef = void 0;
|
|
4
|
-
const base_1 = require("@scure/base");
|
|
5
|
-
const types_1 = require("./types");
|
|
6
|
-
const assetId_1 = require("./assetId");
|
|
7
|
-
const utils_1 = require("./utils");
|
|
8
|
-
/**
|
|
9
|
-
* Reference to either an explicit asset id or another asset group in the same packet.
|
|
10
|
-
*
|
|
11
|
-
* @see AssetId
|
|
12
|
-
*
|
|
13
|
-
* @example
|
|
14
|
-
* ```typescript
|
|
15
|
-
* const refById = AssetRef.fromId(assetId)
|
|
16
|
-
* const refByGroup = AssetRef.fromGroupIndex(0)
|
|
17
|
-
* ```
|
|
18
|
-
*/
|
|
19
|
-
class AssetRef {
|
|
20
|
-
constructor(ref) {
|
|
21
|
-
this.ref = ref;
|
|
22
|
-
}
|
|
23
|
-
/** Reference type discriminator. */
|
|
24
|
-
get type() {
|
|
25
|
-
return this.ref.type;
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Create an asset reference that points to a specific asset id.
|
|
29
|
-
*
|
|
30
|
-
* @param assetId - Asset id referenced by this pointer
|
|
31
|
-
* @returns Asset reference by id
|
|
32
|
-
* @see fromGroupIndex
|
|
33
|
-
*/
|
|
34
|
-
static fromId(assetId) {
|
|
35
|
-
return new AssetRef({ type: types_1.AssetRefType.ByID, assetId });
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* Create an asset reference that points to another asset group by index.
|
|
39
|
-
*
|
|
40
|
-
* @param groupIndex - Zero-based asset group index in the packet
|
|
41
|
-
* @returns Asset reference by group index
|
|
42
|
-
* @see fromId
|
|
43
|
-
*/
|
|
44
|
-
static fromGroupIndex(groupIndex) {
|
|
45
|
-
return new AssetRef({ type: types_1.AssetRefType.ByGroup, groupIndex });
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Decode an asset reference from its hex string form.
|
|
49
|
-
*
|
|
50
|
-
* @param s - Hex-encoded asset reference
|
|
51
|
-
* @returns Decoded asset reference
|
|
52
|
-
* @throws Error if the string is not valid hex or does not encode a valid asset reference
|
|
53
|
-
* @see toString
|
|
54
|
-
*/
|
|
55
|
-
static fromString(s) {
|
|
56
|
-
let buf;
|
|
57
|
-
try {
|
|
58
|
-
buf = base_1.hex.decode(s);
|
|
59
|
-
}
|
|
60
|
-
catch {
|
|
61
|
-
throw new Error("invalid asset ref format, must be hex");
|
|
62
|
-
}
|
|
63
|
-
return AssetRef.fromBytes(buf);
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Decode an asset reference from its serialized bytes.
|
|
67
|
-
*
|
|
68
|
-
* @param buf - Serialized asset reference bytes
|
|
69
|
-
* @returns Decoded asset reference
|
|
70
|
-
* @throws Error if the buffer is empty or malformed
|
|
71
|
-
*/
|
|
72
|
-
static fromBytes(buf) {
|
|
73
|
-
if (!buf || buf.length === 0) {
|
|
74
|
-
throw new Error("missing asset ref");
|
|
75
|
-
}
|
|
76
|
-
const reader = new utils_1.BufferReader(buf);
|
|
77
|
-
return AssetRef.fromReader(reader);
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Serialize the asset reference to raw bytes.
|
|
81
|
-
*
|
|
82
|
-
* @returns Serialized asset reference bytes
|
|
83
|
-
* @see fromBytes
|
|
84
|
-
*/
|
|
85
|
-
serialize() {
|
|
86
|
-
const writer = new utils_1.BufferWriter();
|
|
87
|
-
this.serializeTo(writer);
|
|
88
|
-
return writer.toBytes();
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Encode the asset reference to a hex string.
|
|
92
|
-
*
|
|
93
|
-
* @returns Hex-encoded asset reference
|
|
94
|
-
* @see fromString
|
|
95
|
-
*/
|
|
96
|
-
toString() {
|
|
97
|
-
return base_1.hex.encode(this.serialize());
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Decode an asset reference from a binary reader.
|
|
101
|
-
*
|
|
102
|
-
* @param reader - Reader positioned at an asset reference
|
|
103
|
-
* @returns Decoded asset reference
|
|
104
|
-
* @throws Error if the type is unknown or the reader does not contain enough bytes
|
|
105
|
-
*/
|
|
106
|
-
static fromReader(reader) {
|
|
107
|
-
const type = reader.readByte();
|
|
108
|
-
let ref;
|
|
109
|
-
switch (type) {
|
|
110
|
-
case types_1.AssetRefType.ByID: {
|
|
111
|
-
const assetId = assetId_1.AssetId.fromReader(reader);
|
|
112
|
-
ref = new AssetRef({ type: types_1.AssetRefType.ByID, assetId });
|
|
113
|
-
break;
|
|
114
|
-
}
|
|
115
|
-
case types_1.AssetRefType.ByGroup: {
|
|
116
|
-
if (reader.remaining() < 2) {
|
|
117
|
-
throw new Error("invalid asset ref length");
|
|
118
|
-
}
|
|
119
|
-
const groupIndex = reader.readUint16LE();
|
|
120
|
-
ref = new AssetRef({ type: types_1.AssetRefType.ByGroup, groupIndex });
|
|
121
|
-
break;
|
|
122
|
-
}
|
|
123
|
-
case types_1.AssetRefType.Unspecified:
|
|
124
|
-
throw new Error("asset ref type unspecified");
|
|
125
|
-
default:
|
|
126
|
-
throw new Error(`asset ref type unknown ${type}`);
|
|
127
|
-
}
|
|
128
|
-
return ref;
|
|
129
|
-
}
|
|
130
|
-
/**
|
|
131
|
-
* Serialize the asset reference into an existing binary writer.
|
|
132
|
-
*
|
|
133
|
-
* @param writer - Writer to append the asset reference to
|
|
134
|
-
* @see serialize
|
|
135
|
-
*/
|
|
136
|
-
serializeTo(writer) {
|
|
137
|
-
writer.writeByte(this.ref.type);
|
|
138
|
-
switch (this.ref.type) {
|
|
139
|
-
case types_1.AssetRefType.ByID:
|
|
140
|
-
this.ref.assetId.serializeTo(writer);
|
|
141
|
-
break;
|
|
142
|
-
case types_1.AssetRefType.ByGroup:
|
|
143
|
-
writer.writeUint16LE(this.ref.groupIndex);
|
|
144
|
-
break;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
exports.AssetRef = AssetRef;
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Packet = exports.AssetGroup = exports.MetadataList = exports.Metadata = exports.AssetOutputs = exports.AssetOutput = exports.AssetInputs = exports.AssetInput = exports.AssetRef = exports.AssetId = exports.AssetRefType = exports.AssetInputType = void 0;
|
|
4
|
-
var types_1 = require("./types");
|
|
5
|
-
Object.defineProperty(exports, "AssetInputType", { enumerable: true, get: function () { return types_1.AssetInputType; } });
|
|
6
|
-
Object.defineProperty(exports, "AssetRefType", { enumerable: true, get: function () { return types_1.AssetRefType; } });
|
|
7
|
-
var assetId_1 = require("./assetId");
|
|
8
|
-
Object.defineProperty(exports, "AssetId", { enumerable: true, get: function () { return assetId_1.AssetId; } });
|
|
9
|
-
var assetRef_1 = require("./assetRef");
|
|
10
|
-
Object.defineProperty(exports, "AssetRef", { enumerable: true, get: function () { return assetRef_1.AssetRef; } });
|
|
11
|
-
var assetInput_1 = require("./assetInput");
|
|
12
|
-
Object.defineProperty(exports, "AssetInput", { enumerable: true, get: function () { return assetInput_1.AssetInput; } });
|
|
13
|
-
Object.defineProperty(exports, "AssetInputs", { enumerable: true, get: function () { return assetInput_1.AssetInputs; } });
|
|
14
|
-
var assetOutput_1 = require("./assetOutput");
|
|
15
|
-
Object.defineProperty(exports, "AssetOutput", { enumerable: true, get: function () { return assetOutput_1.AssetOutput; } });
|
|
16
|
-
Object.defineProperty(exports, "AssetOutputs", { enumerable: true, get: function () { return assetOutput_1.AssetOutputs; } });
|
|
17
|
-
var metadata_1 = require("./metadata");
|
|
18
|
-
Object.defineProperty(exports, "Metadata", { enumerable: true, get: function () { return metadata_1.Metadata; } });
|
|
19
|
-
Object.defineProperty(exports, "MetadataList", { enumerable: true, get: function () { return metadata_1.MetadataList; } });
|
|
20
|
-
var assetGroup_1 = require("./assetGroup");
|
|
21
|
-
Object.defineProperty(exports, "AssetGroup", { enumerable: true, get: function () { return assetGroup_1.AssetGroup; } });
|
|
22
|
-
var packet_1 = require("./packet");
|
|
23
|
-
Object.defineProperty(exports, "Packet", { enumerable: true, get: function () { return packet_1.Packet; } });
|
|
@@ -1,187 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MetadataList = exports.Metadata = void 0;
|
|
4
|
-
const secp256k1_js_1 = require("@noble/curves/secp256k1.js");
|
|
5
|
-
const base_1 = require("@scure/base");
|
|
6
|
-
const utils_js_1 = require("@scure/btc-signer/utils.js");
|
|
7
|
-
const utils_1 = require("./utils");
|
|
8
|
-
/**
|
|
9
|
-
* Metadata represents a key-value pair.
|
|
10
|
-
* @param key - the key
|
|
11
|
-
* @param value - the value
|
|
12
|
-
*/
|
|
13
|
-
class Metadata {
|
|
14
|
-
constructor(key, value) {
|
|
15
|
-
this.key = key;
|
|
16
|
-
this.value = value;
|
|
17
|
-
}
|
|
18
|
-
/** Create a metadata entry from raw key and value bytes. */
|
|
19
|
-
static create(key, value) {
|
|
20
|
-
const md = new Metadata(key, value);
|
|
21
|
-
md.validate();
|
|
22
|
-
return md;
|
|
23
|
-
}
|
|
24
|
-
/** Decode metadata from its hex string form. */
|
|
25
|
-
static fromString(s) {
|
|
26
|
-
let buf;
|
|
27
|
-
try {
|
|
28
|
-
buf = base_1.hex.decode(s);
|
|
29
|
-
}
|
|
30
|
-
catch {
|
|
31
|
-
throw new Error("invalid metadata format, must be hex");
|
|
32
|
-
}
|
|
33
|
-
return Metadata.fromBytes(buf);
|
|
34
|
-
}
|
|
35
|
-
/** Decode metadata from its serialized bytes. */
|
|
36
|
-
static fromBytes(buf) {
|
|
37
|
-
if (!buf || buf.length === 0) {
|
|
38
|
-
throw new Error("missing metadata");
|
|
39
|
-
}
|
|
40
|
-
const reader = new utils_1.BufferReader(buf);
|
|
41
|
-
return Metadata.fromReader(reader);
|
|
42
|
-
}
|
|
43
|
-
/** Serialize metadata to raw bytes. */
|
|
44
|
-
serialize() {
|
|
45
|
-
const writer = new utils_1.BufferWriter();
|
|
46
|
-
this.serializeTo(writer);
|
|
47
|
-
return writer.toBytes();
|
|
48
|
-
}
|
|
49
|
-
/** Encode metadata to a hex string. */
|
|
50
|
-
toString() {
|
|
51
|
-
return base_1.hex.encode(this.serialize());
|
|
52
|
-
}
|
|
53
|
-
get keyString() {
|
|
54
|
-
return new TextDecoder().decode(this.key);
|
|
55
|
-
}
|
|
56
|
-
get valueString() {
|
|
57
|
-
return new TextDecoder().decode(this.value);
|
|
58
|
-
}
|
|
59
|
-
/** Validate the metadata key and value. */
|
|
60
|
-
validate() {
|
|
61
|
-
if (this.key.length === 0) {
|
|
62
|
-
throw new Error("missing metadata key");
|
|
63
|
-
}
|
|
64
|
-
if (this.value.length === 0) {
|
|
65
|
-
throw new Error("missing metadata value");
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
/** Decode metadata from a buffer reader. */
|
|
69
|
-
static fromReader(reader) {
|
|
70
|
-
let key;
|
|
71
|
-
let value;
|
|
72
|
-
try {
|
|
73
|
-
key = reader.readVarSlice();
|
|
74
|
-
}
|
|
75
|
-
catch {
|
|
76
|
-
throw new Error("invalid metadata length");
|
|
77
|
-
}
|
|
78
|
-
try {
|
|
79
|
-
value = reader.readVarSlice();
|
|
80
|
-
}
|
|
81
|
-
catch {
|
|
82
|
-
throw new Error("invalid metadata length");
|
|
83
|
-
}
|
|
84
|
-
const md = new Metadata(key, value);
|
|
85
|
-
md.validate();
|
|
86
|
-
return md;
|
|
87
|
-
}
|
|
88
|
-
/** Serialize metadata into an existing buffer writer. */
|
|
89
|
-
serializeTo(writer) {
|
|
90
|
-
writer.writeVarSlice(this.key);
|
|
91
|
-
writer.writeVarSlice(this.value);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
exports.Metadata = Metadata;
|
|
95
|
-
class MetadataList {
|
|
96
|
-
constructor(items) {
|
|
97
|
-
this.items = items;
|
|
98
|
-
}
|
|
99
|
-
/** Create a metadata list from its hex string form. */
|
|
100
|
-
static fromString(s) {
|
|
101
|
-
let buf;
|
|
102
|
-
try {
|
|
103
|
-
buf = base_1.hex.decode(s);
|
|
104
|
-
}
|
|
105
|
-
catch {
|
|
106
|
-
throw new Error("invalid metadata list format");
|
|
107
|
-
}
|
|
108
|
-
return MetadataList.fromBytes(buf);
|
|
109
|
-
}
|
|
110
|
-
/** Decode a metadata list from its serialized bytes. */
|
|
111
|
-
static fromBytes(buf) {
|
|
112
|
-
if (!buf || buf.length === 0) {
|
|
113
|
-
throw new Error("missing metadata list");
|
|
114
|
-
}
|
|
115
|
-
const reader = new utils_1.BufferReader(buf);
|
|
116
|
-
return MetadataList.fromReader(reader);
|
|
117
|
-
}
|
|
118
|
-
/** Decode a metadata list from a buffer reader. */
|
|
119
|
-
static fromReader(reader) {
|
|
120
|
-
const count = Number(reader.readVarUint());
|
|
121
|
-
const items = Array.from({ length: count }, () => Metadata.fromReader(reader));
|
|
122
|
-
return new MetadataList(items);
|
|
123
|
-
}
|
|
124
|
-
/** Serialize the metadata list into an existing buffer writer. */
|
|
125
|
-
serializeTo(writer) {
|
|
126
|
-
writer.writeVarUint(this.items.length);
|
|
127
|
-
for (const item of this) {
|
|
128
|
-
item.serializeTo(writer);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
/** Serialize the metadata list to raw bytes. */
|
|
132
|
-
serialize() {
|
|
133
|
-
const writer = new utils_1.BufferWriter();
|
|
134
|
-
this.serializeTo(writer);
|
|
135
|
-
return writer.toBytes();
|
|
136
|
-
}
|
|
137
|
-
/** Iterate through metadata entries in insertion order. */
|
|
138
|
-
[Symbol.iterator]() {
|
|
139
|
-
return this.items[Symbol.iterator]();
|
|
140
|
-
}
|
|
141
|
-
get length() {
|
|
142
|
-
return this.items.length;
|
|
143
|
-
}
|
|
144
|
-
/** Compute the tagged Merkle root for the metadata list. */
|
|
145
|
-
hash() {
|
|
146
|
-
if (this.items.length === 0)
|
|
147
|
-
throw new Error("missing metadata list");
|
|
148
|
-
const levels = buildMetadataMerkleTree(this.items);
|
|
149
|
-
return levels[levels.length - 1][0]; // the last level is the root
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
exports.MetadataList = MetadataList;
|
|
153
|
-
MetadataList.ARK_LEAF_TAG = "ArkadeAssetLeaf";
|
|
154
|
-
MetadataList.ARK_BRANCH_TAG = "ArkadeAssetBranch";
|
|
155
|
-
MetadataList.ARK_LEAF_VERSION = 0x00;
|
|
156
|
-
function computeMetadataLeafHash(md) {
|
|
157
|
-
const writer = new utils_1.BufferWriter();
|
|
158
|
-
writer.writeByte(MetadataList.ARK_LEAF_VERSION);
|
|
159
|
-
writer.writeVarSlice(md.key);
|
|
160
|
-
writer.writeVarSlice(md.value);
|
|
161
|
-
return secp256k1_js_1.schnorr.utils.taggedHash(MetadataList.ARK_LEAF_TAG, writer.toBytes());
|
|
162
|
-
}
|
|
163
|
-
function computeMetadataBranchHash(a, b) {
|
|
164
|
-
const [smaller, larger] = (0, utils_js_1.compareBytes)(a, b) === -1 ? [a, b] : [b, a];
|
|
165
|
-
return secp256k1_js_1.schnorr.utils.taggedHash(MetadataList.ARK_BRANCH_TAG, smaller, larger);
|
|
166
|
-
}
|
|
167
|
-
function buildMetadataMerkleTree(leaves) {
|
|
168
|
-
if (leaves.length === 0)
|
|
169
|
-
return [];
|
|
170
|
-
const leafHashes = leaves.map(computeMetadataLeafHash);
|
|
171
|
-
const levels = [leafHashes];
|
|
172
|
-
let current = leafHashes;
|
|
173
|
-
while (current.length > 1) {
|
|
174
|
-
const next = [];
|
|
175
|
-
for (let i = 0; i < current.length; i += 2) {
|
|
176
|
-
if (i + 1 < current.length) {
|
|
177
|
-
next.push(computeMetadataBranchHash(current[i], current[i + 1]));
|
|
178
|
-
}
|
|
179
|
-
else {
|
|
180
|
-
next.push(current[i]);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
levels.push(next);
|
|
184
|
-
current = next;
|
|
185
|
-
}
|
|
186
|
-
return levels;
|
|
187
|
-
}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Packet = void 0;
|
|
4
|
-
const base_1 = require("@scure/base");
|
|
5
|
-
const types_1 = require("./types");
|
|
6
|
-
const assetGroup_1 = require("./assetGroup");
|
|
7
|
-
const utils_1 = require("./utils");
|
|
8
|
-
/**
|
|
9
|
-
* Packet represents a collection of asset groups.
|
|
10
|
-
* It encodes/decodes as raw bytes only — OP_RETURN framing is handled by the Extension module.
|
|
11
|
-
*/
|
|
12
|
-
class Packet {
|
|
13
|
-
constructor(groups) {
|
|
14
|
-
this.groups = groups;
|
|
15
|
-
}
|
|
16
|
-
/** Create a validated asset packet from a list of asset groups. */
|
|
17
|
-
static create(groups) {
|
|
18
|
-
const p = new Packet(groups);
|
|
19
|
-
p.validate();
|
|
20
|
-
return p;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* fromBytes parses a Packet from raw bytes.
|
|
24
|
-
*/
|
|
25
|
-
static fromBytes(buf) {
|
|
26
|
-
return Packet.fromReader(new utils_1.BufferReader(buf));
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* fromString parses a Packet from a raw hex string (not an OP_RETURN script).
|
|
30
|
-
*/
|
|
31
|
-
static fromString(s) {
|
|
32
|
-
if (!s) {
|
|
33
|
-
throw new Error("missing packet data");
|
|
34
|
-
}
|
|
35
|
-
let buf;
|
|
36
|
-
try {
|
|
37
|
-
buf = base_1.hex.decode(s);
|
|
38
|
-
}
|
|
39
|
-
catch {
|
|
40
|
-
throw new Error("invalid packet format, must be hex");
|
|
41
|
-
}
|
|
42
|
-
return Packet.fromBytes(buf);
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* type returns the TLV packet type tag. Implements ExtensionPacket interface.
|
|
46
|
-
*/
|
|
47
|
-
type() {
|
|
48
|
-
return Packet.PACKET_TYPE;
|
|
49
|
-
}
|
|
50
|
-
/** Convert the packet into the batch-leaf form for a specific intent transaction id. */
|
|
51
|
-
leafTxPacket(intentTxid) {
|
|
52
|
-
const leafGroups = this.groups.map((group) => group.toBatchLeafAssetGroup(intentTxid));
|
|
53
|
-
return new Packet(leafGroups);
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* serialize encodes the packet as raw bytes (varint group count + group data).
|
|
57
|
-
* Does NOT include OP_RETURN, Arkade magic bytes (`ARK`), or TLV type/length; those are
|
|
58
|
-
* added by the Extension module.
|
|
59
|
-
*/
|
|
60
|
-
serialize() {
|
|
61
|
-
if (this.groups.length === 0) {
|
|
62
|
-
return new Uint8Array(0);
|
|
63
|
-
}
|
|
64
|
-
const writer = new utils_1.BufferWriter();
|
|
65
|
-
writer.writeVarUint(this.groups.length);
|
|
66
|
-
for (const group of this.groups) {
|
|
67
|
-
group.serializeTo(writer);
|
|
68
|
-
}
|
|
69
|
-
return writer.toBytes();
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* toString returns the hex-encoded raw packet bytes.
|
|
73
|
-
*/
|
|
74
|
-
toString() {
|
|
75
|
-
return base_1.hex.encode(this.serialize());
|
|
76
|
-
}
|
|
77
|
-
/** Validate packet structure and cross-group references. */
|
|
78
|
-
validate() {
|
|
79
|
-
if (this.groups.length === 0) {
|
|
80
|
-
throw new Error("missing assets");
|
|
81
|
-
}
|
|
82
|
-
const seenAssetIds = new Set();
|
|
83
|
-
for (const group of this.groups) {
|
|
84
|
-
if (group.assetId !== null) {
|
|
85
|
-
const key = group.assetId.toString();
|
|
86
|
-
if (seenAssetIds.has(key)) {
|
|
87
|
-
throw new Error(`duplicate asset group for asset ${key}`);
|
|
88
|
-
}
|
|
89
|
-
seenAssetIds.add(key);
|
|
90
|
-
}
|
|
91
|
-
if (group.controlAsset !== null &&
|
|
92
|
-
group.controlAsset.ref.type === types_1.AssetRefType.ByGroup &&
|
|
93
|
-
group.controlAsset.ref.groupIndex >= this.groups.length) {
|
|
94
|
-
throw new Error(`invalid control asset group index, ${group.controlAsset.ref.groupIndex} out of range [0, ${this.groups.length - 1}]`);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
static fromReader(reader) {
|
|
99
|
-
const count = Number(reader.readVarUint());
|
|
100
|
-
const groups = [];
|
|
101
|
-
for (let i = 0; i < count; i++) {
|
|
102
|
-
groups.push(assetGroup_1.AssetGroup.fromReader(reader));
|
|
103
|
-
}
|
|
104
|
-
if (reader.remaining() > 0) {
|
|
105
|
-
throw new Error(`invalid packet length, left ${reader.remaining()} unknown bytes to read`);
|
|
106
|
-
}
|
|
107
|
-
const packet = new Packet(groups);
|
|
108
|
-
packet.validate();
|
|
109
|
-
return packet;
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
exports.Packet = Packet;
|
|
113
|
-
/** PACKET_TYPE is the 1-byte TLV type tag used in the Extension envelope. */
|
|
114
|
-
Packet.PACKET_TYPE = 0;
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MASK_METADATA = exports.MASK_CONTROL_ASSET = exports.MASK_ASSET_ID = exports.AssetRefType = exports.AssetInputType = exports.ASSET_VERSION = exports.ASSET_ID_SIZE = exports.TX_HASH_SIZE = void 0;
|
|
4
|
-
exports.TX_HASH_SIZE = 32;
|
|
5
|
-
exports.ASSET_ID_SIZE = 34;
|
|
6
|
-
exports.ASSET_VERSION = 0x01;
|
|
7
|
-
var AssetInputType;
|
|
8
|
-
(function (AssetInputType) {
|
|
9
|
-
AssetInputType[AssetInputType["Unspecified"] = 0] = "Unspecified";
|
|
10
|
-
AssetInputType[AssetInputType["Local"] = 1] = "Local";
|
|
11
|
-
AssetInputType[AssetInputType["Intent"] = 2] = "Intent";
|
|
12
|
-
})(AssetInputType || (exports.AssetInputType = AssetInputType = {}));
|
|
13
|
-
var AssetRefType;
|
|
14
|
-
(function (AssetRefType) {
|
|
15
|
-
AssetRefType[AssetRefType["Unspecified"] = 0] = "Unspecified";
|
|
16
|
-
AssetRefType[AssetRefType["ByID"] = 1] = "ByID";
|
|
17
|
-
AssetRefType[AssetRefType["ByGroup"] = 2] = "ByGroup";
|
|
18
|
-
})(AssetRefType || (exports.AssetRefType = AssetRefType = {}));
|
|
19
|
-
// Presence byte masks for AssetGroup
|
|
20
|
-
exports.MASK_ASSET_ID = 0x01;
|
|
21
|
-
exports.MASK_CONTROL_ASSET = 0x02;
|
|
22
|
-
exports.MASK_METADATA = 0x04;
|