@arkade-os/sdk 0.4.27 → 0.4.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +45 -116
- package/dist/adapters/asyncStorage.cjs +48 -0
- package/dist/adapters/asyncStorage.cjs.map +1 -0
- package/dist/adapters/asyncStorage.d.cts +16 -0
- package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
- package/dist/adapters/asyncStorage.js +46 -0
- package/dist/adapters/asyncStorage.js.map +1 -0
- package/dist/adapters/expo.cjs +19 -0
- package/dist/adapters/expo.cjs.map +1 -0
- package/dist/adapters/expo.d.cts +48 -0
- package/dist/adapters/expo.d.ts +48 -0
- package/dist/adapters/expo.js +6 -0
- package/dist/adapters/expo.js.map +1 -0
- package/dist/adapters/fileSystem.cjs +116 -0
- package/dist/adapters/fileSystem.cjs.map +1 -0
- package/dist/adapters/fileSystem.d.cts +17 -0
- package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
- package/dist/adapters/fileSystem.js +93 -0
- package/dist/adapters/fileSystem.js.map +1 -0
- package/dist/adapters/indexedDB.cjs +103 -0
- package/dist/adapters/indexedDB.cjs.map +1 -0
- package/dist/adapters/indexedDB.d.cts +18 -0
- package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
- package/dist/adapters/indexedDB.js +101 -0
- package/dist/adapters/indexedDB.js.map +1 -0
- package/dist/adapters/localStorage.cjs +50 -0
- package/dist/adapters/localStorage.cjs.map +1 -0
- package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
- package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
- package/dist/adapters/localStorage.js +48 -0
- package/dist/adapters/localStorage.js.map +1 -0
- package/dist/ark-ChhTwpLf.d.cts +3892 -0
- package/dist/ark-ChhTwpLf.d.ts +3892 -0
- package/dist/asyncStorageTaskQueue-DW1-BpI7.d.cts +49 -0
- package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-DZ0nUuEJ.d.ts} +6 -3
- package/dist/chunk-5BLDMQED.cjs +18 -0
- package/dist/chunk-5BLDMQED.cjs.map +1 -0
- package/dist/chunk-6FLL2Q36.cjs +2701 -0
- package/dist/chunk-6FLL2Q36.cjs.map +1 -0
- package/dist/chunk-6NWNOLL3.js +2671 -0
- package/dist/chunk-6NWNOLL3.js.map +1 -0
- package/dist/chunk-ABWRLTX5.js +210 -0
- package/dist/chunk-ABWRLTX5.js.map +1 -0
- package/dist/chunk-BVP2U66Q.js +13943 -0
- package/dist/chunk-BVP2U66Q.js.map +1 -0
- package/dist/chunk-GDCTOSMV.cjs +14058 -0
- package/dist/chunk-GDCTOSMV.cjs.map +1 -0
- package/dist/chunk-GIGILVVP.cjs +213 -0
- package/dist/chunk-GIGILVVP.cjs.map +1 -0
- package/dist/chunk-IEO3XDKI.cjs +838 -0
- package/dist/chunk-IEO3XDKI.cjs.map +1 -0
- package/dist/chunk-NSBPE2FW.js +15 -0
- package/dist/chunk-NSBPE2FW.js.map +1 -0
- package/dist/chunk-PJUFOJ2L.cjs +100 -0
- package/dist/chunk-PJUFOJ2L.cjs.map +1 -0
- package/dist/chunk-TH6T23XG.js +95 -0
- package/dist/chunk-TH6T23XG.js.map +1 -0
- package/dist/chunk-TU3LVAPX.js +769 -0
- package/dist/chunk-TU3LVAPX.js.map +1 -0
- package/dist/chunk-WMIPYZSB.cjs +803 -0
- package/dist/chunk-WMIPYZSB.cjs.map +1 -0
- package/dist/chunk-YA4G7RFB.js +829 -0
- package/dist/chunk-YA4G7RFB.js.map +1 -0
- package/dist/contracts/handlers/index.cjs +26 -0
- package/dist/contracts/handlers/index.cjs.map +1 -0
- package/dist/contracts/handlers/index.d.cts +7 -0
- package/dist/contracts/handlers/index.d.ts +7 -0
- package/dist/contracts/handlers/index.js +5 -0
- package/dist/contracts/handlers/index.js.map +1 -0
- package/dist/delegate-4JBUkUhR.d.cts +84 -0
- package/dist/delegate-DN7RELL1.d.ts +84 -0
- package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
- package/dist/index-C0IanN1m.d.ts +11 -0
- package/dist/index-Cn82bBUu.d.ts +199 -0
- package/dist/index-DfT5xzgY.d.cts +199 -0
- package/dist/index.cjs +504 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +3469 -0
- package/dist/index.d.ts +3469 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/repositories/realm/index.cjs +513 -0
- package/dist/repositories/realm/index.cjs.map +1 -0
- package/dist/repositories/realm/index.d.cts +217 -0
- package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
- package/dist/repositories/realm/index.js +507 -0
- package/dist/repositories/realm/index.js.map +1 -0
- package/dist/repositories/sqlite/index.cjs +588 -0
- package/dist/repositories/sqlite/index.cjs.map +1 -0
- package/dist/repositories/sqlite/index.d.cts +118 -0
- package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
- package/dist/repositories/sqlite/index.js +585 -0
- package/dist/repositories/sqlite/index.js.map +1 -0
- package/dist/taskRunner-B-aPfHhK.d.cts +114 -0
- package/dist/taskRunner-B-vG08pX.d.ts +114 -0
- package/dist/wallet/expo/background.cjs +93 -0
- package/dist/wallet/expo/background.cjs.map +1 -0
- package/dist/wallet/expo/background.d.cts +84 -0
- package/dist/wallet/expo/background.d.ts +84 -0
- package/dist/wallet/expo/background.js +68 -0
- package/dist/wallet/expo/background.js.map +1 -0
- package/dist/wallet/expo/index.cjs +175 -0
- package/dist/wallet/expo/index.cjs.map +1 -0
- package/dist/wallet/expo/index.d.cts +124 -0
- package/dist/wallet/expo/index.d.ts +124 -0
- package/dist/wallet/expo/index.js +173 -0
- package/dist/wallet/expo/index.js.map +1 -0
- package/dist/wallet-CCtqT2Wb.d.ts +778 -0
- package/dist/wallet-DjgFb_4T.d.cts +778 -0
- package/dist/worker/expo/index.cjs +140 -0
- package/dist/worker/expo/index.cjs.map +1 -0
- package/dist/worker/expo/index.d.cts +29 -0
- package/dist/worker/expo/index.d.ts +29 -0
- package/dist/worker/expo/index.js +121 -0
- package/dist/worker/expo/index.js.map +1 -0
- package/package.json +110 -76
- package/dist/cjs/adapters/asyncStorage.js +0 -5
- package/dist/cjs/adapters/expo.js +0 -8
- package/dist/cjs/adapters/fileSystem.js +0 -5
- package/dist/cjs/adapters/indexedDB.js +0 -5
- package/dist/cjs/adapters/localStorage.js +0 -5
- package/dist/cjs/arkfee/celenv.js +0 -43
- package/dist/cjs/arkfee/estimator.js +0 -143
- package/dist/cjs/arkfee/index.js +0 -5
- package/dist/cjs/arkfee/types.js +0 -26
- package/dist/cjs/arknote/index.js +0 -128
- package/dist/cjs/bip322/index.js +0 -270
- package/dist/cjs/contracts/arkcontract.js +0 -147
- package/dist/cjs/contracts/contractManager.js +0 -649
- package/dist/cjs/contracts/contractWatcher.js +0 -598
- package/dist/cjs/contracts/handlers/default.js +0 -93
- package/dist/cjs/contracts/handlers/delegate.js +0 -90
- package/dist/cjs/contracts/handlers/helpers.js +0 -115
- package/dist/cjs/contracts/handlers/index.js +0 -19
- package/dist/cjs/contracts/handlers/registry.js +0 -89
- package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
- package/dist/cjs/contracts/index.js +0 -41
- package/dist/cjs/contracts/types.js +0 -2
- package/dist/cjs/contracts/vtxoOwnership.js +0 -78
- package/dist/cjs/extension/asset/assetGroup.js +0 -228
- package/dist/cjs/extension/asset/assetId.js +0 -152
- package/dist/cjs/extension/asset/assetInput.js +0 -222
- package/dist/cjs/extension/asset/assetOutput.js +0 -174
- package/dist/cjs/extension/asset/assetRef.js +0 -148
- package/dist/cjs/extension/asset/index.js +0 -23
- package/dist/cjs/extension/asset/metadata.js +0 -187
- package/dist/cjs/extension/asset/packet.js +0 -114
- package/dist/cjs/extension/asset/types.js +0 -22
- package/dist/cjs/extension/asset/utils.js +0 -105
- package/dist/cjs/extension/index.js +0 -254
- package/dist/cjs/extension/packet.js +0 -20
- package/dist/cjs/forfeit.js +0 -45
- package/dist/cjs/identity/descriptor.js +0 -169
- package/dist/cjs/identity/descriptorProvider.js +0 -2
- package/dist/cjs/identity/hdCapableIdentity.js +0 -20
- package/dist/cjs/identity/index.js +0 -40
- package/dist/cjs/identity/seedIdentity.js +0 -477
- package/dist/cjs/identity/serialize.js +0 -171
- package/dist/cjs/identity/singleKey.js +0 -126
- package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
- package/dist/cjs/index.js +0 -202
- package/dist/cjs/intent/index.js +0 -259
- package/dist/cjs/musig2/index.js +0 -11
- package/dist/cjs/musig2/keys.js +0 -57
- package/dist/cjs/musig2/nonces.js +0 -48
- package/dist/cjs/musig2/sign.js +0 -102
- package/dist/cjs/networks.js +0 -26
- package/dist/cjs/package.json +0 -3
- package/dist/cjs/providers/ark.js +0 -577
- package/dist/cjs/providers/delegator.js +0 -85
- package/dist/cjs/providers/electrum.js +0 -869
- package/dist/cjs/providers/errors.js +0 -59
- package/dist/cjs/providers/expoArk.js +0 -82
- package/dist/cjs/providers/expoIndexer.js +0 -111
- package/dist/cjs/providers/expoUtils.js +0 -124
- package/dist/cjs/providers/indexer.js +0 -630
- package/dist/cjs/providers/onchain.js +0 -262
- package/dist/cjs/providers/utils.js +0 -121
- package/dist/cjs/repositories/contractRepository.js +0 -2
- package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
- package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
- package/dist/cjs/repositories/index.js +0 -34
- package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
- package/dist/cjs/repositories/indexedDB/db.js +0 -19
- package/dist/cjs/repositories/indexedDB/manager.js +0 -100
- package/dist/cjs/repositories/indexedDB/schema.js +0 -204
- package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
- package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
- package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
- package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
- package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
- package/dist/cjs/repositories/realm/contractRepository.js +0 -116
- package/dist/cjs/repositories/realm/index.js +0 -11
- package/dist/cjs/repositories/realm/schemas.js +0 -157
- package/dist/cjs/repositories/realm/types.js +0 -7
- package/dist/cjs/repositories/realm/walletRepository.js +0 -305
- package/dist/cjs/repositories/scriptFromAddress.js +0 -16
- package/dist/cjs/repositories/serialization.js +0 -82
- package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
- package/dist/cjs/repositories/sqlite/index.js +0 -7
- package/dist/cjs/repositories/sqlite/types.js +0 -2
- package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
- package/dist/cjs/repositories/walletRepository.js +0 -2
- package/dist/cjs/script/address.js +0 -108
- package/dist/cjs/script/base.js +0 -185
- package/dist/cjs/script/default.js +0 -57
- package/dist/cjs/script/delegate.js +0 -53
- package/dist/cjs/script/tapscript.js +0 -619
- package/dist/cjs/script/vhtlc.js +0 -170
- package/dist/cjs/storage/asyncStorage.js +0 -50
- package/dist/cjs/storage/fileSystem.js +0 -141
- package/dist/cjs/storage/inMemory.js +0 -24
- package/dist/cjs/storage/index.js +0 -2
- package/dist/cjs/storage/indexedDB.js +0 -101
- package/dist/cjs/storage/localStorage.js +0 -51
- package/dist/cjs/tree/signingSession.js +0 -229
- package/dist/cjs/tree/txTree.js +0 -192
- package/dist/cjs/tree/validation.js +0 -107
- package/dist/cjs/utils/anchor.js +0 -35
- package/dist/cjs/utils/arkTransaction.js +0 -271
- package/dist/cjs/utils/bip21.js +0 -127
- package/dist/cjs/utils/syncCursors.js +0 -128
- package/dist/cjs/utils/timelock.js +0 -59
- package/dist/cjs/utils/transaction.js +0 -28
- package/dist/cjs/utils/transactionHistory.js +0 -183
- package/dist/cjs/utils/txSizeEstimator.js +0 -132
- package/dist/cjs/utils/unknownFields.js +0 -174
- package/dist/cjs/wallet/asset-manager.js +0 -330
- package/dist/cjs/wallet/asset.js +0 -119
- package/dist/cjs/wallet/batch.js +0 -183
- package/dist/cjs/wallet/delegator.js +0 -308
- package/dist/cjs/wallet/expo/background.js +0 -116
- package/dist/cjs/wallet/expo/index.js +0 -9
- package/dist/cjs/wallet/expo/wallet.js +0 -230
- package/dist/cjs/wallet/hdDescriptorProvider.js +0 -188
- package/dist/cjs/wallet/index.js +0 -82
- package/dist/cjs/wallet/inputSignerRouter.js +0 -98
- package/dist/cjs/wallet/onchain.js +0 -290
- package/dist/cjs/wallet/ramps.js +0 -216
- package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
- package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1174
- package/dist/cjs/wallet/signingErrors.js +0 -32
- package/dist/cjs/wallet/unroll.js +0 -293
- package/dist/cjs/wallet/utils.js +0 -111
- package/dist/cjs/wallet/validation.js +0 -154
- package/dist/cjs/wallet/vtxo-manager.js +0 -1142
- package/dist/cjs/wallet/wallet.js +0 -2195
- package/dist/cjs/wallet/walletReceiveRotator.js +0 -547
- package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
- package/dist/cjs/worker/browser/utils.js +0 -67
- package/dist/cjs/worker/errors.js +0 -16
- package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
- package/dist/cjs/worker/expo/index.js +0 -13
- package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
- package/dist/cjs/worker/expo/processors/index.js +0 -6
- package/dist/cjs/worker/expo/taskQueue.js +0 -41
- package/dist/cjs/worker/expo/taskRunner.js +0 -73
- package/dist/cjs/worker/messageBus.js +0 -474
- package/dist/esm/adapters/asyncStorage.js +0 -1
- package/dist/esm/adapters/expo.js +0 -3
- package/dist/esm/adapters/fileSystem.js +0 -1
- package/dist/esm/adapters/indexedDB.js +0 -1
- package/dist/esm/adapters/localStorage.js +0 -1
- package/dist/esm/arkfee/celenv.js +0 -40
- package/dist/esm/arkfee/estimator.js +0 -139
- package/dist/esm/arkfee/index.js +0 -1
- package/dist/esm/arkfee/types.js +0 -22
- package/dist/esm/arknote/index.js +0 -124
- package/dist/esm/bip322/index.js +0 -267
- package/dist/esm/contracts/arkcontract.js +0 -140
- package/dist/esm/contracts/contractManager.js +0 -645
- package/dist/esm/contracts/contractWatcher.js +0 -594
- package/dist/esm/contracts/handlers/default.js +0 -90
- package/dist/esm/contracts/handlers/delegate.js +0 -87
- package/dist/esm/contracts/handlers/helpers.js +0 -110
- package/dist/esm/contracts/handlers/index.js +0 -12
- package/dist/esm/contracts/handlers/registry.js +0 -86
- package/dist/esm/contracts/handlers/vhtlc.js +0 -191
- package/dist/esm/contracts/index.js +0 -13
- package/dist/esm/contracts/types.js +0 -1
- package/dist/esm/contracts/vtxoOwnership.js +0 -69
- package/dist/esm/extension/asset/assetGroup.js +0 -224
- package/dist/esm/extension/asset/assetId.js +0 -148
- package/dist/esm/extension/asset/assetInput.js +0 -217
- package/dist/esm/extension/asset/assetOutput.js +0 -169
- package/dist/esm/extension/asset/assetRef.js +0 -144
- package/dist/esm/extension/asset/index.js +0 -8
- package/dist/esm/extension/asset/metadata.js +0 -182
- package/dist/esm/extension/asset/packet.js +0 -110
- package/dist/esm/extension/asset/types.js +0 -19
- package/dist/esm/extension/asset/utils.js +0 -99
- package/dist/esm/extension/index.js +0 -248
- package/dist/esm/extension/packet.js +0 -16
- package/dist/esm/forfeit.js +0 -41
- package/dist/esm/identity/descriptor.js +0 -161
- package/dist/esm/identity/descriptorProvider.js +0 -1
- package/dist/esm/identity/hdCapableIdentity.js +0 -17
- package/dist/esm/identity/index.js +0 -13
- package/dist/esm/identity/seedIdentity.js +0 -469
- package/dist/esm/identity/serialize.js +0 -164
- package/dist/esm/identity/singleKey.js +0 -121
- package/dist/esm/identity/staticDescriptorProvider.js +0 -61
- package/dist/esm/index.js +0 -87
- package/dist/esm/intent/index.js +0 -255
- package/dist/esm/musig2/index.js +0 -3
- package/dist/esm/musig2/keys.js +0 -21
- package/dist/esm/musig2/nonces.js +0 -11
- package/dist/esm/musig2/sign.js +0 -63
- package/dist/esm/networks.js +0 -22
- package/dist/esm/package.json +0 -3
- package/dist/esm/providers/ark.js +0 -572
- package/dist/esm/providers/delegator.js +0 -81
- package/dist/esm/providers/electrum.js +0 -864
- package/dist/esm/providers/errors.js +0 -54
- package/dist/esm/providers/expoArk.js +0 -78
- package/dist/esm/providers/expoIndexer.js +0 -107
- package/dist/esm/providers/expoUtils.js +0 -87
- package/dist/esm/providers/indexer.js +0 -626
- package/dist/esm/providers/onchain.js +0 -258
- package/dist/esm/providers/utils.js +0 -117
- package/dist/esm/repositories/contractRepository.js +0 -1
- package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
- package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
- package/dist/esm/repositories/index.js +0 -10
- package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
- package/dist/esm/repositories/indexedDB/db.js +0 -4
- package/dist/esm/repositories/indexedDB/manager.js +0 -95
- package/dist/esm/repositories/indexedDB/schema.js +0 -199
- package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
- package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
- package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
- package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
- package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
- package/dist/esm/repositories/realm/contractRepository.js +0 -112
- package/dist/esm/repositories/realm/index.js +0 -3
- package/dist/esm/repositories/realm/schemas.js +0 -153
- package/dist/esm/repositories/realm/types.js +0 -6
- package/dist/esm/repositories/realm/walletRepository.js +0 -301
- package/dist/esm/repositories/scriptFromAddress.js +0 -13
- package/dist/esm/repositories/serialization.js +0 -67
- package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
- package/dist/esm/repositories/sqlite/index.js +0 -2
- package/dist/esm/repositories/sqlite/types.js +0 -1
- package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
- package/dist/esm/repositories/walletRepository.js +0 -1
- package/dist/esm/script/address.js +0 -104
- package/dist/esm/script/base.js +0 -179
- package/dist/esm/script/default.js +0 -54
- package/dist/esm/script/delegate.js +0 -50
- package/dist/esm/script/tapscript.js +0 -615
- package/dist/esm/script/vhtlc.js +0 -167
- package/dist/esm/storage/asyncStorage.js +0 -46
- package/dist/esm/storage/fileSystem.js +0 -104
- package/dist/esm/storage/inMemory.js +0 -20
- package/dist/esm/storage/index.js +0 -1
- package/dist/esm/storage/indexedDB.js +0 -97
- package/dist/esm/storage/localStorage.js +0 -47
- package/dist/esm/tree/signingSession.js +0 -191
- package/dist/esm/tree/txTree.js +0 -188
- package/dist/esm/tree/validation.js +0 -101
- package/dist/esm/utils/anchor.js +0 -31
- package/dist/esm/utils/arkTransaction.js +0 -264
- package/dist/esm/utils/bip21.js +0 -123
- package/dist/esm/utils/syncCursors.js +0 -119
- package/dist/esm/utils/timelock.js +0 -22
- package/dist/esm/utils/transaction.js +0 -24
- package/dist/esm/utils/transactionHistory.js +0 -180
- package/dist/esm/utils/txSizeEstimator.js +0 -128
- package/dist/esm/utils/unknownFields.js +0 -169
- package/dist/esm/wallet/asset-manager.js +0 -325
- package/dist/esm/wallet/asset.js +0 -113
- package/dist/esm/wallet/batch.js +0 -180
- package/dist/esm/wallet/delegator.js +0 -303
- package/dist/esm/wallet/expo/background.js +0 -111
- package/dist/esm/wallet/expo/index.js +0 -2
- package/dist/esm/wallet/expo/wallet.js +0 -193
- package/dist/esm/wallet/hdDescriptorProvider.js +0 -184
- package/dist/esm/wallet/index.js +0 -75
- package/dist/esm/wallet/inputSignerRouter.js +0 -94
- package/dist/esm/wallet/onchain.js +0 -285
- package/dist/esm/wallet/ramps.js +0 -212
- package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
- package/dist/esm/wallet/serviceWorker/wallet.js +0 -1169
- package/dist/esm/wallet/signingErrors.js +0 -27
- package/dist/esm/wallet/unroll.js +0 -289
- package/dist/esm/wallet/utils.js +0 -103
- package/dist/esm/wallet/validation.js +0 -142
- package/dist/esm/wallet/vtxo-manager.js +0 -1136
- package/dist/esm/wallet/wallet.js +0 -2186
- package/dist/esm/wallet/walletReceiveRotator.js +0 -540
- package/dist/esm/worker/browser/service-worker-manager.js +0 -177
- package/dist/esm/worker/browser/utils.js +0 -63
- package/dist/esm/worker/errors.js +0 -11
- package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
- package/dist/esm/worker/expo/index.js +0 -4
- package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
- package/dist/esm/worker/expo/processors/index.js +0 -1
- package/dist/esm/worker/expo/taskQueue.js +0 -37
- package/dist/esm/worker/expo/taskRunner.js +0 -69
- package/dist/esm/worker/messageBus.js +0 -470
- package/dist/types/adapters/asyncStorage.d.ts +0 -2
- package/dist/types/adapters/expo.d.ts +0 -4
- package/dist/types/adapters/fileSystem.d.ts +0 -2
- package/dist/types/adapters/indexedDB.d.ts +0 -2
- package/dist/types/adapters/localStorage.d.ts +0 -2
- package/dist/types/arkfee/celenv.d.ts +0 -25
- package/dist/types/arkfee/estimator.d.ts +0 -49
- package/dist/types/arkfee/index.d.ts +0 -2
- package/dist/types/arkfee/types.d.ts +0 -38
- package/dist/types/arknote/index.d.ts +0 -84
- package/dist/types/bip322/index.d.ts +0 -55
- package/dist/types/contracts/arkcontract.d.ts +0 -99
- package/dist/types/contracts/contractManager.d.ts +0 -411
- package/dist/types/contracts/contractWatcher.d.ts +0 -217
- package/dist/types/contracts/handlers/default.d.ts +0 -19
- package/dist/types/contracts/handlers/delegate.d.ts +0 -21
- package/dist/types/contracts/handlers/helpers.d.ts +0 -19
- package/dist/types/contracts/handlers/index.d.ts +0 -7
- package/dist/types/contracts/handlers/registry.d.ts +0 -65
- package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
- package/dist/types/contracts/index.d.ts +0 -14
- package/dist/types/contracts/types.d.ts +0 -250
- package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
- package/dist/types/extension/asset/assetGroup.d.ts +0 -119
- package/dist/types/extension/asset/assetId.d.ts +0 -83
- package/dist/types/extension/asset/assetInput.d.ts +0 -64
- package/dist/types/extension/asset/assetOutput.d.ts +0 -54
- package/dist/types/extension/asset/assetRef.d.ts +0 -91
- package/dist/types/extension/asset/index.d.ts +0 -8
- package/dist/types/extension/asset/metadata.d.ts +0 -52
- package/dist/types/extension/asset/packet.d.ts +0 -41
- package/dist/types/extension/asset/types.d.ts +0 -16
- package/dist/types/extension/asset/utils.d.ts +0 -21
- package/dist/types/extension/index.d.ts +0 -56
- package/dist/types/extension/packet.d.ts +0 -21
- package/dist/types/forfeit.d.ts +0 -18
- package/dist/types/identity/descriptor.d.ts +0 -61
- package/dist/types/identity/descriptorProvider.d.ts +0 -42
- package/dist/types/identity/hdCapableIdentity.d.ts +0 -71
- package/dist/types/identity/index.d.ts +0 -57
- package/dist/types/identity/seedIdentity.d.ts +0 -270
- package/dist/types/identity/serialize.d.ts +0 -96
- package/dist/types/identity/singleKey.d.ts +0 -62
- package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
- package/dist/types/index.d.ts +0 -59
- package/dist/types/intent/index.d.ts +0 -86
- package/dist/types/musig2/index.d.ts +0 -4
- package/dist/types/musig2/keys.d.ts +0 -9
- package/dist/types/musig2/nonces.d.ts +0 -14
- package/dist/types/musig2/sign.d.ts +0 -27
- package/dist/types/networks.d.ts +0 -16
- package/dist/types/providers/ark.d.ts +0 -369
- package/dist/types/providers/delegator.d.ts +0 -82
- package/dist/types/providers/electrum.d.ts +0 -312
- package/dist/types/providers/errors.d.ts +0 -13
- package/dist/types/providers/expoArk.d.ts +0 -22
- package/dist/types/providers/expoIndexer.d.ts +0 -18
- package/dist/types/providers/expoUtils.d.ts +0 -18
- package/dist/types/providers/indexer.d.ts +0 -301
- package/dist/types/providers/onchain.d.ts +0 -148
- package/dist/types/providers/utils.d.ts +0 -12
- package/dist/types/repositories/contractRepository.d.ts +0 -32
- package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
- package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
- package/dist/types/repositories/index.d.ts +0 -9
- package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
- package/dist/types/repositories/indexedDB/db.d.ts +0 -4
- package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
- package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
- package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
- package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
- package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
- package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
- package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
- package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
- package/dist/types/repositories/realm/index.d.ts +0 -4
- package/dist/types/repositories/realm/types.d.ts +0 -16
- package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
- package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
- package/dist/types/repositories/serialization.d.ts +0 -65
- package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
- package/dist/types/repositories/sqlite/index.d.ts +0 -3
- package/dist/types/repositories/sqlite/types.d.ts +0 -18
- package/dist/types/repositories/walletRepository.d.ts +0 -72
- package/dist/types/script/address.d.ts +0 -67
- package/dist/types/script/base.d.ts +0 -105
- package/dist/types/script/default.d.ts +0 -44
- package/dist/types/script/delegate.d.ts +0 -40
- package/dist/types/script/tapscript.d.ts +0 -169
- package/dist/types/script/vhtlc.d.ts +0 -66
- package/dist/types/tree/signingSession.d.ts +0 -37
- package/dist/types/tree/txTree.d.ts +0 -28
- package/dist/types/tree/validation.d.ts +0 -15
- package/dist/types/utils/anchor.d.ts +0 -19
- package/dist/types/utils/arkTransaction.d.ts +0 -49
- package/dist/types/utils/bip21.d.ts +0 -38
- package/dist/types/utils/syncCursors.d.ts +0 -60
- package/dist/types/utils/timelock.d.ts +0 -9
- package/dist/types/utils/transaction.d.ts +0 -13
- package/dist/types/utils/transactionHistory.d.ts +0 -15
- package/dist/types/utils/txSizeEstimator.d.ts +0 -40
- package/dist/types/utils/unknownFields.d.ts +0 -83
- package/dist/types/wallet/asset-manager.d.ts +0 -69
- package/dist/types/wallet/asset.d.ts +0 -21
- package/dist/types/wallet/batch.d.ts +0 -107
- package/dist/types/wallet/delegator.d.ts +0 -48
- package/dist/types/wallet/expo/background.d.ts +0 -66
- package/dist/types/wallet/expo/index.d.ts +0 -4
- package/dist/types/wallet/expo/wallet.d.ts +0 -99
- package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -114
- package/dist/types/wallet/index.d.ts +0 -789
- package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
- package/dist/types/wallet/onchain.d.ts +0 -109
- package/dist/types/wallet/ramps.d.ts +0 -64
- package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
- package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -248
- package/dist/types/wallet/signingErrors.d.ts +0 -19
- package/dist/types/wallet/unroll.d.ts +0 -114
- package/dist/types/wallet/utils.d.ts +0 -36
- package/dist/types/wallet/validation.d.ts +0 -24
- package/dist/types/wallet/vtxo-manager.d.ts +0 -476
- package/dist/types/wallet/wallet.d.ts +0 -409
- package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
- package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
- package/dist/types/worker/browser/utils.d.ts +0 -17
- package/dist/types/worker/errors.d.ts +0 -7
- package/dist/types/worker/expo/index.d.ts +0 -7
- package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
- package/dist/types/worker/expo/processors/index.d.ts +0 -1
- package/dist/types/worker/expo/taskQueue.d.ts +0 -50
- package/dist/types/worker/expo/taskRunner.d.ts +0 -66
- package/dist/types/worker/messageBus.d.ts +0 -189
package/dist/esm/script/vhtlc.js
DELETED
|
@@ -1,167 +0,0 @@
|
|
|
1
|
-
import { Script } from "@scure/btc-signer";
|
|
2
|
-
import { CLTVMultisigTapscript, ConditionCSVMultisigTapscript, ConditionMultisigTapscript, CSVMultisigTapscript, MultisigTapscript, } from "./tapscript.js";
|
|
3
|
-
import { hex } from "@scure/base";
|
|
4
|
-
import { VtxoScript } from "./base.js";
|
|
5
|
-
/** Virtual Hash Time Lock Contract (VHTLC) namespace. */
|
|
6
|
-
export var VHTLC;
|
|
7
|
-
(function (VHTLC) {
|
|
8
|
-
/**
|
|
9
|
-
* Virtual Hash Time Lock Contract (VHTLC) script implementation.
|
|
10
|
-
*
|
|
11
|
-
* VHTLC enables atomic swaps and conditional payments in the Arkade protocol.
|
|
12
|
-
* It provides multiple spending paths:
|
|
13
|
-
*
|
|
14
|
-
* - **claim**: Receiver can claim funds by revealing the preimage
|
|
15
|
-
* - **refund**: Sender and receiver can collaboratively refund
|
|
16
|
-
* - **refundWithoutReceiver**: Sender can refund after locktime expires
|
|
17
|
-
* - **unilateralClaim**: Receiver can claim unilaterally after delay
|
|
18
|
-
* - **unilateralRefund**: Sender and receiver can refund unilaterally after delay
|
|
19
|
-
* - **unilateralRefundWithoutReceiver**: Sender can refund unilaterally after delay
|
|
20
|
-
*
|
|
21
|
-
* @example
|
|
22
|
-
* ```typescript
|
|
23
|
-
* const vhtlc = new VHTLC.Script({
|
|
24
|
-
* sender: alicePubKey,
|
|
25
|
-
* receiver: bobPubKey,
|
|
26
|
-
* server: serverPubKey,
|
|
27
|
-
* preimageHash: hash160(secret),
|
|
28
|
-
* refundLocktime: BigInt(chainTip + 10),
|
|
29
|
-
* unilateralClaimDelay: { type: 'blocks', value: 100n },
|
|
30
|
-
* unilateralRefundDelay: { type: 'blocks', value: 102n },
|
|
31
|
-
* unilateralRefundWithoutReceiverDelay: { type: 'blocks', value: 103n }
|
|
32
|
-
* });
|
|
33
|
-
* ```
|
|
34
|
-
*/
|
|
35
|
-
class Script extends VtxoScript {
|
|
36
|
-
/** Create a VHTLC script from the supplied participant keys, hash, and timelocks. */
|
|
37
|
-
constructor(options) {
|
|
38
|
-
validateOptions(options);
|
|
39
|
-
const { sender, receiver, server, preimageHash, refundLocktime, unilateralClaimDelay, unilateralRefundDelay, unilateralRefundWithoutReceiverDelay, } = options;
|
|
40
|
-
const conditionScript = preimageConditionScript(preimageHash);
|
|
41
|
-
const claimScript = ConditionMultisigTapscript.encode({
|
|
42
|
-
conditionScript,
|
|
43
|
-
pubkeys: [receiver, server],
|
|
44
|
-
}).script;
|
|
45
|
-
const refundScript = MultisigTapscript.encode({
|
|
46
|
-
pubkeys: [sender, receiver, server],
|
|
47
|
-
}).script;
|
|
48
|
-
const refundWithoutReceiverScript = CLTVMultisigTapscript.encode({
|
|
49
|
-
absoluteTimelock: refundLocktime,
|
|
50
|
-
pubkeys: [sender, server],
|
|
51
|
-
}).script;
|
|
52
|
-
const unilateralClaimScript = ConditionCSVMultisigTapscript.encode({
|
|
53
|
-
conditionScript,
|
|
54
|
-
timelock: unilateralClaimDelay,
|
|
55
|
-
pubkeys: [receiver],
|
|
56
|
-
}).script;
|
|
57
|
-
const unilateralRefundScript = CSVMultisigTapscript.encode({
|
|
58
|
-
timelock: unilateralRefundDelay,
|
|
59
|
-
pubkeys: [sender, receiver],
|
|
60
|
-
}).script;
|
|
61
|
-
const unilateralRefundWithoutReceiverScript = CSVMultisigTapscript.encode({
|
|
62
|
-
timelock: unilateralRefundWithoutReceiverDelay,
|
|
63
|
-
pubkeys: [sender],
|
|
64
|
-
}).script;
|
|
65
|
-
super([
|
|
66
|
-
claimScript,
|
|
67
|
-
refundScript,
|
|
68
|
-
refundWithoutReceiverScript,
|
|
69
|
-
unilateralClaimScript,
|
|
70
|
-
unilateralRefundScript,
|
|
71
|
-
unilateralRefundWithoutReceiverScript,
|
|
72
|
-
]);
|
|
73
|
-
this.options = options;
|
|
74
|
-
this.claimScript = hex.encode(claimScript);
|
|
75
|
-
this.refundScript = hex.encode(refundScript);
|
|
76
|
-
this.refundWithoutReceiverScript = hex.encode(refundWithoutReceiverScript);
|
|
77
|
-
this.unilateralClaimScript = hex.encode(unilateralClaimScript);
|
|
78
|
-
this.unilateralRefundScript = hex.encode(unilateralRefundScript);
|
|
79
|
-
this.unilateralRefundWithoutReceiverScript = hex.encode(unilateralRefundWithoutReceiverScript);
|
|
80
|
-
}
|
|
81
|
-
/** Return the collaborative claim tapleaf script. */
|
|
82
|
-
claim() {
|
|
83
|
-
return this.findLeaf(this.claimScript);
|
|
84
|
-
}
|
|
85
|
-
/** Return the collaborative refund tapleaf script. */
|
|
86
|
-
refund() {
|
|
87
|
-
return this.findLeaf(this.refundScript);
|
|
88
|
-
}
|
|
89
|
-
/** Return the refund-without-receiver tapleaf script. */
|
|
90
|
-
refundWithoutReceiver() {
|
|
91
|
-
return this.findLeaf(this.refundWithoutReceiverScript);
|
|
92
|
-
}
|
|
93
|
-
/** Return the unilateral claim tapleaf script. */
|
|
94
|
-
unilateralClaim() {
|
|
95
|
-
return this.findLeaf(this.unilateralClaimScript);
|
|
96
|
-
}
|
|
97
|
-
/** Return the unilateral refund tapleaf script. */
|
|
98
|
-
unilateralRefund() {
|
|
99
|
-
return this.findLeaf(this.unilateralRefundScript);
|
|
100
|
-
}
|
|
101
|
-
/** Return the unilateral refund-without-receiver tapleaf script. */
|
|
102
|
-
unilateralRefundWithoutReceiver() {
|
|
103
|
-
return this.findLeaf(this.unilateralRefundWithoutReceiverScript);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
VHTLC.Script = Script;
|
|
107
|
-
function validateOptions(options) {
|
|
108
|
-
const { sender, receiver, server, preimageHash, refundLocktime, unilateralClaimDelay, unilateralRefundDelay, unilateralRefundWithoutReceiverDelay, } = options;
|
|
109
|
-
if (!preimageHash || preimageHash.length !== 20) {
|
|
110
|
-
throw new Error("preimage hash must be 20 bytes");
|
|
111
|
-
}
|
|
112
|
-
if (!receiver || receiver.length !== 32) {
|
|
113
|
-
throw new Error("Invalid public key length (receiver)");
|
|
114
|
-
}
|
|
115
|
-
if (!sender || sender.length !== 32) {
|
|
116
|
-
throw new Error("Invalid public key length (sender)");
|
|
117
|
-
}
|
|
118
|
-
if (!server || server.length !== 32) {
|
|
119
|
-
throw new Error("Invalid public key length (server)");
|
|
120
|
-
}
|
|
121
|
-
if (typeof refundLocktime !== "bigint" || refundLocktime <= 0n) {
|
|
122
|
-
throw new Error("refund locktime must be greater than 0");
|
|
123
|
-
}
|
|
124
|
-
if (!unilateralClaimDelay ||
|
|
125
|
-
typeof unilateralClaimDelay.value !== "bigint" ||
|
|
126
|
-
unilateralClaimDelay.value <= 0n) {
|
|
127
|
-
throw new Error("unilateral claim delay must greater than 0");
|
|
128
|
-
}
|
|
129
|
-
if (unilateralClaimDelay.type === "seconds" &&
|
|
130
|
-
unilateralClaimDelay.value % 512n !== 0n) {
|
|
131
|
-
throw new Error("seconds timelock must be multiple of 512");
|
|
132
|
-
}
|
|
133
|
-
if (unilateralClaimDelay.type === "seconds" &&
|
|
134
|
-
unilateralClaimDelay.value < 512n) {
|
|
135
|
-
throw new Error("seconds timelock must be greater or equal to 512");
|
|
136
|
-
}
|
|
137
|
-
if (!unilateralRefundDelay ||
|
|
138
|
-
typeof unilateralRefundDelay.value !== "bigint" ||
|
|
139
|
-
unilateralRefundDelay.value <= 0n) {
|
|
140
|
-
throw new Error("unilateral refund delay must greater than 0");
|
|
141
|
-
}
|
|
142
|
-
if (unilateralRefundDelay.type === "seconds" &&
|
|
143
|
-
unilateralRefundDelay.value % 512n !== 0n) {
|
|
144
|
-
throw new Error("seconds timelock must be multiple of 512");
|
|
145
|
-
}
|
|
146
|
-
if (unilateralRefundDelay.type === "seconds" &&
|
|
147
|
-
unilateralRefundDelay.value < 512n) {
|
|
148
|
-
throw new Error("seconds timelock must be greater or equal to 512");
|
|
149
|
-
}
|
|
150
|
-
if (!unilateralRefundWithoutReceiverDelay ||
|
|
151
|
-
typeof unilateralRefundWithoutReceiverDelay.value !== "bigint" ||
|
|
152
|
-
unilateralRefundWithoutReceiverDelay.value <= 0n) {
|
|
153
|
-
throw new Error("unilateral refund without receiver delay must greater than 0");
|
|
154
|
-
}
|
|
155
|
-
if (unilateralRefundWithoutReceiverDelay.type === "seconds" &&
|
|
156
|
-
unilateralRefundWithoutReceiverDelay.value % 512n !== 0n) {
|
|
157
|
-
throw new Error("seconds timelock must be multiple of 512");
|
|
158
|
-
}
|
|
159
|
-
if (unilateralRefundWithoutReceiverDelay.type === "seconds" &&
|
|
160
|
-
unilateralRefundWithoutReceiverDelay.value < 512n) {
|
|
161
|
-
throw new Error("seconds timelock must be greater or equal to 512");
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
})(VHTLC || (VHTLC = {}));
|
|
165
|
-
function preimageConditionScript(preimageHash) {
|
|
166
|
-
return Script.encode(["HASH160", preimageHash, "EQUAL"]);
|
|
167
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @deprecated Use repositories instead
|
|
3
|
-
* Note: This requires @react-native-async-storage/async-storage to be installed
|
|
4
|
-
*/
|
|
5
|
-
export class AsyncStorageAdapter {
|
|
6
|
-
constructor() {
|
|
7
|
-
try {
|
|
8
|
-
// Dynamic import to avoid errors in non-React Native environments
|
|
9
|
-
this.AsyncStorage =
|
|
10
|
-
require("@react-native-async-storage/async-storage").default;
|
|
11
|
-
}
|
|
12
|
-
catch (error) {
|
|
13
|
-
throw new Error("AsyncStorage is not available. Make sure @react-native-async-storage/async-storage is installed in React Native environment.");
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
async getItem(key) {
|
|
17
|
-
return await this.AsyncStorage.getItem(key);
|
|
18
|
-
}
|
|
19
|
-
async setItem(key, value) {
|
|
20
|
-
try {
|
|
21
|
-
await this.AsyncStorage.setItem(key, value);
|
|
22
|
-
}
|
|
23
|
-
catch (error) {
|
|
24
|
-
console.error(`Failed to set item for key ${key}:`, error);
|
|
25
|
-
throw error;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
async removeItem(key) {
|
|
29
|
-
try {
|
|
30
|
-
await this.AsyncStorage.removeItem(key);
|
|
31
|
-
}
|
|
32
|
-
catch (error) {
|
|
33
|
-
console.error(`Failed to remove item for key ${key}:`, error);
|
|
34
|
-
throw error;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
async clear() {
|
|
38
|
-
try {
|
|
39
|
-
await this.AsyncStorage.clear();
|
|
40
|
-
}
|
|
41
|
-
catch (error) {
|
|
42
|
-
console.error("Failed to clear AsyncStorage:", error);
|
|
43
|
-
throw error;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
}
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import * as fs from "fs/promises";
|
|
2
|
-
import * as path from "path";
|
|
3
|
-
/**
|
|
4
|
-
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
5
|
-
*/
|
|
6
|
-
export class FileSystemStorageAdapter {
|
|
7
|
-
constructor(dirPath) {
|
|
8
|
-
// Normalize and resolve the storage base path once
|
|
9
|
-
this.basePath = path.resolve(dirPath).replace(/[/\\]+$/, "");
|
|
10
|
-
}
|
|
11
|
-
validateAndGetFilePath(key) {
|
|
12
|
-
// Reject dangerous keys
|
|
13
|
-
if (key === "." || key === "..") {
|
|
14
|
-
throw new Error("Invalid key: '.' and '..' are not allowed");
|
|
15
|
-
}
|
|
16
|
-
// Check for null bytes
|
|
17
|
-
if (key.includes("\0")) {
|
|
18
|
-
throw new Error("Invalid key: null bytes are not allowed");
|
|
19
|
-
}
|
|
20
|
-
// Check for path traversal attempts before normalization
|
|
21
|
-
if (key.includes("..")) {
|
|
22
|
-
throw new Error("Invalid key: directory traversal is not allowed");
|
|
23
|
-
}
|
|
24
|
-
// Check for reserved Windows names (case-insensitive)
|
|
25
|
-
const reservedNames = /^(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])$/i;
|
|
26
|
-
const keyWithoutExt = key.split(".")[0];
|
|
27
|
-
if (reservedNames.test(keyWithoutExt)) {
|
|
28
|
-
throw new Error(`Invalid key: '${key}' uses a reserved Windows name`);
|
|
29
|
-
}
|
|
30
|
-
// Check for trailing spaces or dots
|
|
31
|
-
if (key.endsWith(" ") || key.endsWith(".")) {
|
|
32
|
-
throw new Error("Invalid key: trailing spaces or dots are not allowed");
|
|
33
|
-
}
|
|
34
|
-
// Normalize path separators and sanitize key
|
|
35
|
-
const normalizedKey = key
|
|
36
|
-
.replace(/[/\\]/g, "_")
|
|
37
|
-
.replace(/[^a-zA-Z0-9._-]/g, "_");
|
|
38
|
-
// Resolve the full path and check for directory traversal
|
|
39
|
-
const resolved = path.resolve(this.basePath, normalizedKey);
|
|
40
|
-
const relative = path.relative(this.basePath, resolved);
|
|
41
|
-
// Reject if trying to escape the base directory
|
|
42
|
-
if (relative.startsWith("..") || relative.includes(path.sep + "..")) {
|
|
43
|
-
throw new Error("Invalid key: directory traversal is not allowed");
|
|
44
|
-
}
|
|
45
|
-
return resolved;
|
|
46
|
-
}
|
|
47
|
-
async ensureDirectory() {
|
|
48
|
-
try {
|
|
49
|
-
await fs.access(this.basePath);
|
|
50
|
-
}
|
|
51
|
-
catch {
|
|
52
|
-
await fs.mkdir(this.basePath, { recursive: true });
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
async getItem(key) {
|
|
56
|
-
try {
|
|
57
|
-
const filePath = this.validateAndGetFilePath(key);
|
|
58
|
-
const data = await fs.readFile(filePath, "utf-8");
|
|
59
|
-
return data;
|
|
60
|
-
}
|
|
61
|
-
catch (error) {
|
|
62
|
-
if (error.code === "ENOENT") {
|
|
63
|
-
return null;
|
|
64
|
-
}
|
|
65
|
-
console.error(`Failed to read file for key ${key}:`, error);
|
|
66
|
-
return null;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
async setItem(key, value) {
|
|
70
|
-
try {
|
|
71
|
-
await this.ensureDirectory();
|
|
72
|
-
const filePath = this.validateAndGetFilePath(key);
|
|
73
|
-
await fs.writeFile(filePath, value, "utf-8");
|
|
74
|
-
}
|
|
75
|
-
catch (error) {
|
|
76
|
-
console.error(`Failed to write file for key ${key}:`, error);
|
|
77
|
-
throw error;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
async removeItem(key) {
|
|
81
|
-
try {
|
|
82
|
-
const filePath = this.validateAndGetFilePath(key);
|
|
83
|
-
await fs.unlink(filePath);
|
|
84
|
-
}
|
|
85
|
-
catch (error) {
|
|
86
|
-
if (error.code !== "ENOENT") {
|
|
87
|
-
console.error(`Failed to remove file for key ${key}:`, error);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
async clear() {
|
|
92
|
-
try {
|
|
93
|
-
const entries = await fs.readdir(this.basePath);
|
|
94
|
-
await Promise.all(entries.map(async (entry) => {
|
|
95
|
-
const entryPath = path.join(this.basePath, entry);
|
|
96
|
-
// Use fs.rm with recursive option to handle both files and directories
|
|
97
|
-
await fs.rm(entryPath, { recursive: true, force: true });
|
|
98
|
-
}));
|
|
99
|
-
}
|
|
100
|
-
catch (error) {
|
|
101
|
-
console.error("Failed to clear storage directory:", error);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
3
|
-
*/
|
|
4
|
-
export class InMemoryStorageAdapter {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.store = new Map();
|
|
7
|
-
}
|
|
8
|
-
async getItem(key) {
|
|
9
|
-
return this.store.get(key) ?? null;
|
|
10
|
-
}
|
|
11
|
-
async setItem(key, value) {
|
|
12
|
-
this.store.set(key, value);
|
|
13
|
-
}
|
|
14
|
-
async removeItem(key) {
|
|
15
|
-
this.store.delete(key);
|
|
16
|
-
}
|
|
17
|
-
async clear() {
|
|
18
|
-
this.store.clear();
|
|
19
|
-
}
|
|
20
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
import { DB_VERSION } from "../repositories/indexedDB/db.js";
|
|
2
|
-
/**
|
|
3
|
-
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
4
|
-
*/
|
|
5
|
-
export class IndexedDBStorageAdapter {
|
|
6
|
-
constructor(dbName, version = DB_VERSION) {
|
|
7
|
-
this.db = null;
|
|
8
|
-
this.dbName = dbName;
|
|
9
|
-
this.version = version;
|
|
10
|
-
}
|
|
11
|
-
async getDB() {
|
|
12
|
-
if (this.db)
|
|
13
|
-
return this.db;
|
|
14
|
-
const globalObject = typeof window === "undefined" ? self : window;
|
|
15
|
-
if (!(globalObject && "indexedDB" in globalObject)) {
|
|
16
|
-
throw new Error("IndexedDB is not available in this environment");
|
|
17
|
-
}
|
|
18
|
-
return new Promise((resolve, reject) => {
|
|
19
|
-
const request = globalObject.indexedDB.open(this.dbName, this.version);
|
|
20
|
-
request.onerror = () => reject(request.error);
|
|
21
|
-
request.onsuccess = () => {
|
|
22
|
-
this.db = request.result;
|
|
23
|
-
resolve(this.db);
|
|
24
|
-
};
|
|
25
|
-
request.onupgradeneeded = () => {
|
|
26
|
-
const db = request.result;
|
|
27
|
-
if (!db.objectStoreNames.contains("storage")) {
|
|
28
|
-
db.createObjectStore("storage");
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
async getItem(key) {
|
|
34
|
-
try {
|
|
35
|
-
const db = await this.getDB();
|
|
36
|
-
return new Promise((resolve, reject) => {
|
|
37
|
-
const transaction = db.transaction(["storage"], "readonly");
|
|
38
|
-
const store = transaction.objectStore("storage");
|
|
39
|
-
const request = store.get(key);
|
|
40
|
-
request.onerror = () => reject(request.error);
|
|
41
|
-
request.onsuccess = () => {
|
|
42
|
-
resolve(request.result || null);
|
|
43
|
-
};
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
catch (error) {
|
|
47
|
-
console.error(`Failed to get item for key ${key}:`, error);
|
|
48
|
-
return null;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
async setItem(key, value) {
|
|
52
|
-
try {
|
|
53
|
-
const db = await this.getDB();
|
|
54
|
-
return new Promise((resolve, reject) => {
|
|
55
|
-
const transaction = db.transaction(["storage"], "readwrite");
|
|
56
|
-
const store = transaction.objectStore("storage");
|
|
57
|
-
const request = store.put(value, key);
|
|
58
|
-
request.onerror = () => reject(request.error);
|
|
59
|
-
request.onsuccess = () => resolve();
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
catch (error) {
|
|
63
|
-
console.error(`Failed to set item for key ${key}:`, error);
|
|
64
|
-
throw error;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
async removeItem(key) {
|
|
68
|
-
try {
|
|
69
|
-
const db = await this.getDB();
|
|
70
|
-
return new Promise((resolve, reject) => {
|
|
71
|
-
const transaction = db.transaction(["storage"], "readwrite");
|
|
72
|
-
const store = transaction.objectStore("storage");
|
|
73
|
-
const request = store.delete(key);
|
|
74
|
-
request.onerror = () => reject(request.error);
|
|
75
|
-
request.onsuccess = () => resolve();
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
catch (error) {
|
|
79
|
-
console.error(`Failed to remove item for key ${key}:`, error);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
async clear() {
|
|
83
|
-
try {
|
|
84
|
-
const db = await this.getDB();
|
|
85
|
-
return new Promise((resolve, reject) => {
|
|
86
|
-
const transaction = db.transaction(["storage"], "readwrite");
|
|
87
|
-
const store = transaction.objectStore("storage");
|
|
88
|
-
const request = store.clear();
|
|
89
|
-
request.onerror = () => reject(request.error);
|
|
90
|
-
request.onsuccess = () => resolve();
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
catch (error) {
|
|
94
|
-
console.error("Failed to clear storage:", error);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
3
|
-
*/
|
|
4
|
-
export class LocalStorageAdapter {
|
|
5
|
-
getSafeLocalStorage() {
|
|
6
|
-
try {
|
|
7
|
-
if (typeof window === "undefined" || !window.localStorage) {
|
|
8
|
-
return null;
|
|
9
|
-
}
|
|
10
|
-
// Test access to ensure localStorage is actually available
|
|
11
|
-
window.localStorage.length;
|
|
12
|
-
return window.localStorage;
|
|
13
|
-
}
|
|
14
|
-
catch {
|
|
15
|
-
// localStorage may throw in some environments (e.g., private browsing, disabled storage)
|
|
16
|
-
return null;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
async getItem(key) {
|
|
20
|
-
const localStorage = this.getSafeLocalStorage();
|
|
21
|
-
if (!localStorage) {
|
|
22
|
-
throw new Error("localStorage is not available in this environment");
|
|
23
|
-
}
|
|
24
|
-
return localStorage.getItem(key);
|
|
25
|
-
}
|
|
26
|
-
async setItem(key, value) {
|
|
27
|
-
const localStorage = this.getSafeLocalStorage();
|
|
28
|
-
if (!localStorage) {
|
|
29
|
-
throw new Error("localStorage is not available in this environment");
|
|
30
|
-
}
|
|
31
|
-
localStorage.setItem(key, value);
|
|
32
|
-
}
|
|
33
|
-
async removeItem(key) {
|
|
34
|
-
const localStorage = this.getSafeLocalStorage();
|
|
35
|
-
if (!localStorage) {
|
|
36
|
-
throw new Error("localStorage is not available in this environment");
|
|
37
|
-
}
|
|
38
|
-
localStorage.removeItem(key);
|
|
39
|
-
}
|
|
40
|
-
async clear() {
|
|
41
|
-
const localStorage = this.getSafeLocalStorage();
|
|
42
|
-
if (!localStorage) {
|
|
43
|
-
throw new Error("localStorage is not available in this environment");
|
|
44
|
-
}
|
|
45
|
-
localStorage.clear();
|
|
46
|
-
}
|
|
47
|
-
}
|
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
import * as musig2 from "../musig2/index.js";
|
|
2
|
-
import { Script } from "@scure/btc-signer/script.js";
|
|
3
|
-
import { SigHash } from "@scure/btc-signer/transaction.js";
|
|
4
|
-
import { hex } from "@scure/base";
|
|
5
|
-
import { schnorr, secp256k1 } from "@noble/curves/secp256k1.js";
|
|
6
|
-
import { randomPrivateKeyBytes } from "@scure/btc-signer/utils.js";
|
|
7
|
-
import { CosignerPublicKey, getArkPsbtFields } from "../utils/unknownFields.js";
|
|
8
|
-
export const ErrMissingVtxoGraph = new Error("missing vtxo graph");
|
|
9
|
-
export const ErrMissingAggregateKey = new Error("missing aggregate key");
|
|
10
|
-
export class TreeSignerSession {
|
|
11
|
-
constructor(secretKey) {
|
|
12
|
-
this.secretKey = secretKey;
|
|
13
|
-
this.myNonces = null;
|
|
14
|
-
this.aggregateNonces = null;
|
|
15
|
-
this.graph = null;
|
|
16
|
-
this.scriptRoot = null;
|
|
17
|
-
this.rootSharedOutputAmount = null;
|
|
18
|
-
}
|
|
19
|
-
static random() {
|
|
20
|
-
const secretKey = randomPrivateKeyBytes();
|
|
21
|
-
return new TreeSignerSession(secretKey);
|
|
22
|
-
}
|
|
23
|
-
async init(tree, scriptRoot, rootInputAmount) {
|
|
24
|
-
this.graph = tree;
|
|
25
|
-
this.scriptRoot = scriptRoot;
|
|
26
|
-
this.rootSharedOutputAmount = rootInputAmount;
|
|
27
|
-
}
|
|
28
|
-
async getPublicKey() {
|
|
29
|
-
return secp256k1.getPublicKey(this.secretKey);
|
|
30
|
-
}
|
|
31
|
-
async getNonces() {
|
|
32
|
-
if (!this.graph)
|
|
33
|
-
throw ErrMissingVtxoGraph;
|
|
34
|
-
if (!this.myNonces) {
|
|
35
|
-
this.myNonces = this.generateNonces();
|
|
36
|
-
}
|
|
37
|
-
const publicNonces = new Map();
|
|
38
|
-
for (const [txid, nonces] of this.myNonces) {
|
|
39
|
-
publicNonces.set(txid, { pubNonce: nonces.pubNonce });
|
|
40
|
-
}
|
|
41
|
-
return publicNonces;
|
|
42
|
-
}
|
|
43
|
-
async aggregatedNonces(txid, noncesByPubkey) {
|
|
44
|
-
if (!this.graph)
|
|
45
|
-
throw ErrMissingVtxoGraph;
|
|
46
|
-
if (!this.aggregateNonces) {
|
|
47
|
-
this.aggregateNonces = new Map();
|
|
48
|
-
}
|
|
49
|
-
if (!this.myNonces) {
|
|
50
|
-
await this.getNonces(); // generate nonces if not generated yet
|
|
51
|
-
}
|
|
52
|
-
if (this.aggregateNonces.has(txid)) {
|
|
53
|
-
return {
|
|
54
|
-
hasAllNonces: this.aggregateNonces.size === this.myNonces?.size,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
const myNonce = this.myNonces.get(txid);
|
|
58
|
-
if (!myNonce)
|
|
59
|
-
throw new Error(`missing nonce for txid ${txid}`);
|
|
60
|
-
const myPublicKey = await this.getPublicKey();
|
|
61
|
-
// set my nonce to not rely on server
|
|
62
|
-
noncesByPubkey.set(hex.encode(myPublicKey.subarray(1)), myNonce);
|
|
63
|
-
const tx = this.graph.find(txid);
|
|
64
|
-
if (!tx)
|
|
65
|
-
throw new Error(`missing tx for txid ${txid}`);
|
|
66
|
-
const cosigners = getArkPsbtFields(tx.root, 0, CosignerPublicKey).map((c) => hex.encode(c.key.subarray(1)) // xonly pubkey
|
|
67
|
-
);
|
|
68
|
-
const pubNonces = [];
|
|
69
|
-
for (const cosigner of cosigners) {
|
|
70
|
-
const nonce = noncesByPubkey.get(cosigner);
|
|
71
|
-
if (!nonce) {
|
|
72
|
-
throw new Error(`missing nonce for cosigner ${cosigner}`);
|
|
73
|
-
}
|
|
74
|
-
pubNonces.push(nonce.pubNonce);
|
|
75
|
-
}
|
|
76
|
-
const aggregateNonce = musig2.aggregateNonces(pubNonces);
|
|
77
|
-
this.aggregateNonces.set(txid, { pubNonce: aggregateNonce });
|
|
78
|
-
return {
|
|
79
|
-
hasAllNonces: this.aggregateNonces.size === this.myNonces?.size,
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
async sign() {
|
|
83
|
-
if (!this.graph)
|
|
84
|
-
throw ErrMissingVtxoGraph;
|
|
85
|
-
if (!this.aggregateNonces)
|
|
86
|
-
throw new Error("nonces not set");
|
|
87
|
-
if (!this.myNonces)
|
|
88
|
-
throw new Error("nonces not generated");
|
|
89
|
-
const sigs = new Map();
|
|
90
|
-
for (const g of this.graph.iterator()) {
|
|
91
|
-
const sig = this.signPartial(g);
|
|
92
|
-
sigs.set(g.txid, sig);
|
|
93
|
-
}
|
|
94
|
-
return sigs;
|
|
95
|
-
}
|
|
96
|
-
generateNonces() {
|
|
97
|
-
if (!this.graph)
|
|
98
|
-
throw ErrMissingVtxoGraph;
|
|
99
|
-
const myNonces = new Map();
|
|
100
|
-
const publicKey = secp256k1.getPublicKey(this.secretKey);
|
|
101
|
-
for (const g of this.graph.iterator()) {
|
|
102
|
-
const nonces = musig2.generateNonces(publicKey);
|
|
103
|
-
myNonces.set(g.txid, nonces);
|
|
104
|
-
}
|
|
105
|
-
return myNonces;
|
|
106
|
-
}
|
|
107
|
-
signPartial(g) {
|
|
108
|
-
if (!this.graph || !this.scriptRoot || !this.rootSharedOutputAmount) {
|
|
109
|
-
throw TreeSignerSession.NOT_INITIALIZED;
|
|
110
|
-
}
|
|
111
|
-
if (!this.myNonces || !this.aggregateNonces) {
|
|
112
|
-
throw new Error("session not properly initialized");
|
|
113
|
-
}
|
|
114
|
-
const myNonce = this.myNonces.get(g.txid);
|
|
115
|
-
if (!myNonce)
|
|
116
|
-
throw new Error("missing private nonce");
|
|
117
|
-
const aggNonce = this.aggregateNonces.get(g.txid);
|
|
118
|
-
if (!aggNonce)
|
|
119
|
-
throw new Error("missing aggregate nonce");
|
|
120
|
-
const prevoutAmounts = [];
|
|
121
|
-
const prevoutScripts = [];
|
|
122
|
-
const cosigners = getArkPsbtFields(g.root, 0, CosignerPublicKey).map((c) => c.key);
|
|
123
|
-
const { finalKey } = musig2.aggregateKeys(cosigners, true, {
|
|
124
|
-
taprootTweak: this.scriptRoot,
|
|
125
|
-
});
|
|
126
|
-
for (let inputIndex = 0; inputIndex < g.root.inputsLength; inputIndex++) {
|
|
127
|
-
const prevout = getPrevOutput(finalKey, this.graph, this.rootSharedOutputAmount, g.root);
|
|
128
|
-
prevoutAmounts.push(prevout.amount);
|
|
129
|
-
prevoutScripts.push(prevout.script);
|
|
130
|
-
}
|
|
131
|
-
const message = g.root.preimageWitnessV1(0, // always first input
|
|
132
|
-
prevoutScripts, SigHash.DEFAULT, prevoutAmounts);
|
|
133
|
-
return musig2.sign(myNonce.secNonce, this.secretKey, aggNonce.pubNonce, cosigners, message, {
|
|
134
|
-
taprootTweak: this.scriptRoot,
|
|
135
|
-
sortKeys: true,
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
TreeSignerSession.NOT_INITIALIZED = new Error("session not initialized, call init method");
|
|
140
|
-
// Helper function to validate tree signatures
|
|
141
|
-
export async function validateTreeSigs(finalAggregatedKey, sharedOutputAmount, vtxoTree) {
|
|
142
|
-
// Iterate through each level of the tree
|
|
143
|
-
for (const g of vtxoTree.iterator()) {
|
|
144
|
-
// Parse the transaction
|
|
145
|
-
const input = g.root.getInput(0);
|
|
146
|
-
// Check if input has signature
|
|
147
|
-
if (!input.tapKeySig) {
|
|
148
|
-
throw new Error("unsigned tree input");
|
|
149
|
-
}
|
|
150
|
-
// Get the previous output information
|
|
151
|
-
const prevout = getPrevOutput(finalAggregatedKey, vtxoTree, sharedOutputAmount, g.root);
|
|
152
|
-
// Calculate the message that was signed
|
|
153
|
-
const message = g.root.preimageWitnessV1(0, // always first input
|
|
154
|
-
[prevout.script], SigHash.DEFAULT, [prevout.amount]);
|
|
155
|
-
// Verify the signature
|
|
156
|
-
const isValid = schnorr.verify(input.tapKeySig, message, finalAggregatedKey);
|
|
157
|
-
if (!isValid) {
|
|
158
|
-
throw new Error("invalid signature");
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
function getPrevOutput(finalKey, graph, sharedOutputAmount, tx) {
|
|
163
|
-
// generate P2TR script from musig2 final key
|
|
164
|
-
const pkScript = Script.encode(["OP_1", finalKey.slice(1)]);
|
|
165
|
-
// if the input is the root input, return the shared output amount
|
|
166
|
-
if (tx.id === graph.txid) {
|
|
167
|
-
return {
|
|
168
|
-
amount: sharedOutputAmount,
|
|
169
|
-
script: pkScript,
|
|
170
|
-
};
|
|
171
|
-
}
|
|
172
|
-
// find the parent transaction
|
|
173
|
-
const parentInput = tx.getInput(0);
|
|
174
|
-
if (!parentInput.txid)
|
|
175
|
-
throw new Error("missing parent input txid");
|
|
176
|
-
const parentTxid = hex.encode(parentInput.txid);
|
|
177
|
-
const parent = graph.find(parentTxid);
|
|
178
|
-
if (!parent)
|
|
179
|
-
throw new Error("parent tx not found");
|
|
180
|
-
if (parentInput.index === undefined)
|
|
181
|
-
throw new Error("missing input index");
|
|
182
|
-
const parentOutput = parent.root.getOutput(parentInput.index);
|
|
183
|
-
if (!parentOutput)
|
|
184
|
-
throw new Error("parent output not found");
|
|
185
|
-
if (!parentOutput.amount)
|
|
186
|
-
throw new Error("parent output amount not found");
|
|
187
|
-
return {
|
|
188
|
-
amount: parentOutput.amount,
|
|
189
|
-
script: pkScript,
|
|
190
|
-
};
|
|
191
|
-
}
|