@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
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import '../chunk-NSBPE2FW.js';
|
|
2
|
+
import * as fs from 'fs/promises';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
|
|
5
|
+
var FileSystemStorageAdapter = class {
|
|
6
|
+
basePath;
|
|
7
|
+
constructor(dirPath) {
|
|
8
|
+
this.basePath = path.resolve(dirPath).replace(/[/\\]+$/, "");
|
|
9
|
+
}
|
|
10
|
+
validateAndGetFilePath(key) {
|
|
11
|
+
if (key === "." || key === "..") {
|
|
12
|
+
throw new Error("Invalid key: '.' and '..' are not allowed");
|
|
13
|
+
}
|
|
14
|
+
if (key.includes("\0")) {
|
|
15
|
+
throw new Error("Invalid key: null bytes are not allowed");
|
|
16
|
+
}
|
|
17
|
+
if (key.includes("..")) {
|
|
18
|
+
throw new Error("Invalid key: directory traversal is not allowed");
|
|
19
|
+
}
|
|
20
|
+
const reservedNames = /^(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])$/i;
|
|
21
|
+
const keyWithoutExt = key.split(".")[0];
|
|
22
|
+
if (reservedNames.test(keyWithoutExt)) {
|
|
23
|
+
throw new Error(`Invalid key: '${key}' uses a reserved Windows name`);
|
|
24
|
+
}
|
|
25
|
+
if (key.endsWith(" ") || key.endsWith(".")) {
|
|
26
|
+
throw new Error("Invalid key: trailing spaces or dots are not allowed");
|
|
27
|
+
}
|
|
28
|
+
const normalizedKey = key.replace(/[/\\]/g, "_").replace(/[^a-zA-Z0-9._-]/g, "_");
|
|
29
|
+
const resolved = path.resolve(this.basePath, normalizedKey);
|
|
30
|
+
const relative2 = path.relative(this.basePath, resolved);
|
|
31
|
+
if (relative2.startsWith("..") || relative2.includes(path.sep + "..")) {
|
|
32
|
+
throw new Error("Invalid key: directory traversal is not allowed");
|
|
33
|
+
}
|
|
34
|
+
return resolved;
|
|
35
|
+
}
|
|
36
|
+
async ensureDirectory() {
|
|
37
|
+
try {
|
|
38
|
+
await fs.access(this.basePath);
|
|
39
|
+
} catch {
|
|
40
|
+
await fs.mkdir(this.basePath, { recursive: true });
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
async getItem(key) {
|
|
44
|
+
try {
|
|
45
|
+
const filePath = this.validateAndGetFilePath(key);
|
|
46
|
+
const data = await fs.readFile(filePath, "utf-8");
|
|
47
|
+
return data;
|
|
48
|
+
} catch (error) {
|
|
49
|
+
if (error.code === "ENOENT") {
|
|
50
|
+
return null;
|
|
51
|
+
}
|
|
52
|
+
console.error(`Failed to read file for key ${key}:`, error);
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async setItem(key, value) {
|
|
57
|
+
try {
|
|
58
|
+
await this.ensureDirectory();
|
|
59
|
+
const filePath = this.validateAndGetFilePath(key);
|
|
60
|
+
await fs.writeFile(filePath, value, "utf-8");
|
|
61
|
+
} catch (error) {
|
|
62
|
+
console.error(`Failed to write file for key ${key}:`, error);
|
|
63
|
+
throw error;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async removeItem(key) {
|
|
67
|
+
try {
|
|
68
|
+
const filePath = this.validateAndGetFilePath(key);
|
|
69
|
+
await fs.unlink(filePath);
|
|
70
|
+
} catch (error) {
|
|
71
|
+
if (error.code !== "ENOENT") {
|
|
72
|
+
console.error(`Failed to remove file for key ${key}:`, error);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
async clear() {
|
|
77
|
+
try {
|
|
78
|
+
const entries = await fs.readdir(this.basePath);
|
|
79
|
+
await Promise.all(
|
|
80
|
+
entries.map(async (entry) => {
|
|
81
|
+
const entryPath = path.join(this.basePath, entry);
|
|
82
|
+
await fs.rm(entryPath, { recursive: true, force: true });
|
|
83
|
+
})
|
|
84
|
+
);
|
|
85
|
+
} catch (error) {
|
|
86
|
+
console.error("Failed to clear storage directory:", error);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
export { FileSystemStorageAdapter };
|
|
92
|
+
//# sourceMappingURL=fileSystem.js.map
|
|
93
|
+
//# sourceMappingURL=fileSystem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/fileSystem.ts"],"names":["relative"],"mappings":"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","file":"fileSystem.js","sourcesContent":["import * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport type { StorageAdapter } from \"./index\";\n\n/**\n * @deprecated Use repository implementations via `StorageConfig` instead.\n */\nexport class FileSystemStorageAdapter implements StorageAdapter {\n private readonly basePath: string;\n\n constructor(dirPath: string) {\n // Normalize and resolve the storage base path once\n this.basePath = path.resolve(dirPath).replace(/[/\\\\]+$/, \"\");\n }\n\n private validateAndGetFilePath(key: string): string {\n // Reject dangerous keys\n if (key === \".\" || key === \"..\") {\n throw new Error(\"Invalid key: '.' and '..' are not allowed\");\n }\n\n // Check for null bytes\n if (key.includes(\"\\0\")) {\n throw new Error(\"Invalid key: null bytes are not allowed\");\n }\n\n // Check for path traversal attempts before normalization\n if (key.includes(\"..\")) {\n throw new Error(\"Invalid key: directory traversal is not allowed\");\n }\n\n // Check for reserved Windows names (case-insensitive)\n const reservedNames = /^(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])$/i;\n const keyWithoutExt = key.split(\".\")[0];\n if (reservedNames.test(keyWithoutExt)) {\n throw new Error(`Invalid key: '${key}' uses a reserved Windows name`);\n }\n\n // Check for trailing spaces or dots\n if (key.endsWith(\" \") || key.endsWith(\".\")) {\n throw new Error(\"Invalid key: trailing spaces or dots are not allowed\");\n }\n\n // Normalize path separators and sanitize key\n const normalizedKey = key.replace(/[/\\\\]/g, \"_\").replace(/[^a-zA-Z0-9._-]/g, \"_\");\n\n // Resolve the full path and check for directory traversal\n const resolved = path.resolve(this.basePath, normalizedKey);\n const relative = path.relative(this.basePath, resolved);\n\n // Reject if trying to escape the base directory\n if (relative.startsWith(\"..\") || relative.includes(path.sep + \"..\")) {\n throw new Error(\"Invalid key: directory traversal is not allowed\");\n }\n\n return resolved;\n }\n\n private async ensureDirectory(): Promise<void> {\n try {\n await fs.access(this.basePath);\n } catch {\n await fs.mkdir(this.basePath, { recursive: true });\n }\n }\n\n async getItem(key: string): Promise<string | null> {\n try {\n const filePath = this.validateAndGetFilePath(key);\n const data = await fs.readFile(filePath, \"utf-8\");\n return data;\n } catch (error: any) {\n if (error.code === \"ENOENT\") {\n return null;\n }\n console.error(`Failed to read file for key ${key}:`, error);\n return null;\n }\n }\n\n async setItem(key: string, value: string): Promise<void> {\n try {\n await this.ensureDirectory();\n const filePath = this.validateAndGetFilePath(key);\n await fs.writeFile(filePath, value, \"utf-8\");\n } catch (error) {\n console.error(`Failed to write file for key ${key}:`, error);\n throw error;\n }\n }\n\n async removeItem(key: string): Promise<void> {\n try {\n const filePath = this.validateAndGetFilePath(key);\n await fs.unlink(filePath);\n } catch (error: any) {\n if (error.code !== \"ENOENT\") {\n console.error(`Failed to remove file for key ${key}:`, error);\n }\n }\n }\n\n async clear(): Promise<void> {\n try {\n const entries = await fs.readdir(this.basePath);\n await Promise.all(\n entries.map(async (entry) => {\n const entryPath = path.join(this.basePath, entry);\n // Use fs.rm with recursive option to handle both files and directories\n await fs.rm(entryPath, { recursive: true, force: true });\n }),\n );\n } catch (error) {\n console.error(\"Failed to clear storage directory:\", error);\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkZLO6NETT_cjs = require('../chunk-ZLO6NETT.cjs');
|
|
4
|
+
require('../chunk-ADV27S4N.cjs');
|
|
5
|
+
require('../chunk-I3DGUUCT.cjs');
|
|
6
|
+
require('../chunk-5PG7DV7A.cjs');
|
|
7
|
+
require('../chunk-5BLDMQED.cjs');
|
|
8
|
+
|
|
9
|
+
// src/storage/indexedDB.ts
|
|
10
|
+
var IndexedDBStorageAdapter = class {
|
|
11
|
+
dbName;
|
|
12
|
+
version;
|
|
13
|
+
db = null;
|
|
14
|
+
constructor(dbName, version = chunkZLO6NETT_cjs.DB_VERSION) {
|
|
15
|
+
this.dbName = dbName;
|
|
16
|
+
this.version = version;
|
|
17
|
+
}
|
|
18
|
+
async getDB() {
|
|
19
|
+
if (this.db) return this.db;
|
|
20
|
+
const globalObject = typeof window === "undefined" ? self : window;
|
|
21
|
+
if (!(globalObject && "indexedDB" in globalObject)) {
|
|
22
|
+
throw new Error("IndexedDB is not available in this environment");
|
|
23
|
+
}
|
|
24
|
+
return new Promise((resolve, reject) => {
|
|
25
|
+
const request = globalObject.indexedDB.open(this.dbName, this.version);
|
|
26
|
+
request.onerror = () => reject(request.error);
|
|
27
|
+
request.onsuccess = () => {
|
|
28
|
+
this.db = request.result;
|
|
29
|
+
resolve(this.db);
|
|
30
|
+
};
|
|
31
|
+
request.onupgradeneeded = () => {
|
|
32
|
+
const db = request.result;
|
|
33
|
+
if (!db.objectStoreNames.contains("storage")) {
|
|
34
|
+
db.createObjectStore("storage");
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
async getItem(key) {
|
|
40
|
+
try {
|
|
41
|
+
const db = await this.getDB();
|
|
42
|
+
return new Promise((resolve, reject) => {
|
|
43
|
+
const transaction = db.transaction(["storage"], "readonly");
|
|
44
|
+
const store = transaction.objectStore("storage");
|
|
45
|
+
const request = store.get(key);
|
|
46
|
+
request.onerror = () => reject(request.error);
|
|
47
|
+
request.onsuccess = () => {
|
|
48
|
+
resolve(request.result || null);
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
} catch (error) {
|
|
52
|
+
console.error(`Failed to get item for key ${key}:`, error);
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async setItem(key, value) {
|
|
57
|
+
try {
|
|
58
|
+
const db = await this.getDB();
|
|
59
|
+
return new Promise((resolve, reject) => {
|
|
60
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
61
|
+
const store = transaction.objectStore("storage");
|
|
62
|
+
const request = store.put(value, key);
|
|
63
|
+
request.onerror = () => reject(request.error);
|
|
64
|
+
request.onsuccess = () => resolve();
|
|
65
|
+
});
|
|
66
|
+
} catch (error) {
|
|
67
|
+
console.error(`Failed to set item for key ${key}:`, error);
|
|
68
|
+
throw error;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
async removeItem(key) {
|
|
72
|
+
try {
|
|
73
|
+
const db = await this.getDB();
|
|
74
|
+
return new Promise((resolve, reject) => {
|
|
75
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
76
|
+
const store = transaction.objectStore("storage");
|
|
77
|
+
const request = store.delete(key);
|
|
78
|
+
request.onerror = () => reject(request.error);
|
|
79
|
+
request.onsuccess = () => resolve();
|
|
80
|
+
});
|
|
81
|
+
} catch (error) {
|
|
82
|
+
console.error(`Failed to remove item for key ${key}:`, error);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
async clear() {
|
|
86
|
+
try {
|
|
87
|
+
const db = await this.getDB();
|
|
88
|
+
return new Promise((resolve, reject) => {
|
|
89
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
90
|
+
const store = transaction.objectStore("storage");
|
|
91
|
+
const request = store.clear();
|
|
92
|
+
request.onerror = () => reject(request.error);
|
|
93
|
+
request.onsuccess = () => resolve();
|
|
94
|
+
});
|
|
95
|
+
} catch (error) {
|
|
96
|
+
console.error("Failed to clear storage:", error);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
exports.IndexedDBStorageAdapter = IndexedDBStorageAdapter;
|
|
102
|
+
//# sourceMappingURL=indexedDB.cjs.map
|
|
103
|
+
//# sourceMappingURL=indexedDB.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/indexedDB.ts"],"names":["DB_VERSION"],"mappings":"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","file":"indexedDB.cjs","sourcesContent":["import type { StorageAdapter } from \"./index\";\nimport { DB_VERSION } from \"../repositories/indexedDB/db\";\n\n/**\n * @deprecated Use repository implementations via `StorageConfig` instead.\n */\nexport class IndexedDBStorageAdapter implements StorageAdapter {\n private dbName: string;\n private version: number;\n private db: IDBDatabase | null = null;\n\n constructor(dbName: string, version: number = DB_VERSION) {\n this.dbName = dbName;\n this.version = version;\n }\n\n private async getDB(): Promise<IDBDatabase> {\n if (this.db) return this.db;\n\n const globalObject = typeof window === \"undefined\" ? self : window;\n\n if (!(globalObject && \"indexedDB\" in globalObject)) {\n throw new Error(\"IndexedDB is not available in this environment\");\n }\n\n return new Promise((resolve, reject) => {\n const request = globalObject.indexedDB.open(this.dbName, this.version);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => {\n this.db = request.result;\n resolve(this.db);\n };\n\n request.onupgradeneeded = () => {\n const db = request.result;\n if (!db.objectStoreNames.contains(\"storage\")) {\n db.createObjectStore(\"storage\");\n }\n };\n });\n }\n\n async getItem(key: string): Promise<string | null> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readonly\");\n const store = transaction.objectStore(\"storage\");\n const request = store.get(key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => {\n resolve(request.result || null);\n };\n });\n } catch (error) {\n console.error(`Failed to get item for key ${key}:`, error);\n return null;\n }\n }\n\n async setItem(key: string, value: string): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.put(value, key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(`Failed to set item for key ${key}:`, error);\n throw error;\n }\n }\n\n async removeItem(key: string): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.delete(key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(`Failed to remove item for key ${key}:`, error);\n }\n }\n\n async clear(): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.clear();\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(\"Failed to clear storage:\", error);\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { S as StorageAdapter } from '../index-C0IanN1m.cjs';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
5
|
+
*/
|
|
6
|
+
declare class IndexedDBStorageAdapter implements StorageAdapter {
|
|
7
|
+
private dbName;
|
|
8
|
+
private version;
|
|
9
|
+
private db;
|
|
10
|
+
constructor(dbName: string, version?: number);
|
|
11
|
+
private getDB;
|
|
12
|
+
getItem(key: string): Promise<string | null>;
|
|
13
|
+
setItem(key: string, value: string): Promise<void>;
|
|
14
|
+
removeItem(key: string): Promise<void>;
|
|
15
|
+
clear(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export { IndexedDBStorageAdapter, StorageAdapter };
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { S as StorageAdapter } from '../index-C0IanN1m.js';
|
|
2
|
+
|
|
2
3
|
/**
|
|
3
4
|
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
4
5
|
*/
|
|
5
|
-
|
|
6
|
+
declare class IndexedDBStorageAdapter implements StorageAdapter {
|
|
6
7
|
private dbName;
|
|
7
8
|
private version;
|
|
8
9
|
private db;
|
|
@@ -13,3 +14,5 @@ export declare class IndexedDBStorageAdapter implements StorageAdapter {
|
|
|
13
14
|
removeItem(key: string): Promise<void>;
|
|
14
15
|
clear(): Promise<void>;
|
|
15
16
|
}
|
|
17
|
+
|
|
18
|
+
export { IndexedDBStorageAdapter, StorageAdapter };
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { DB_VERSION } from '../chunk-BQLHADL7.js';
|
|
2
|
+
import '../chunk-ZBUDLTBO.js';
|
|
3
|
+
import '../chunk-T64LAI7L.js';
|
|
4
|
+
import '../chunk-HW3JJ323.js';
|
|
5
|
+
import '../chunk-NSBPE2FW.js';
|
|
6
|
+
|
|
7
|
+
// src/storage/indexedDB.ts
|
|
8
|
+
var IndexedDBStorageAdapter = class {
|
|
9
|
+
dbName;
|
|
10
|
+
version;
|
|
11
|
+
db = null;
|
|
12
|
+
constructor(dbName, version = DB_VERSION) {
|
|
13
|
+
this.dbName = dbName;
|
|
14
|
+
this.version = version;
|
|
15
|
+
}
|
|
16
|
+
async getDB() {
|
|
17
|
+
if (this.db) return this.db;
|
|
18
|
+
const globalObject = typeof window === "undefined" ? self : window;
|
|
19
|
+
if (!(globalObject && "indexedDB" in globalObject)) {
|
|
20
|
+
throw new Error("IndexedDB is not available in this environment");
|
|
21
|
+
}
|
|
22
|
+
return new Promise((resolve, reject) => {
|
|
23
|
+
const request = globalObject.indexedDB.open(this.dbName, this.version);
|
|
24
|
+
request.onerror = () => reject(request.error);
|
|
25
|
+
request.onsuccess = () => {
|
|
26
|
+
this.db = request.result;
|
|
27
|
+
resolve(this.db);
|
|
28
|
+
};
|
|
29
|
+
request.onupgradeneeded = () => {
|
|
30
|
+
const db = request.result;
|
|
31
|
+
if (!db.objectStoreNames.contains("storage")) {
|
|
32
|
+
db.createObjectStore("storage");
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
async getItem(key) {
|
|
38
|
+
try {
|
|
39
|
+
const db = await this.getDB();
|
|
40
|
+
return new Promise((resolve, reject) => {
|
|
41
|
+
const transaction = db.transaction(["storage"], "readonly");
|
|
42
|
+
const store = transaction.objectStore("storage");
|
|
43
|
+
const request = store.get(key);
|
|
44
|
+
request.onerror = () => reject(request.error);
|
|
45
|
+
request.onsuccess = () => {
|
|
46
|
+
resolve(request.result || null);
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
} catch (error) {
|
|
50
|
+
console.error(`Failed to get item for key ${key}:`, error);
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
async setItem(key, value) {
|
|
55
|
+
try {
|
|
56
|
+
const db = await this.getDB();
|
|
57
|
+
return new Promise((resolve, reject) => {
|
|
58
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
59
|
+
const store = transaction.objectStore("storage");
|
|
60
|
+
const request = store.put(value, key);
|
|
61
|
+
request.onerror = () => reject(request.error);
|
|
62
|
+
request.onsuccess = () => resolve();
|
|
63
|
+
});
|
|
64
|
+
} catch (error) {
|
|
65
|
+
console.error(`Failed to set item for key ${key}:`, error);
|
|
66
|
+
throw error;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async removeItem(key) {
|
|
70
|
+
try {
|
|
71
|
+
const db = await this.getDB();
|
|
72
|
+
return new Promise((resolve, reject) => {
|
|
73
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
74
|
+
const store = transaction.objectStore("storage");
|
|
75
|
+
const request = store.delete(key);
|
|
76
|
+
request.onerror = () => reject(request.error);
|
|
77
|
+
request.onsuccess = () => resolve();
|
|
78
|
+
});
|
|
79
|
+
} catch (error) {
|
|
80
|
+
console.error(`Failed to remove item for key ${key}:`, error);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
async clear() {
|
|
84
|
+
try {
|
|
85
|
+
const db = await this.getDB();
|
|
86
|
+
return new Promise((resolve, reject) => {
|
|
87
|
+
const transaction = db.transaction(["storage"], "readwrite");
|
|
88
|
+
const store = transaction.objectStore("storage");
|
|
89
|
+
const request = store.clear();
|
|
90
|
+
request.onerror = () => reject(request.error);
|
|
91
|
+
request.onsuccess = () => resolve();
|
|
92
|
+
});
|
|
93
|
+
} catch (error) {
|
|
94
|
+
console.error("Failed to clear storage:", error);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
export { IndexedDBStorageAdapter };
|
|
100
|
+
//# sourceMappingURL=indexedDB.js.map
|
|
101
|
+
//# sourceMappingURL=indexedDB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/indexedDB.ts"],"names":[],"mappings":"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","file":"indexedDB.js","sourcesContent":["import type { StorageAdapter } from \"./index\";\nimport { DB_VERSION } from \"../repositories/indexedDB/db\";\n\n/**\n * @deprecated Use repository implementations via `StorageConfig` instead.\n */\nexport class IndexedDBStorageAdapter implements StorageAdapter {\n private dbName: string;\n private version: number;\n private db: IDBDatabase | null = null;\n\n constructor(dbName: string, version: number = DB_VERSION) {\n this.dbName = dbName;\n this.version = version;\n }\n\n private async getDB(): Promise<IDBDatabase> {\n if (this.db) return this.db;\n\n const globalObject = typeof window === \"undefined\" ? self : window;\n\n if (!(globalObject && \"indexedDB\" in globalObject)) {\n throw new Error(\"IndexedDB is not available in this environment\");\n }\n\n return new Promise((resolve, reject) => {\n const request = globalObject.indexedDB.open(this.dbName, this.version);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => {\n this.db = request.result;\n resolve(this.db);\n };\n\n request.onupgradeneeded = () => {\n const db = request.result;\n if (!db.objectStoreNames.contains(\"storage\")) {\n db.createObjectStore(\"storage\");\n }\n };\n });\n }\n\n async getItem(key: string): Promise<string | null> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readonly\");\n const store = transaction.objectStore(\"storage\");\n const request = store.get(key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => {\n resolve(request.result || null);\n };\n });\n } catch (error) {\n console.error(`Failed to get item for key ${key}:`, error);\n return null;\n }\n }\n\n async setItem(key: string, value: string): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.put(value, key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(`Failed to set item for key ${key}:`, error);\n throw error;\n }\n }\n\n async removeItem(key: string): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.delete(key);\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(`Failed to remove item for key ${key}:`, error);\n }\n }\n\n async clear(): Promise<void> {\n try {\n const db = await this.getDB();\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([\"storage\"], \"readwrite\");\n const store = transaction.objectStore(\"storage\");\n const request = store.clear();\n\n request.onerror = () => reject(request.error);\n request.onsuccess = () => resolve();\n });\n } catch (error) {\n console.error(\"Failed to clear storage:\", error);\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
require('../chunk-5BLDMQED.cjs');
|
|
4
|
+
|
|
5
|
+
// src/storage/localStorage.ts
|
|
6
|
+
var LocalStorageAdapter = class {
|
|
7
|
+
getSafeLocalStorage() {
|
|
8
|
+
try {
|
|
9
|
+
if (typeof window === "undefined" || !window.localStorage) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
window.localStorage.length;
|
|
13
|
+
return window.localStorage;
|
|
14
|
+
} catch {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
async getItem(key) {
|
|
19
|
+
const localStorage = this.getSafeLocalStorage();
|
|
20
|
+
if (!localStorage) {
|
|
21
|
+
throw new Error("localStorage is not available in this environment");
|
|
22
|
+
}
|
|
23
|
+
return localStorage.getItem(key);
|
|
24
|
+
}
|
|
25
|
+
async setItem(key, value) {
|
|
26
|
+
const localStorage = this.getSafeLocalStorage();
|
|
27
|
+
if (!localStorage) {
|
|
28
|
+
throw new Error("localStorage is not available in this environment");
|
|
29
|
+
}
|
|
30
|
+
localStorage.setItem(key, value);
|
|
31
|
+
}
|
|
32
|
+
async removeItem(key) {
|
|
33
|
+
const localStorage = this.getSafeLocalStorage();
|
|
34
|
+
if (!localStorage) {
|
|
35
|
+
throw new Error("localStorage is not available in this environment");
|
|
36
|
+
}
|
|
37
|
+
localStorage.removeItem(key);
|
|
38
|
+
}
|
|
39
|
+
async clear() {
|
|
40
|
+
const localStorage = this.getSafeLocalStorage();
|
|
41
|
+
if (!localStorage) {
|
|
42
|
+
throw new Error("localStorage is not available in this environment");
|
|
43
|
+
}
|
|
44
|
+
localStorage.clear();
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
exports.LocalStorageAdapter = LocalStorageAdapter;
|
|
49
|
+
//# sourceMappingURL=localStorage.cjs.map
|
|
50
|
+
//# sourceMappingURL=localStorage.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/localStorage.ts"],"names":[],"mappings":";;;;;AAKO,IAAM,sBAAN,MAAoD;AAAA,EAC/C,mBAAA,GAAsC;AAC1C,IAAA,IAAI;AACA,MAAA,IAAI,OAAO,MAAA,KAAW,WAAA,IAAe,CAAC,OAAO,YAAA,EAAc;AACvD,QAAA,OAAO,IAAA;AAAA,MACX;AAEA,MAAA,MAAA,CAAO,YAAA,CAAa,MAAA;AACpB,MAAA,OAAO,MAAA,CAAO,YAAA;AAAA,IAClB,CAAA,CAAA,MAAQ;AAEJ,MAAA,OAAO,IAAA;AAAA,IACX;AAAA,EACJ;AAAA,EAEA,MAAM,QAAQ,GAAA,EAAqC;AAC/C,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,OAAO,YAAA,CAAa,QAAQ,GAAG,CAAA;AAAA,EACnC;AAAA,EAEA,MAAM,OAAA,CAAQ,GAAA,EAAa,KAAA,EAA8B;AACrD,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,OAAA,CAAQ,KAAK,KAAK,CAAA;AAAA,EACnC;AAAA,EAEA,MAAM,WAAW,GAAA,EAA4B;AACzC,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,WAAW,GAAG,CAAA;AAAA,EAC/B;AAAA,EAEA,MAAM,KAAA,GAAuB;AACzB,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,KAAA,EAAM;AAAA,EACvB;AACJ","file":"localStorage.cjs","sourcesContent":["import type { StorageAdapter } from \"./index\";\n\n/**\n * @deprecated Use repository implementations via `StorageConfig` instead.\n */\nexport class LocalStorageAdapter implements StorageAdapter {\n private getSafeLocalStorage(): Storage | null {\n try {\n if (typeof window === \"undefined\" || !window.localStorage) {\n return null;\n }\n // Test access to ensure localStorage is actually available\n window.localStorage.length;\n return window.localStorage;\n } catch {\n // localStorage may throw in some environments (e.g., private browsing, disabled storage)\n return null;\n }\n }\n\n async getItem(key: string): Promise<string | null> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n return localStorage.getItem(key);\n }\n\n async setItem(key: string, value: string): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.setItem(key, value);\n }\n\n async removeItem(key: string): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.removeItem(key);\n }\n\n async clear(): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.clear();\n }\n}\n"]}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { S as StorageAdapter } from '../index-C0IanN1m.cjs';
|
|
2
|
+
|
|
2
3
|
/**
|
|
3
4
|
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
4
5
|
*/
|
|
5
|
-
|
|
6
|
-
private
|
|
6
|
+
declare class LocalStorageAdapter implements StorageAdapter {
|
|
7
|
+
private getSafeLocalStorage;
|
|
7
8
|
getItem(key: string): Promise<string | null>;
|
|
8
9
|
setItem(key: string, value: string): Promise<void>;
|
|
9
10
|
removeItem(key: string): Promise<void>;
|
|
10
11
|
clear(): Promise<void>;
|
|
11
12
|
}
|
|
13
|
+
|
|
14
|
+
export { LocalStorageAdapter, StorageAdapter };
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { S as StorageAdapter } from '../index-C0IanN1m.js';
|
|
2
|
+
|
|
2
3
|
/**
|
|
3
4
|
* @deprecated Use repository implementations via `StorageConfig` instead.
|
|
4
5
|
*/
|
|
5
|
-
|
|
6
|
+
declare class LocalStorageAdapter implements StorageAdapter {
|
|
6
7
|
private getSafeLocalStorage;
|
|
7
8
|
getItem(key: string): Promise<string | null>;
|
|
8
9
|
setItem(key: string, value: string): Promise<void>;
|
|
9
10
|
removeItem(key: string): Promise<void>;
|
|
10
11
|
clear(): Promise<void>;
|
|
11
12
|
}
|
|
13
|
+
|
|
14
|
+
export { LocalStorageAdapter, StorageAdapter };
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import '../chunk-NSBPE2FW.js';
|
|
2
|
+
|
|
3
|
+
// src/storage/localStorage.ts
|
|
4
|
+
var LocalStorageAdapter = class {
|
|
5
|
+
getSafeLocalStorage() {
|
|
6
|
+
try {
|
|
7
|
+
if (typeof window === "undefined" || !window.localStorage) {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
window.localStorage.length;
|
|
11
|
+
return window.localStorage;
|
|
12
|
+
} catch {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
async getItem(key) {
|
|
17
|
+
const localStorage = this.getSafeLocalStorage();
|
|
18
|
+
if (!localStorage) {
|
|
19
|
+
throw new Error("localStorage is not available in this environment");
|
|
20
|
+
}
|
|
21
|
+
return localStorage.getItem(key);
|
|
22
|
+
}
|
|
23
|
+
async setItem(key, value) {
|
|
24
|
+
const localStorage = this.getSafeLocalStorage();
|
|
25
|
+
if (!localStorage) {
|
|
26
|
+
throw new Error("localStorage is not available in this environment");
|
|
27
|
+
}
|
|
28
|
+
localStorage.setItem(key, value);
|
|
29
|
+
}
|
|
30
|
+
async removeItem(key) {
|
|
31
|
+
const localStorage = this.getSafeLocalStorage();
|
|
32
|
+
if (!localStorage) {
|
|
33
|
+
throw new Error("localStorage is not available in this environment");
|
|
34
|
+
}
|
|
35
|
+
localStorage.removeItem(key);
|
|
36
|
+
}
|
|
37
|
+
async clear() {
|
|
38
|
+
const localStorage = this.getSafeLocalStorage();
|
|
39
|
+
if (!localStorage) {
|
|
40
|
+
throw new Error("localStorage is not available in this environment");
|
|
41
|
+
}
|
|
42
|
+
localStorage.clear();
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
export { LocalStorageAdapter };
|
|
47
|
+
//# sourceMappingURL=localStorage.js.map
|
|
48
|
+
//# sourceMappingURL=localStorage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/localStorage.ts"],"names":[],"mappings":";;;AAKO,IAAM,sBAAN,MAAoD;AAAA,EAC/C,mBAAA,GAAsC;AAC1C,IAAA,IAAI;AACA,MAAA,IAAI,OAAO,MAAA,KAAW,WAAA,IAAe,CAAC,OAAO,YAAA,EAAc;AACvD,QAAA,OAAO,IAAA;AAAA,MACX;AAEA,MAAA,MAAA,CAAO,YAAA,CAAa,MAAA;AACpB,MAAA,OAAO,MAAA,CAAO,YAAA;AAAA,IAClB,CAAA,CAAA,MAAQ;AAEJ,MAAA,OAAO,IAAA;AAAA,IACX;AAAA,EACJ;AAAA,EAEA,MAAM,QAAQ,GAAA,EAAqC;AAC/C,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,OAAO,YAAA,CAAa,QAAQ,GAAG,CAAA;AAAA,EACnC;AAAA,EAEA,MAAM,OAAA,CAAQ,GAAA,EAAa,KAAA,EAA8B;AACrD,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,OAAA,CAAQ,KAAK,KAAK,CAAA;AAAA,EACnC;AAAA,EAEA,MAAM,WAAW,GAAA,EAA4B;AACzC,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,WAAW,GAAG,CAAA;AAAA,EAC/B;AAAA,EAEA,MAAM,KAAA,GAAuB;AACzB,IAAA,MAAM,YAAA,GAAe,KAAK,mBAAA,EAAoB;AAC9C,IAAA,IAAI,CAAC,YAAA,EAAc;AACf,MAAA,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAAA,IACvE;AACA,IAAA,YAAA,CAAa,KAAA,EAAM;AAAA,EACvB;AACJ","file":"localStorage.js","sourcesContent":["import type { StorageAdapter } from \"./index\";\n\n/**\n * @deprecated Use repository implementations via `StorageConfig` instead.\n */\nexport class LocalStorageAdapter implements StorageAdapter {\n private getSafeLocalStorage(): Storage | null {\n try {\n if (typeof window === \"undefined\" || !window.localStorage) {\n return null;\n }\n // Test access to ensure localStorage is actually available\n window.localStorage.length;\n return window.localStorage;\n } catch {\n // localStorage may throw in some environments (e.g., private browsing, disabled storage)\n return null;\n }\n }\n\n async getItem(key: string): Promise<string | null> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n return localStorage.getItem(key);\n }\n\n async setItem(key: string, value: string): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.setItem(key, value);\n }\n\n async removeItem(key: string): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.removeItem(key);\n }\n\n async clear(): Promise<void> {\n const localStorage = this.getSafeLocalStorage();\n if (!localStorage) {\n throw new Error(\"localStorage is not available in this environment\");\n }\n localStorage.clear();\n }\n}\n"]}
|