@bsv/wallet-toolbox 2.1.27 → 2.1.30
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/CHANGELOG.md +6 -0
- package/docs/client.md +485 -160
- package/docs/monitor.md +69 -1
- package/docs/storage.md +421 -63
- package/docs/wallet.md +945 -145
- package/out/src/CWIStyleWalletManager.js +107 -41
- package/out/src/CWIStyleWalletManager.js.map +1 -1
- package/out/src/Setup.js +3 -3
- package/out/src/Setup.js.map +1 -1
- package/out/src/SetupClient.js +1 -1
- package/out/src/SetupClient.js.map +1 -1
- package/out/src/ShamirWalletManager.d.ts +2 -2
- package/out/src/ShamirWalletManager.js +10 -3
- package/out/src/ShamirWalletManager.js.map +1 -1
- package/out/src/SimpleWalletManager.js +29 -0
- package/out/src/SimpleWalletManager.js.map +1 -1
- package/out/src/Wallet.js +84 -66
- package/out/src/Wallet.js.map +1 -1
- package/out/src/WalletAuthenticationManager.js +6 -3
- package/out/src/WalletAuthenticationManager.js.map +1 -1
- package/out/src/WalletLogger.js +6 -4
- package/out/src/WalletLogger.js.map +1 -1
- package/out/src/WalletPermissionsManager.d.ts.map +1 -1
- package/out/src/WalletPermissionsManager.js +158 -167
- package/out/src/WalletPermissionsManager.js.map +1 -1
- package/out/src/WalletSettingsManager.js +3 -0
- package/out/src/WalletSettingsManager.js.map +1 -1
- package/out/src/entropy/EntropyCollector.js +9 -9
- package/out/src/entropy/EntropyCollector.js.map +1 -1
- package/out/src/fundWalletP2PKH.js +5 -6
- package/out/src/fundWalletP2PKH.js.map +1 -1
- package/out/src/mockchain/MockChainMigrations.js +1 -1
- package/out/src/mockchain/MockChainMigrations.js.map +1 -1
- package/out/src/mockchain/MockChainStorage.js +1 -0
- package/out/src/mockchain/MockChainStorage.js.map +1 -1
- package/out/src/mockchain/MockChainTracker.js +2 -0
- package/out/src/mockchain/MockChainTracker.js.map +1 -1
- package/out/src/mockchain/MockMiner.js +2 -2
- package/out/src/mockchain/MockMiner.js.map +1 -1
- package/out/src/mockchain/MockServices.js +21 -25
- package/out/src/mockchain/MockServices.js.map +1 -1
- package/out/src/monitor/Monitor.d.ts.map +1 -1
- package/out/src/monitor/Monitor.js +57 -33
- package/out/src/monitor/Monitor.js.map +1 -1
- package/out/src/monitor/MonitorDaemon.js +12 -10
- package/out/src/monitor/MonitorDaemon.js.map +1 -1
- package/out/src/monitor/tasks/TaskArcSSE.js +10 -13
- package/out/src/monitor/tasks/TaskArcSSE.js.map +1 -1
- package/out/src/monitor/tasks/TaskCheckForProofs.js +10 -11
- package/out/src/monitor/tasks/TaskCheckForProofs.js.map +1 -1
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts +59 -1
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts.map +1 -1
- package/out/src/monitor/tasks/TaskCheckNoSends.js +101 -12
- package/out/src/monitor/tasks/TaskCheckNoSends.js.map +1 -1
- package/out/src/monitor/tasks/TaskClock.js +3 -1
- package/out/src/monitor/tasks/TaskClock.js.map +1 -1
- package/out/src/monitor/tasks/TaskFailAbandoned.js +2 -1
- package/out/src/monitor/tasks/TaskFailAbandoned.js.map +1 -1
- package/out/src/monitor/tasks/TaskMineBlock.js +3 -2
- package/out/src/monitor/tasks/TaskMineBlock.js.map +1 -1
- package/out/src/monitor/tasks/TaskMonitorCallHistory.js +2 -1
- package/out/src/monitor/tasks/TaskMonitorCallHistory.js.map +1 -1
- package/out/src/monitor/tasks/TaskNewHeader.js +12 -1
- package/out/src/monitor/tasks/TaskNewHeader.js.map +1 -1
- package/out/src/monitor/tasks/TaskPurge.js +7 -5
- package/out/src/monitor/tasks/TaskPurge.js.map +1 -1
- package/out/src/monitor/tasks/TaskReorg.js +4 -2
- package/out/src/monitor/tasks/TaskReorg.js.map +1 -1
- package/out/src/monitor/tasks/TaskReviewDoubleSpends.js +12 -9
- package/out/src/monitor/tasks/TaskReviewDoubleSpends.js.map +1 -1
- package/out/src/monitor/tasks/TaskReviewProvenTxs.js +8 -3
- package/out/src/monitor/tasks/TaskReviewProvenTxs.js.map +1 -1
- package/out/src/monitor/tasks/TaskReviewStatus.js +7 -5
- package/out/src/monitor/tasks/TaskReviewStatus.js.map +1 -1
- package/out/src/monitor/tasks/TaskReviewUtxos.js +6 -2
- package/out/src/monitor/tasks/TaskReviewUtxos.js.map +1 -1
- package/out/src/monitor/tasks/TaskSendWaiting.js +9 -2
- package/out/src/monitor/tasks/TaskSendWaiting.js.map +1 -1
- package/out/src/monitor/tasks/TaskSyncWhenIdle.js +2 -1
- package/out/src/monitor/tasks/TaskSyncWhenIdle.js.map +1 -1
- package/out/src/monitor/tasks/TaskUnFail.js +6 -5
- package/out/src/monitor/tasks/TaskUnFail.js.map +1 -1
- package/out/src/monitor/tasks/WalletMonitorTask.js +7 -4
- package/out/src/monitor/tasks/WalletMonitorTask.js.map +1 -1
- package/out/src/sdk/PrivilegedKeyManager.js +44 -27
- package/out/src/sdk/PrivilegedKeyManager.js.map +1 -1
- package/out/src/sdk/WERR_errors.js +23 -8
- package/out/src/sdk/WERR_errors.js.map +1 -1
- package/out/src/sdk/WalletError.js +7 -7
- package/out/src/sdk/WalletError.js.map +1 -1
- package/out/src/services/ServiceCollection.js +9 -2
- package/out/src/services/ServiceCollection.js.map +1 -1
- package/out/src/services/Services.js +58 -54
- package/out/src/services/Services.js.map +1 -1
- package/out/src/services/chaintracker/BHServiceClient.js +8 -2
- package/out/src/services/chaintracker/BHServiceClient.js.map +1 -1
- package/out/src/services/chaintracker/ChaintracksChainTracker.js +5 -2
- package/out/src/services/chaintracker/ChaintracksChainTracker.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Chaintracks.js +27 -21
- package/out/src/services/chaintracker/chaintracks/Chaintracks.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/ChaintracksService.js +10 -5
- package/out/src/services/chaintracker/chaintracks/ChaintracksService.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js +4 -1
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.js +8 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.js +7 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.js +5 -3
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainWs.js +3 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainWs.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.js +3 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.js +3 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainWs.js +4 -3
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainWs.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.js +1 -2
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.js +8 -5
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.js +3 -1
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksKnexMigrations.js +2 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksKnexMigrations.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.js +12 -6
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.js +8 -7
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageKnex.js +8 -8
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageKnex.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.js +15 -16
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.js +1 -1
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createDefaultKnexChaintracksOptions.js +3 -3
- package/out/src/services/chaintracker/chaintracks/createDefaultKnexChaintracksOptions.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.js +1 -1
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.js +1 -1
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createKnexChaintracks.js +1 -1
- package/out/src/services/chaintracker/chaintracks/createKnexChaintracks.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.js +1 -1
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.js +19 -16
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataReader.js +4 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataReader.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.js +17 -4
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.js +21 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.js +1 -3
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFs.js +9 -3
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFs.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.js +7 -5
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.js +4 -6
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js +1 -1
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js.map +1 -1
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.js +8 -8
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.js.map +1 -1
- package/out/src/services/createDefaultWalletServicesOptions.js +8 -8
- package/out/src/services/createDefaultWalletServicesOptions.js.map +1 -1
- package/out/src/services/providers/ARC.js +13 -5
- package/out/src/services/providers/ARC.js.map +1 -1
- package/out/src/services/providers/ArcSSEClient.js +9 -8
- package/out/src/services/providers/ArcSSEClient.js.map +1 -1
- package/out/src/services/providers/Bitails.js +6 -2
- package/out/src/services/providers/Bitails.js.map +1 -1
- package/out/src/services/providers/SdkWhatsOnChain.js +6 -2
- package/out/src/services/providers/SdkWhatsOnChain.js.map +1 -1
- package/out/src/services/providers/WhatsOnChain.js +2 -1
- package/out/src/services/providers/WhatsOnChain.js.map +1 -1
- package/out/src/services/providers/getBeefForTxid.js +2 -1
- package/out/src/services/providers/getBeefForTxid.js.map +1 -1
- package/out/src/signer/WalletSigner.js +4 -1
- package/out/src/signer/WalletSigner.js.map +1 -1
- package/out/src/signer/methods/acquireDirectCertificate.js +1 -2
- package/out/src/signer/methods/acquireDirectCertificate.js.map +1 -1
- package/out/src/signer/methods/buildSignableTransaction.js +1 -2
- package/out/src/signer/methods/buildSignableTransaction.js.map +1 -1
- package/out/src/signer/methods/completeSignedTransaction.js +4 -5
- package/out/src/signer/methods/completeSignedTransaction.js.map +1 -1
- package/out/src/signer/methods/createAction.js +9 -11
- package/out/src/signer/methods/createAction.js.map +1 -1
- package/out/src/signer/methods/internalizeAction.d.ts +8 -1
- package/out/src/signer/methods/internalizeAction.d.ts.map +1 -1
- package/out/src/signer/methods/internalizeAction.js +8 -1
- package/out/src/signer/methods/internalizeAction.js.map +1 -1
- package/out/src/signer/methods/signAction.js +5 -6
- package/out/src/signer/methods/signAction.js.map +1 -1
- package/out/src/storage/StorageIdb.js +84 -99
- package/out/src/storage/StorageIdb.js.map +1 -1
- package/out/src/storage/StorageKnex.d.ts.map +1 -1
- package/out/src/storage/StorageKnex.js +22 -29
- package/out/src/storage/StorageKnex.js.map +1 -1
- package/out/src/storage/StorageProvider.d.ts +4 -1
- package/out/src/storage/StorageProvider.d.ts.map +1 -1
- package/out/src/storage/StorageProvider.js +122 -32
- package/out/src/storage/StorageProvider.js.map +1 -1
- package/out/src/storage/StorageReader.js +4 -2
- package/out/src/storage/StorageReader.js.map +1 -1
- package/out/src/storage/StorageSyncReader.js +2 -0
- package/out/src/storage/StorageSyncReader.js.map +1 -1
- package/out/src/storage/WalletStorageManager.js +47 -25
- package/out/src/storage/WalletStorageManager.js.map +1 -1
- package/out/src/storage/adminServer/adminServer.js +35 -48
- package/out/src/storage/adminServer/adminServer.js.map +1 -1
- package/out/src/storage/idbHelpers.js +1 -2
- package/out/src/storage/idbHelpers.js.map +1 -1
- package/out/src/storage/methods/ListActionsSpecOp.d.ts.map +1 -1
- package/out/src/storage/methods/ListActionsSpecOp.js +69 -6
- package/out/src/storage/methods/ListActionsSpecOp.js.map +1 -1
- package/out/src/storage/methods/ListOutputsSpecOp.d.ts.map +1 -1
- package/out/src/storage/methods/ListOutputsSpecOp.js +5 -2
- package/out/src/storage/methods/ListOutputsSpecOp.js.map +1 -1
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js +10 -12
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js.map +1 -1
- package/out/src/storage/methods/createAction.d.ts.map +1 -1
- package/out/src/storage/methods/createAction.js +111 -69
- package/out/src/storage/methods/createAction.js.map +1 -1
- package/out/src/storage/methods/generateChange.js +2 -3
- package/out/src/storage/methods/generateChange.js.map +1 -1
- package/out/src/storage/methods/getBeefForTransaction.js +2 -4
- package/out/src/storage/methods/getBeefForTransaction.js.map +1 -1
- package/out/src/storage/methods/internalizeAction.d.ts +69 -2
- package/out/src/storage/methods/internalizeAction.d.ts.map +1 -1
- package/out/src/storage/methods/internalizeAction.js +232 -27
- package/out/src/storage/methods/internalizeAction.js.map +1 -1
- package/out/src/storage/methods/listActionsIdb.js +7 -9
- package/out/src/storage/methods/listActionsIdb.js.map +1 -1
- package/out/src/storage/methods/listActionsKnex.js +7 -9
- package/out/src/storage/methods/listActionsKnex.js.map +1 -1
- package/out/src/storage/methods/listOutputsIdb.js +5 -7
- package/out/src/storage/methods/listOutputsIdb.js.map +1 -1
- package/out/src/storage/methods/listOutputsKnex.js +9 -10
- package/out/src/storage/methods/listOutputsKnex.js.map +1 -1
- package/out/src/storage/methods/processAction.d.ts.map +1 -1
- package/out/src/storage/methods/processAction.js +12 -11
- package/out/src/storage/methods/processAction.js.map +1 -1
- package/out/src/storage/methods/reviewStatus.d.ts +3 -2
- package/out/src/storage/methods/reviewStatus.d.ts.map +1 -1
- package/out/src/storage/methods/reviewStatus.js +34 -2
- package/out/src/storage/methods/reviewStatus.js.map +1 -1
- package/out/src/storage/methods/reviewStatusIdb.d.ts +2 -2
- package/out/src/storage/methods/reviewStatusIdb.d.ts.map +1 -1
- package/out/src/storage/methods/reviewStatusIdb.js +54 -13
- package/out/src/storage/methods/reviewStatusIdb.js.map +1 -1
- package/out/src/storage/portable/index.d.ts.map +1 -1
- package/out/src/storage/portable/index.js +171 -129
- package/out/src/storage/portable/index.js.map +1 -1
- package/out/src/storage/remoting/StorageClient.js +2 -3
- package/out/src/storage/remoting/StorageClient.js.map +1 -1
- package/out/src/storage/remoting/StorageClientBase.js +6 -3
- package/out/src/storage/remoting/StorageClientBase.js.map +1 -1
- package/out/src/storage/remoting/StorageServer.js +17 -11
- package/out/src/storage/remoting/StorageServer.js.map +1 -1
- package/out/src/storage/schema/KnexMigrations.js +5 -1
- package/out/src/storage/schema/KnexMigrations.js.map +1 -1
- package/out/src/storage/schema/entities/EntityBase.js +1 -0
- package/out/src/storage/schema/entities/EntityBase.js.map +1 -1
- package/out/src/storage/schema/entities/EntityOutputBasket.js +1 -1
- package/out/src/storage/schema/entities/EntityOutputBasket.js.map +1 -1
- package/out/src/storage/schema/entities/EntityProvenTx.js +12 -13
- package/out/src/storage/schema/entities/EntityProvenTx.js.map +1 -1
- package/out/src/storage/schema/entities/EntityProvenTxReq.js +7 -9
- package/out/src/storage/schema/entities/EntityProvenTxReq.js.map +1 -1
- package/out/src/storage/schema/entities/EntitySyncState.js +6 -3
- package/out/src/storage/schema/entities/EntitySyncState.js.map +1 -1
- package/out/src/storage/schema/entities/MergeEntity.js +4 -0
- package/out/src/storage/schema/entities/MergeEntity.js.map +1 -1
- package/out/src/storage/storageProviderHelpers.js +2 -3
- package/out/src/storage/storageProviderHelpers.js.map +1 -1
- package/out/src/storage/sync/StorageMySQLDojoReader.js +2 -2
- package/out/src/storage/sync/StorageMySQLDojoReader.js.map +1 -1
- package/out/src/utility/Format.js +4 -5
- package/out/src/utility/Format.js.map +1 -1
- package/out/src/utility/ScriptTemplateBRC29.js +7 -6
- package/out/src/utility/ScriptTemplateBRC29.js.map +1 -1
- package/out/src/utility/brc114ActionTimeLabels.js +1 -1
- package/out/src/utility/brc114ActionTimeLabels.js.map +1 -1
- package/out/src/utility/identityUtils.js +2 -4
- package/out/src/utility/identityUtils.js.map +1 -1
- package/out/src/utility/utilityHelpers.buffer.js +3 -3
- package/out/src/utility/utilityHelpers.buffer.js.map +1 -1
- package/out/src/utility/utilityHelpers.js +2 -2
- package/out/src/utility/utilityHelpers.js.map +1 -1
- package/out/src/utility/utilityHelpers.noBuffer.js +4 -4
- package/out/src/utility/utilityHelpers.noBuffer.js.map +1 -1
- package/out/src/wab-client/WABClient.js +1 -0
- package/out/src/wab-client/WABClient.js.map +1 -1
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.js +1 -4
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.js.map +1 -1
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.js +1 -4
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.js.map +1 -1
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.js +1 -4
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.js.map +1 -1
- package/package.json +19 -19
- package/out/src/__tests/CWIStyleWalletManager.test.d.ts +0 -2
- package/out/src/__tests/CWIStyleWalletManager.test.d.ts.map +0 -1
- package/out/src/__tests/CWIStyleWalletManager.test.js +0 -810
- package/out/src/__tests/CWIStyleWalletManager.test.js.map +0 -1
- package/out/src/__tests/ShamirWalletManager.test.d.ts +0 -2
- package/out/src/__tests/ShamirWalletManager.test.d.ts.map +0 -1
- package/out/src/__tests/ShamirWalletManager.test.js +0 -303
- package/out/src/__tests/ShamirWalletManager.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.callbacks.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.callbacks.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.callbacks.test.js +0 -365
- package/out/src/__tests/WalletPermissionsManager.callbacks.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.checks.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.checks.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.checks.test.js +0 -642
- package/out/src/__tests/WalletPermissionsManager.checks.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.encryption.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.encryption.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.encryption.test.js +0 -335
- package/out/src/__tests/WalletPermissionsManager.encryption.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.fixtures.d.ts +0 -86
- package/out/src/__tests/WalletPermissionsManager.fixtures.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.fixtures.js +0 -280
- package/out/src/__tests/WalletPermissionsManager.fixtures.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.flows.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.flows.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.flows.test.js +0 -613
- package/out/src/__tests/WalletPermissionsManager.flows.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.initialization.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.initialization.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.initialization.test.js +0 -227
- package/out/src/__tests/WalletPermissionsManager.initialization.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.pmodules.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.pmodules.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.pmodules.test.js +0 -735
- package/out/src/__tests/WalletPermissionsManager.pmodules.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.proxying.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.proxying.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.proxying.test.js +0 -585
- package/out/src/__tests/WalletPermissionsManager.proxying.test.js.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.tokens.test.d.ts +0 -2
- package/out/src/__tests/WalletPermissionsManager.tokens.test.d.ts.map +0 -1
- package/out/src/__tests/WalletPermissionsManager.tokens.test.js +0 -416
- package/out/src/__tests/WalletPermissionsManager.tokens.test.js.map +0 -1
- package/out/src/entropy/__tests/EntropyCollector.test.d.ts +0 -2
- package/out/src/entropy/__tests/EntropyCollector.test.d.ts.map +0 -1
- package/out/src/entropy/__tests/EntropyCollector.test.js +0 -137
- package/out/src/entropy/__tests/EntropyCollector.test.js.map +0 -1
- package/out/src/monitor/__test/MonitorDaemon.man.test.d.ts +0 -2
- package/out/src/monitor/__test/MonitorDaemon.man.test.d.ts.map +0 -1
- package/out/src/monitor/__test/MonitorDaemon.man.test.js +0 -41
- package/out/src/monitor/__test/MonitorDaemon.man.test.js.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskArcSSE.test.d.ts +0 -2
- package/out/src/monitor/tasks/__tests/TaskArcSSE.test.d.ts.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskArcSSE.test.js +0 -257
- package/out/src/monitor/tasks/__tests/TaskArcSSE.test.js.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewDoubleSpends.test.d.ts +0 -2
- package/out/src/monitor/tasks/__tests/TaskReviewDoubleSpends.test.d.ts.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewDoubleSpends.test.js +0 -161
- package/out/src/monitor/tasks/__tests/TaskReviewDoubleSpends.test.js.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewProvenTxs.test.d.ts +0 -2
- package/out/src/monitor/tasks/__tests/TaskReviewProvenTxs.test.d.ts.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewProvenTxs.test.js +0 -214
- package/out/src/monitor/tasks/__tests/TaskReviewProvenTxs.test.js.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewUtxos.test.d.ts +0 -2
- package/out/src/monitor/tasks/__tests/TaskReviewUtxos.test.d.ts.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskReviewUtxos.test.js +0 -92
- package/out/src/monitor/tasks/__tests/TaskReviewUtxos.test.js.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskSendWaiting.test.d.ts +0 -2
- package/out/src/monitor/tasks/__tests/TaskSendWaiting.test.d.ts.map +0 -1
- package/out/src/monitor/tasks/__tests/TaskSendWaiting.test.js +0 -139
- package/out/src/monitor/tasks/__tests/TaskSendWaiting.test.js.map +0 -1
- package/out/src/sdk/__test/CertificateLifeCycle.test.d.ts +0 -2
- package/out/src/sdk/__test/CertificateLifeCycle.test.d.ts.map +0 -1
- package/out/src/sdk/__test/CertificateLifeCycle.test.js +0 -62
- package/out/src/sdk/__test/CertificateLifeCycle.test.js.map +0 -1
- package/out/src/sdk/__test/PrivilegedKeyManager.test.d.ts +0 -2
- package/out/src/sdk/__test/PrivilegedKeyManager.test.d.ts.map +0 -1
- package/out/src/sdk/__test/PrivilegedKeyManager.test.js +0 -647
- package/out/src/sdk/__test/PrivilegedKeyManager.test.js.map +0 -1
- package/out/src/sdk/__test/WalletError.test.d.ts +0 -2
- package/out/src/sdk/__test/WalletError.test.d.ts.map +0 -1
- package/out/src/sdk/__test/WalletError.test.js +0 -255
- package/out/src/sdk/__test/WalletError.test.js.map +0 -1
- package/out/src/sdk/__test/validationHelpers.test.d.ts +0 -2
- package/out/src/sdk/__test/validationHelpers.test.d.ts.map +0 -1
- package/out/src/sdk/__test/validationHelpers.test.js +0 -20
- package/out/src/sdk/__test/validationHelpers.test.js.map +0 -1
- package/out/src/services/__tests/ARC.man.test.d.ts +0 -2
- package/out/src/services/__tests/ARC.man.test.d.ts.map +0 -1
- package/out/src/services/__tests/ARC.man.test.js +0 -104
- package/out/src/services/__tests/ARC.man.test.js.map +0 -1
- package/out/src/services/__tests/ARC.timeout.man.test.d.ts +0 -2
- package/out/src/services/__tests/ARC.timeout.man.test.d.ts.map +0 -1
- package/out/src/services/__tests/ARC.timeout.man.test.js +0 -74
- package/out/src/services/__tests/ARC.timeout.man.test.js.map +0 -1
- package/out/src/services/__tests/ArcGorillaPool.man.test.d.ts +0 -2
- package/out/src/services/__tests/ArcGorillaPool.man.test.d.ts.map +0 -1
- package/out/src/services/__tests/ArcGorillaPool.man.test.js +0 -93
- package/out/src/services/__tests/ArcGorillaPool.man.test.js.map +0 -1
- package/out/src/services/__tests/arcServices.test.d.ts +0 -2
- package/out/src/services/__tests/arcServices.test.d.ts.map +0 -1
- package/out/src/services/__tests/arcServices.test.js +0 -7
- package/out/src/services/__tests/arcServices.test.js.map +0 -1
- package/out/src/services/__tests/bitrails.test.d.ts +0 -2
- package/out/src/services/__tests/bitrails.test.d.ts.map +0 -1
- package/out/src/services/__tests/bitrails.test.js +0 -60
- package/out/src/services/__tests/bitrails.test.js.map +0 -1
- package/out/src/services/__tests/getFiatExchangeRate.test.d.ts +0 -2
- package/out/src/services/__tests/getFiatExchangeRate.test.d.ts.map +0 -1
- package/out/src/services/__tests/getFiatExchangeRate.test.js +0 -156
- package/out/src/services/__tests/getFiatExchangeRate.test.js.map +0 -1
- package/out/src/services/__tests/getMerklePath.test.d.ts +0 -2
- package/out/src/services/__tests/getMerklePath.test.d.ts.map +0 -1
- package/out/src/services/__tests/getMerklePath.test.js +0 -16
- package/out/src/services/__tests/getMerklePath.test.js.map +0 -1
- package/out/src/services/__tests/getRawTx.test.d.ts +0 -2
- package/out/src/services/__tests/getRawTx.test.d.ts.map +0 -1
- package/out/src/services/__tests/getRawTx.test.js +0 -16
- package/out/src/services/__tests/getRawTx.test.js.map +0 -1
- package/out/src/services/__tests/postBeef.test.d.ts +0 -2
- package/out/src/services/__tests/postBeef.test.d.ts.map +0 -1
- package/out/src/services/__tests/postBeef.test.js +0 -101
- package/out/src/services/__tests/postBeef.test.js.map +0 -1
- package/out/src/services/__tests/verifyBeef.test.d.ts +0 -2
- package/out/src/services/__tests/verifyBeef.test.d.ts.map +0 -1
- package/out/src/services/__tests/verifyBeef.test.js +0 -43
- package/out/src/services/__tests/verifyBeef.test.js.map +0 -1
- package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.d.ts +0 -2
- package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.js +0 -25
- package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.js.map +0 -1
- package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.d.ts +0 -2
- package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.js +0 -27
- package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/BulkIngestorCDNBabbage.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/BulkIngestorCDNBabbage.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/BulkIngestorCDNBabbage.test.js +0 -57
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/BulkIngestorCDNBabbage.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/LiveIngestorWhatsOnChainPoll.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/LiveIngestorWhatsOnChainPoll.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/LiveIngestorWhatsOnChainPoll.test.js +0 -41
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/LiveIngestorWhatsOnChainPoll.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/WhatsOnChainServices.man.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/WhatsOnChainServices.man.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/WhatsOnChainServices.man.test.js +0 -109
- package/out/src/services/chaintracker/chaintracks/Ingest/__tests/WhatsOnChainServices.man.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageIdb.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageIdb.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageIdb.test.js +0 -88
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageIdb.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageKnex.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageKnex.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageKnex.test.js +0 -39
- package/out/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageKnex.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/Chaintracks.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/__tests/Chaintracks.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/Chaintracks.test.js +0 -76
- package/out/src/services/chaintracker/chaintracks/__tests/Chaintracks.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksCDN.man.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksCDN.man.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksCDN.man.test.js +0 -44
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksCDN.man.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksClientApi.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksClientApi.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksClientApi.test.js +0 -165
- package/out/src/services/chaintracker/chaintracks/__tests/ChaintracksClientApi.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/LocalCdnServer.d.ts +0 -12
- package/out/src/services/chaintracker/chaintracks/__tests/LocalCdnServer.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/LocalCdnServer.js +0 -66
- package/out/src/services/chaintracker/chaintracks/__tests/LocalCdnServer.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/bulkIngestorFailures.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/__tests/bulkIngestorFailures.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/bulkIngestorFailures.test.js +0 -109
- package/out/src/services/chaintracker/chaintracks/__tests/bulkIngestorFailures.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/createIdbChaintracks.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/__tests/createIdbChaintracks.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/__tests/createIdbChaintracks.test.js +0 -55
- package/out/src/services/chaintracker/chaintracks/__tests/createIdbChaintracks.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/BulkFileDataManager.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/util/__tests/BulkFileDataManager.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/BulkFileDataManager.test.js +0 -255
- package/out/src/services/chaintracker/chaintracks/util/__tests/BulkFileDataManager.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/ChaintracksFetch.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/util/__tests/ChaintracksFetch.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/ChaintracksFetch.test.js +0 -56
- package/out/src/services/chaintracker/chaintracks/util/__tests/ChaintracksFetch.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/HeightRange.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/util/__tests/HeightRange.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/HeightRange.test.js +0 -69
- package/out/src/services/chaintracker/chaintracks/util/__tests/HeightRange.test.js.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/SingleWriterMultiReaderLock.test.d.ts +0 -2
- package/out/src/services/chaintracker/chaintracks/util/__tests/SingleWriterMultiReaderLock.test.d.ts.map +0 -1
- package/out/src/services/chaintracker/chaintracks/util/__tests/SingleWriterMultiReaderLock.test.js +0 -51
- package/out/src/services/chaintracker/chaintracks/util/__tests/SingleWriterMultiReaderLock.test.js.map +0 -1
- package/out/src/services/providers/__tests/ArcSSEClient.test.d.ts +0 -2
- package/out/src/services/providers/__tests/ArcSSEClient.test.d.ts.map +0 -1
- package/out/src/services/providers/__tests/ArcSSEClient.test.js +0 -256
- package/out/src/services/providers/__tests/ArcSSEClient.test.js.map +0 -1
- package/out/src/services/providers/__tests/WhatsOnChain.test.d.ts +0 -2
- package/out/src/services/providers/__tests/WhatsOnChain.test.d.ts.map +0 -1
- package/out/src/services/providers/__tests/WhatsOnChain.test.js +0 -191
- package/out/src/services/providers/__tests/WhatsOnChain.test.js.map +0 -1
- package/out/src/services/providers/__tests/exchangeRates.test.d.ts +0 -2
- package/out/src/services/providers/__tests/exchangeRates.test.d.ts.map +0 -1
- package/out/src/services/providers/__tests/exchangeRates.test.js +0 -23
- package/out/src/services/providers/__tests/exchangeRates.test.js.map +0 -1
- package/out/src/storage/__test/StorageIdb.test.d.ts +0 -2
- package/out/src/storage/__test/StorageIdb.test.d.ts.map +0 -1
- package/out/src/storage/__test/StorageIdb.test.js +0 -44
- package/out/src/storage/__test/StorageIdb.test.js.map +0 -1
- package/out/src/storage/__test/WalletStorageManager.test.d.ts +0 -2
- package/out/src/storage/__test/WalletStorageManager.test.d.ts.map +0 -1
- package/out/src/storage/__test/WalletStorageManager.test.js +0 -254
- package/out/src/storage/__test/WalletStorageManager.test.js.map +0 -1
- package/out/src/storage/__test/adminStats.man.test.d.ts +0 -2
- package/out/src/storage/__test/adminStats.man.test.d.ts.map +0 -1
- package/out/src/storage/__test/adminStats.man.test.js +0 -78
- package/out/src/storage/__test/adminStats.man.test.js.map +0 -1
- package/out/src/storage/__test/findStaleMerkleRoots.test.d.ts +0 -2
- package/out/src/storage/__test/findStaleMerkleRoots.test.d.ts.map +0 -1
- package/out/src/storage/__test/findStaleMerkleRoots.test.js +0 -41
- package/out/src/storage/__test/findStaleMerkleRoots.test.js.map +0 -1
- package/out/src/storage/__test/findStaleMerkleRootsKnex.test.d.ts +0 -2
- package/out/src/storage/__test/findStaleMerkleRootsKnex.test.d.ts.map +0 -1
- package/out/src/storage/__test/findStaleMerkleRootsKnex.test.js +0 -73
- package/out/src/storage/__test/findStaleMerkleRootsKnex.test.js.map +0 -1
- package/out/src/storage/__test/getBeefForTransaction.test.d.ts +0 -2
- package/out/src/storage/__test/getBeefForTransaction.test.d.ts.map +0 -1
- package/out/src/storage/__test/getBeefForTransaction.test.js +0 -347
- package/out/src/storage/__test/getBeefForTransaction.test.js.map +0 -1
- package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.d.ts +0 -2
- package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.d.ts.map +0 -1
- package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.js +0 -1111
- package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.js.map +0 -1
- package/out/src/storage/methods/__test/offsetKey.test.d.ts +0 -2
- package/out/src/storage/methods/__test/offsetKey.test.d.ts.map +0 -1
- package/out/src/storage/methods/__test/offsetKey.test.js +0 -229
- package/out/src/storage/methods/__test/offsetKey.test.js.map +0 -1
- package/out/src/storage/remoting/__test/StorageClient.man.test.d.ts +0 -2
- package/out/src/storage/remoting/__test/StorageClient.man.test.d.ts.map +0 -1
- package/out/src/storage/remoting/__test/StorageClient.man.test.js +0 -487
- package/out/src/storage/remoting/__test/StorageClient.man.test.js.map +0 -1
- package/out/src/storage/remoting/__test/StorageClient.test.d.ts +0 -2
- package/out/src/storage/remoting/__test/StorageClient.test.d.ts.map +0 -1
- package/out/src/storage/remoting/__test/StorageClient.test.js +0 -119
- package/out/src/storage/remoting/__test/StorageClient.test.js.map +0 -1
- package/out/src/storage/remoting/__tests__/entityValidationHelpers.test.d.ts +0 -2
- package/out/src/storage/remoting/__tests__/entityValidationHelpers.test.d.ts.map +0 -1
- package/out/src/storage/remoting/__tests__/entityValidationHelpers.test.js +0 -268
- package/out/src/storage/remoting/__tests__/entityValidationHelpers.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.js +0 -301
- package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/CertificateTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/CertificateTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/CertificateTests.test.js +0 -308
- package/out/src/storage/schema/entities/__tests/CertificateTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/CommissionTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/CommissionTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/CommissionTests.test.js +0 -316
- package/out/src/storage/schema/entities/__tests/CommissionTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.js +0 -228
- package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.js +0 -191
- package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTagTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/OutputTagTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTagTests.test.js +0 -226
- package/out/src/storage/schema/entities/__tests/OutputTagTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/OutputTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/OutputTests.test.js +0 -413
- package/out/src/storage/schema/entities/__tests/OutputTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.js +0 -331
- package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.js +0 -474
- package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/SyncStateTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/SyncStateTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/SyncStateTests.test.js +0 -234
- package/out/src/storage/schema/entities/__tests/SyncStateTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/TransactionTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/TransactionTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/TransactionTests.test.js +0 -539
- package/out/src/storage/schema/entities/__tests/TransactionTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.js +0 -304
- package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/TxLabelTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/TxLabelTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/TxLabelTests.test.js +0 -170
- package/out/src/storage/schema/entities/__tests/TxLabelTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/stampLogTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/stampLogTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/stampLogTests.test.js +0 -81
- package/out/src/storage/schema/entities/__tests/stampLogTests.test.js.map +0 -1
- package/out/src/storage/schema/entities/__tests/usersTests.test.d.ts +0 -2
- package/out/src/storage/schema/entities/__tests/usersTests.test.d.ts.map +0 -1
- package/out/src/storage/schema/entities/__tests/usersTests.test.js +0 -277
- package/out/src/storage/schema/entities/__tests/usersTests.test.js.map +0 -1
- package/out/src/utility/__tests/utilityHelpers.noBuffer.test.d.ts +0 -2
- package/out/src/utility/__tests/utilityHelpers.noBuffer.test.d.ts.map +0 -1
- package/out/src/utility/__tests/utilityHelpers.noBuffer.test.js +0 -107
- package/out/src/utility/__tests/utilityHelpers.noBuffer.test.js.map +0 -1
- package/out/src/wab-client/__tests/WABClient.man.test.d.ts +0 -2
- package/out/src/wab-client/__tests/WABClient.man.test.d.ts.map +0 -1
- package/out/src/wab-client/__tests/WABClient.man.test.js +0 -52
- package/out/src/wab-client/__tests/WABClient.man.test.js.map +0 -1
|
@@ -1,214 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const TaskReviewProvenTxs_1 = require("../TaskReviewProvenTxs");
|
|
4
|
-
const HeightRange_1 = require("../../../services/chaintracker/chaintracks/util/HeightRange");
|
|
5
|
-
function makeMonitor(options) {
|
|
6
|
-
const reviewHeightRange = jest.fn().mockResolvedValue(options.reviewResult || {
|
|
7
|
-
log: '',
|
|
8
|
-
reviewedHeights: 0,
|
|
9
|
-
mismatchedHeights: 0,
|
|
10
|
-
affectedTransactions: 0,
|
|
11
|
-
updatedTransactions: 0
|
|
12
|
-
});
|
|
13
|
-
const findStaleMerkleRoots = jest.fn(async ({ height }) => { var _a, _b; return (_b = (_a = options.staleRootsByHeight) === null || _a === void 0 ? void 0 : _a[height]) !== null && _b !== void 0 ? _b : []; });
|
|
14
|
-
const findMonitorEvents = jest.fn(async () => options.monitorEvents || []);
|
|
15
|
-
const runAsStorageProvider = jest.fn(async (fn) => await fn({ findStaleMerkleRoots }));
|
|
16
|
-
const reproveHeightMerkleRoot = jest.fn(async (height, staleRoot) => {
|
|
17
|
-
var _a;
|
|
18
|
-
return (((_a = options.reproveResultsByHeightRoot) === null || _a === void 0 ? void 0 : _a[`${height}:${staleRoot}`]) || {
|
|
19
|
-
log: ` reproved ${height}:${staleRoot}\n`,
|
|
20
|
-
updated: [],
|
|
21
|
-
unchanged: [],
|
|
22
|
-
unavailable: []
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
const logEvent = jest.fn().mockResolvedValue(undefined);
|
|
26
|
-
const chaintracks = {
|
|
27
|
-
currentHeight: jest.fn().mockResolvedValue(options.tipHeight),
|
|
28
|
-
findHeaderForHeight: jest.fn(async (height) => { var _a; return (_a = options.headersByHeight) === null || _a === void 0 ? void 0 : _a[height]; })
|
|
29
|
-
};
|
|
30
|
-
return {
|
|
31
|
-
monitor: {
|
|
32
|
-
storage: {
|
|
33
|
-
runAsStorageProvider,
|
|
34
|
-
reproveHeightMerkleRoot
|
|
35
|
-
},
|
|
36
|
-
chaintracks,
|
|
37
|
-
chaintracksWithEvents: undefined,
|
|
38
|
-
logEvent
|
|
39
|
-
},
|
|
40
|
-
reviewHeightRange,
|
|
41
|
-
findStaleMerkleRoots,
|
|
42
|
-
findMonitorEvents,
|
|
43
|
-
runAsStorageProvider,
|
|
44
|
-
reproveHeightMerkleRoot,
|
|
45
|
-
logEvent,
|
|
46
|
-
chaintracks
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
describe('TaskReviewProvenTxs tests', () => {
|
|
50
|
-
test('0 reviewHeightRange uses findStaleMerkleRoots and reproves only stale roots in the requested range', async () => {
|
|
51
|
-
const m = makeMonitor({
|
|
52
|
-
tipHeight: 120,
|
|
53
|
-
headersByHeight: {
|
|
54
|
-
107: { height: 107, merkleRoot: 'root-107', hash: 'hash-107' },
|
|
55
|
-
108: { height: 108, merkleRoot: 'root-108-new', hash: 'hash-108' }
|
|
56
|
-
},
|
|
57
|
-
staleRootsByHeight: {
|
|
58
|
-
107: [],
|
|
59
|
-
108: ['root-108-old']
|
|
60
|
-
},
|
|
61
|
-
reproveResultsByHeightRoot: {
|
|
62
|
-
'108:root-108-old': {
|
|
63
|
-
log: ' height 108 stale merkleRoot root-108-old with 2 impacted transactions\n',
|
|
64
|
-
updated: [{}],
|
|
65
|
-
unchanged: [{}],
|
|
66
|
-
unavailable: []
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 2, 12);
|
|
71
|
-
const result = await task.reviewHeightRange(new HeightRange_1.HeightRange(107, 108));
|
|
72
|
-
expect(m.findStaleMerkleRoots).toHaveBeenNthCalledWith(1, { height: 107, merkleRoot: 'root-107' });
|
|
73
|
-
expect(m.findStaleMerkleRoots).toHaveBeenNthCalledWith(2, { height: 108, merkleRoot: 'root-108-new' });
|
|
74
|
-
expect(m.reproveHeightMerkleRoot).toHaveBeenCalledTimes(1);
|
|
75
|
-
expect(m.reproveHeightMerkleRoot).toHaveBeenCalledWith(108, 'root-108-old');
|
|
76
|
-
expect(result.reviewedHeights).toBe(2);
|
|
77
|
-
expect(result.mismatchedHeights).toBe(1);
|
|
78
|
-
expect(result.affectedTransactions).toBe(2);
|
|
79
|
-
expect(result.updatedTransactions).toBe(1);
|
|
80
|
-
expect(result.log).toContain('height 108 canonical root-108-new stale root-108-old');
|
|
81
|
-
});
|
|
82
|
-
test('1 reviewHeightRange records unavailable headers and skips empty ranges cleanly', async () => {
|
|
83
|
-
const m = makeMonitor({
|
|
84
|
-
tipHeight: 120,
|
|
85
|
-
headersByHeight: {
|
|
86
|
-
10: undefined
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 2, 12);
|
|
90
|
-
const result = await task.reviewHeightRange(new HeightRange_1.HeightRange(10, 10));
|
|
91
|
-
const empty = await task.reviewHeightRange(HeightRange_1.HeightRange.empty);
|
|
92
|
-
expect(m.reproveHeightMerkleRoot).not.toHaveBeenCalled();
|
|
93
|
-
expect(result.reviewedHeights).toBe(1);
|
|
94
|
-
expect(result.log).toContain('height 10 canonical header unavailable');
|
|
95
|
-
expect(empty.reviewedHeights).toBe(0);
|
|
96
|
-
expect(empty.log).toBe('');
|
|
97
|
-
});
|
|
98
|
-
test('2 getLastReviewedHeight skips plain-text events and uses the latest checkpoint event', async () => {
|
|
99
|
-
const m = makeMonitor({
|
|
100
|
-
tipHeight: 120,
|
|
101
|
-
monitorEvents: [
|
|
102
|
-
{ details: 'reviewing heights 10..20 tip=120 minAge=100 maxPerRun=100' },
|
|
103
|
-
{ details: JSON.stringify({ reviewedThroughHeight: 20 }) },
|
|
104
|
-
{ details: JSON.stringify({ reviewedThroughHeight: 7 }) }
|
|
105
|
-
]
|
|
106
|
-
});
|
|
107
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor);
|
|
108
|
-
jest
|
|
109
|
-
.spyOn(task.storage, 'runAsStorageProvider')
|
|
110
|
-
.mockImplementation(async (fn) => await fn({ findMonitorEvents: m.findMonitorEvents }));
|
|
111
|
-
const lastReviewedHeight = await task.getLastReviewedHeight();
|
|
112
|
-
expect(lastReviewedHeight).toBe(20);
|
|
113
|
-
});
|
|
114
|
-
test('3 runTask starts from height 0 on cold start and caps the range by batch size and minimum age', async () => {
|
|
115
|
-
const m = makeMonitor({
|
|
116
|
-
tipHeight: 250,
|
|
117
|
-
reviewResult: {
|
|
118
|
-
log: '',
|
|
119
|
-
reviewedHeights: 100,
|
|
120
|
-
mismatchedHeights: 0,
|
|
121
|
-
affectedTransactions: 0,
|
|
122
|
-
updatedTransactions: 0
|
|
123
|
-
}
|
|
124
|
-
});
|
|
125
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 100, 100);
|
|
126
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(undefined);
|
|
127
|
-
const reviewSpy = jest.spyOn(task, 'reviewHeightRange').mockResolvedValue(m.reviewHeightRange());
|
|
128
|
-
const log = await task.runTask();
|
|
129
|
-
expect(reviewSpy).toHaveBeenCalledWith(new HeightRange_1.HeightRange(0, 99));
|
|
130
|
-
expect(log).toContain('"reviewedThroughHeight":99');
|
|
131
|
-
expect(log).toContain('"minBlockAge":100');
|
|
132
|
-
expect(log).toContain('reviewing heights 0..99 tip=250 minAge=100 maxPerRun=100');
|
|
133
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
134
|
-
});
|
|
135
|
-
test('4 runTask resumes from the last reviewed height plus one', async () => {
|
|
136
|
-
const m = makeMonitor({
|
|
137
|
-
tipHeight: 250,
|
|
138
|
-
reviewResult: {
|
|
139
|
-
log: ' height 121 canonical root-121-new stale root-121-old\n reproved stale root\n',
|
|
140
|
-
reviewedHeights: 21,
|
|
141
|
-
mismatchedHeights: 1,
|
|
142
|
-
affectedTransactions: 1,
|
|
143
|
-
updatedTransactions: 0
|
|
144
|
-
}
|
|
145
|
-
});
|
|
146
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 100, 100);
|
|
147
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(100);
|
|
148
|
-
const reviewSpy = jest.spyOn(task, 'reviewHeightRange').mockResolvedValue(m.reviewHeightRange());
|
|
149
|
-
const log = await task.runTask();
|
|
150
|
-
expect(reviewSpy).toHaveBeenCalledTimes(1);
|
|
151
|
-
expect(reviewSpy).toHaveBeenCalledWith(new HeightRange_1.HeightRange(101, 150));
|
|
152
|
-
expect(log).toContain('"reviewedThroughHeight":150');
|
|
153
|
-
expect(log).toContain('"minBlockAge":100');
|
|
154
|
-
expect(log).toContain('reviewing heights 101..150 tip=250 minAge=100 maxPerRun=100');
|
|
155
|
-
expect(log).toContain('height 121 canonical root-121-new stale root-121-old');
|
|
156
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
157
|
-
});
|
|
158
|
-
test('5 runTask returns review logs even when the range is clean', async () => {
|
|
159
|
-
const m = makeMonitor({
|
|
160
|
-
tipHeight: 250,
|
|
161
|
-
reviewResult: {
|
|
162
|
-
log: '',
|
|
163
|
-
reviewedHeights: 50,
|
|
164
|
-
mismatchedHeights: 0,
|
|
165
|
-
affectedTransactions: 0,
|
|
166
|
-
updatedTransactions: 0
|
|
167
|
-
}
|
|
168
|
-
});
|
|
169
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 50, 100);
|
|
170
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(149);
|
|
171
|
-
const reviewSpy = jest.spyOn(task, 'reviewHeightRange').mockResolvedValue(m.reviewHeightRange());
|
|
172
|
-
const log = await task.runTask();
|
|
173
|
-
expect(reviewSpy).toHaveBeenCalledTimes(1);
|
|
174
|
-
expect(reviewSpy).toHaveBeenCalledWith(new HeightRange_1.HeightRange(150, 150));
|
|
175
|
-
expect(log).toContain('"reviewedThroughHeight":150');
|
|
176
|
-
expect(log).toContain('"minBlockAge":100');
|
|
177
|
-
expect(log).toContain('reviewing heights 150..150 tip=250 minAge=100 maxPerRun=50');
|
|
178
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
179
|
-
});
|
|
180
|
-
test('6 runTask returns early when the chain tip is below the minimum age window', async () => {
|
|
181
|
-
const m = makeMonitor({
|
|
182
|
-
tipHeight: 5
|
|
183
|
-
});
|
|
184
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 100, 100);
|
|
185
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(undefined);
|
|
186
|
-
const log = await task.runTask();
|
|
187
|
-
expect(m.reviewHeightRange).not.toHaveBeenCalled();
|
|
188
|
-
expect(log).toBe('');
|
|
189
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
190
|
-
});
|
|
191
|
-
test('7 runTask returns early when all eligible heights have already been reviewed', async () => {
|
|
192
|
-
const m = makeMonitor({
|
|
193
|
-
tipHeight: 250
|
|
194
|
-
});
|
|
195
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 100, 100);
|
|
196
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(200);
|
|
197
|
-
const log = await task.runTask();
|
|
198
|
-
expect(m.reviewHeightRange).not.toHaveBeenCalled();
|
|
199
|
-
expect(log).toBe('');
|
|
200
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
201
|
-
});
|
|
202
|
-
test('8 runTask returns empty log when the computed range is empty', async () => {
|
|
203
|
-
const m = makeMonitor({
|
|
204
|
-
tipHeight: 250
|
|
205
|
-
});
|
|
206
|
-
const task = new TaskReviewProvenTxs_1.TaskReviewProvenTxs(m.monitor, 0, 0, 100);
|
|
207
|
-
jest.spyOn(task, 'getLastReviewedHeight').mockResolvedValue(undefined);
|
|
208
|
-
const log = await task.runTask();
|
|
209
|
-
expect(m.reviewHeightRange).not.toHaveBeenCalled();
|
|
210
|
-
expect(log).toBe('');
|
|
211
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
212
|
-
});
|
|
213
|
-
});
|
|
214
|
-
//# sourceMappingURL=TaskReviewProvenTxs.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TaskReviewProvenTxs.test.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/__tests/TaskReviewProvenTxs.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;AAC5D,6FAAyF;AAEzF,SAAS,WAAW,CAAE,OAarB;IACC,MAAM,iBAAiB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CACnD,OAAO,CAAC,YAAY,IAAI;QACtB,GAAG,EAAE,EAAE;QACP,eAAe,EAAE,CAAC;QAClB,iBAAiB,EAAE,CAAC;QACpB,oBAAoB,EAAE,CAAC;QACvB,mBAAmB,EAAE,CAAC;KACvB,CACF,CAAA;IACD,MAAM,oBAAoB,GAAG,IAAI,CAAC,EAAE,CAClC,KAAK,EAAE,EAAE,MAAM,EAAsB,EAAE,EAAE,eAAC,OAAA,MAAA,MAAA,OAAO,CAAC,kBAAkB,0CAAG,MAAM,CAAC,mCAAI,EAAE,CAAA,EAAA,CACrF,CAAA;IACD,MAAM,iBAAiB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAA;IAC1E,MAAM,oBAAoB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,EAAO,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAC,CAAA;IAC3F,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,MAAc,EAAE,SAAiB,EAAE,EAAE;;QAClF,OAAO,CACL,CAAC,MAAA,OAAO,CAAC,0BAA0B,0CAAG,GAAG,MAAM,IAAI,SAAS,EAAE,CAAC,CAAC,IAAI;YAClE,GAAG,EAAE,cAAc,MAAM,IAAI,SAAS,IAAI;YAC1C,OAAO,EAAE,EAAE;YACX,SAAS,EAAE,EAAE;YACb,WAAW,EAAE,EAAE;SAChB,CACF,CAAA;IACH,CAAC,CAAC,CAAA;IACF,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;IAEvD,MAAM,WAAW,GAAG;QAClB,aAAa,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,SAAS,CAAC;QAC7D,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,MAAc,EAAE,EAAE,WAAC,OAAA,MAAA,OAAO,CAAC,eAAe,0CAAG,MAAM,CAAC,CAAA,EAAA,CAAC;KAC1F,CAAA;IAED,OAAO;QACL,OAAO,EAAE;YACP,OAAO,EAAE;gBACP,oBAAoB;gBACpB,uBAAuB;aACxB;YACD,WAAW;YACX,qBAAqB,EAAE,SAAS;YAChC,QAAQ;SACT;QACD,iBAAiB;QACjB,oBAAoB;QACpB,iBAAiB;QACjB,oBAAoB;QACpB,uBAAuB;QACvB,QAAQ;QACR,WAAW;KACZ,CAAA;AACH,CAAC;AAED,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAI,CAAC,oGAAoG,EAAE,KAAK,IAAI,EAAE;QACpH,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,eAAe,EAAE;gBACf,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE;gBAC9D,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,cAAc,EAAE,IAAI,EAAE,UAAU,EAAE;aACnE;YACD,kBAAkB,EAAE;gBAClB,GAAG,EAAE,EAAE;gBACP,GAAG,EAAE,CAAC,cAAc,CAAC;aACtB;YACD,0BAA0B,EAAE;gBAC1B,kBAAkB,EAAE;oBAClB,GAAG,EAAE,2EAA2E;oBAChF,OAAO,EAAE,CAAC,EAAE,CAAC;oBACb,SAAS,EAAE,CAAC,EAAE,CAAC;oBACf,WAAW,EAAE,EAAE;iBAChB;aACF;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAA;QAEhE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,yBAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAEtE,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,uBAAuB,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAA;QAClG,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,uBAAuB,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,cAAc,EAAE,CAAC,CAAA;QACtG,MAAM,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QAC1D,MAAM,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,oBAAoB,CAAC,GAAG,EAAE,cAAc,CAAC,CAAA;QAC3E,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACtC,MAAM,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACxC,MAAM,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC3C,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC1C,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,sDAAsD,CAAC,CAAA;IACtF,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,gFAAgF,EAAE,KAAK,IAAI,EAAE;QAChG,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,eAAe,EAAE;gBACf,EAAE,EAAE,SAAS;aACd;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAA;QAEhE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,yBAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;QACpE,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,yBAAW,CAAC,KAAK,CAAC,CAAA;QAE7D,MAAM,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QACxD,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACtC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,wCAAwC,CAAC,CAAA;QACtE,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACrC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAC5B,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,sFAAsF,EAAE,KAAK,IAAI,EAAE;QACtG,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,aAAa,EAAE;gBACb,EAAE,OAAO,EAAE,2DAA2D,EAAE;gBACxE,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,qBAAqB,EAAE,EAAE,EAAE,CAAC,EAAE;gBAC1D,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,qBAAqB,EAAE,CAAC,EAAE,CAAC,EAAE;aAC1D;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,CAAC,CAAA;QACtD,IAAI;aACD,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,sBAAsB,CAAC;aAC3C,kBAAkB,CAAC,KAAK,EAAE,EAAO,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAA;QAE9F,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAA;QAE7D,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,+FAA+F,EAAE,KAAK,IAAI,EAAE;QAC/G,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,YAAY,EAAE;gBACZ,GAAG,EAAE,EAAE;gBACP,eAAe,EAAE,GAAG;gBACpB,iBAAiB,EAAE,CAAC;gBACpB,oBAAoB,EAAE,CAAC;gBACvB,mBAAmB,EAAE,CAAC;aACvB;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;QACnE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;QACtE,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAA;QAEhG,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,SAAS,CAAC,CAAC,oBAAoB,CAAC,IAAI,yBAAW,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;QAC9D,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,4BAA4B,CAAC,CAAA;QACnD,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAA;QAC1C,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,0DAA0D,CAAC,CAAA;QACjF,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,0DAA0D,EAAE,KAAK,IAAI,EAAE;QAC1E,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,YAAY,EAAE;gBACZ,GAAG,EAAE,iFAAiF;gBACtF,eAAe,EAAE,EAAE;gBACnB,iBAAiB,EAAE,CAAC;gBACpB,oBAAoB,EAAE,CAAC;gBACvB,mBAAmB,EAAE,CAAC;aACvB;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;QACnE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAA;QAChE,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAA;QAEhG,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QAC1C,MAAM,CAAC,SAAS,CAAC,CAAC,oBAAoB,CAAC,IAAI,yBAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QACjE,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAA;QACpD,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAA;QAC1C,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,6DAA6D,CAAC,CAAA;QACpF,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,sDAAsD,CAAC,CAAA;QAC7E,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;YACd,YAAY,EAAE;gBACZ,GAAG,EAAE,EAAE;gBACP,eAAe,EAAE,EAAE;gBACnB,iBAAiB,EAAE,CAAC;gBACpB,oBAAoB,EAAE,CAAC;gBACvB,mBAAmB,EAAE,CAAC;aACvB;SACF,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,CAAA;QAClE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAA;QAChE,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAA;QAEhG,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QAC1C,MAAM,CAAC,SAAS,CAAC,CAAC,oBAAoB,CAAC,IAAI,yBAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QACjE,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAA;QACpD,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAA;QAC1C,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,4DAA4D,CAAC,CAAA;QACnF,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC5F,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,CAAC;SACb,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;QACnE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;QAEtE,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QAClD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACpB,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,8EAA8E,EAAE,KAAK,IAAI,EAAE;QAC9F,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;SACf,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;QACnE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAA;QAEhE,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QAClD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACpB,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC9E,MAAM,CAAC,GAAG,WAAW,CAAC;YACpB,SAAS,EAAE,GAAG;SACf,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,IAAI,yCAAmB,CAAC,CAAC,CAAC,OAAc,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAA;QACjE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;QAEtE,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEhC,MAAM,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QAClD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACpB,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TaskReviewUtxos.test.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/__tests/TaskReviewUtxos.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const TaskReviewUtxos_1 = require("../TaskReviewUtxos");
|
|
4
|
-
const sdk_1 = require("../../../sdk");
|
|
5
|
-
function makeUser(userId, identityKey = `key-${userId}`) {
|
|
6
|
-
const now = new Date();
|
|
7
|
-
return {
|
|
8
|
-
created_at: now,
|
|
9
|
-
updated_at: now,
|
|
10
|
-
userId,
|
|
11
|
-
identityKey,
|
|
12
|
-
activeStorage: 'storage-key'
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
function makeOutput(outpoint, satoshis, spendable) {
|
|
16
|
-
return { outpoint, satoshis, spendable };
|
|
17
|
-
}
|
|
18
|
-
function makeMonitor(users, outputsByUserId) {
|
|
19
|
-
const findUsers = jest.fn().mockResolvedValue(users);
|
|
20
|
-
const listOutputs = jest.fn(async (auth) => {
|
|
21
|
-
var _a;
|
|
22
|
-
const outputs = (_a = outputsByUserId[auth.userId]) !== null && _a !== void 0 ? _a : [];
|
|
23
|
-
return {
|
|
24
|
-
totalOutputs: outputs.length,
|
|
25
|
-
outputs
|
|
26
|
-
};
|
|
27
|
-
});
|
|
28
|
-
const runAsStorageProvider = jest.fn(async (fn) => await fn({ findUsers, listOutputs }));
|
|
29
|
-
const logEvent = jest.fn().mockResolvedValue(undefined);
|
|
30
|
-
return {
|
|
31
|
-
monitor: {
|
|
32
|
-
storage: { runAsStorageProvider },
|
|
33
|
-
logEvent
|
|
34
|
-
},
|
|
35
|
-
findUsers,
|
|
36
|
-
listOutputs,
|
|
37
|
-
runAsStorageProvider,
|
|
38
|
-
logEvent
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
describe('TaskReviewUtxos', () => {
|
|
42
|
-
test('0 reviewByIdentityKey reviews all invalid utxos for the matching user', async () => {
|
|
43
|
-
const users = [makeUser(1), makeUser(2)];
|
|
44
|
-
const m = makeMonitor(users, {
|
|
45
|
-
1: [makeOutput('tx1.0', 50, false)],
|
|
46
|
-
2: []
|
|
47
|
-
});
|
|
48
|
-
const task = new TaskReviewUtxos_1.TaskReviewUtxos(m.monitor);
|
|
49
|
-
const log = await task.reviewByIdentityKey('key-1');
|
|
50
|
-
expect(m.findUsers).toHaveBeenCalledWith({ partial: { identityKey: 'key-1' } });
|
|
51
|
-
expect(m.listOutputs).toHaveBeenCalledWith({ userId: 1, identityKey: 'key-1' }, expect.objectContaining({
|
|
52
|
-
basket: sdk_1.specOpInvalidChange,
|
|
53
|
-
tags: ['release', 'all'],
|
|
54
|
-
tagQueryMode: 'all',
|
|
55
|
-
limit: 0,
|
|
56
|
-
offset: 0
|
|
57
|
-
}));
|
|
58
|
-
expect(m.logEvent).not.toHaveBeenCalled();
|
|
59
|
-
expect(log).toContain('userId 1: 1 spendable utxos updated to unspendable');
|
|
60
|
-
expect(log).toContain('tx1.0 50 now spent');
|
|
61
|
-
});
|
|
62
|
-
test('1 reviewByIdentityKey limits review to invalid change utxos when mode is change', async () => {
|
|
63
|
-
const users = [makeUser(1)];
|
|
64
|
-
const m = makeMonitor(users, { 1: [makeOutput('tx1.0', 50, false)] });
|
|
65
|
-
const task = new TaskReviewUtxos_1.TaskReviewUtxos(m.monitor);
|
|
66
|
-
await task.reviewByIdentityKey('key-1', 'change');
|
|
67
|
-
expect(m.listOutputs).toHaveBeenCalledWith({ userId: 1, identityKey: 'key-1' }, expect.objectContaining({
|
|
68
|
-
tags: ['release']
|
|
69
|
-
}));
|
|
70
|
-
});
|
|
71
|
-
test('2 reviewByIdentityKey returns no-findings summary when the user has no invalid utxos', async () => {
|
|
72
|
-
const users = [makeUser(1)];
|
|
73
|
-
const m = makeMonitor(users, {});
|
|
74
|
-
const task = new TaskReviewUtxos_1.TaskReviewUtxos(m.monitor);
|
|
75
|
-
const log = await task.reviewByIdentityKey('key-1');
|
|
76
|
-
expect(log).toBe('userId 1: no invalid utxos found, key-1\n');
|
|
77
|
-
});
|
|
78
|
-
test('3 reviewByIdentityKey reports when the identity key does not exist', async () => {
|
|
79
|
-
const m = makeMonitor([], {});
|
|
80
|
-
const task = new TaskReviewUtxos_1.TaskReviewUtxos(m.monitor);
|
|
81
|
-
const log = await task.reviewByIdentityKey('missing-key');
|
|
82
|
-
expect(m.listOutputs).not.toHaveBeenCalled();
|
|
83
|
-
expect(log).toBe('identityKey missing-key was not found\n');
|
|
84
|
-
});
|
|
85
|
-
test('4 trigger and runTask are stubbed out', async () => {
|
|
86
|
-
const m = makeMonitor([], {});
|
|
87
|
-
const task = new TaskReviewUtxos_1.TaskReviewUtxos(m.monitor);
|
|
88
|
-
expect(task.trigger(Date.now())).toEqual({ run: false });
|
|
89
|
-
await expect(task.runTask()).resolves.toBe('TaskReviewUtxos is disabled; use reviewByIdentityKey instead.\n');
|
|
90
|
-
});
|
|
91
|
-
});
|
|
92
|
-
//# sourceMappingURL=TaskReviewUtxos.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TaskReviewUtxos.test.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/__tests/TaskReviewUtxos.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TaskSendWaiting.test.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/__tests/TaskSendWaiting.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const TaskSendWaiting_1 = require("../TaskSendWaiting");
|
|
4
|
-
function makeReq(provenTxReqId, txid, updatedAt, batch) {
|
|
5
|
-
const now = new Date();
|
|
6
|
-
return {
|
|
7
|
-
provenTxReqId,
|
|
8
|
-
created_at: now,
|
|
9
|
-
updated_at: updatedAt,
|
|
10
|
-
txid,
|
|
11
|
-
batch,
|
|
12
|
-
status: 'unsent',
|
|
13
|
-
history: '{}',
|
|
14
|
-
notify: '{}',
|
|
15
|
-
attempts: 0,
|
|
16
|
-
notified: false
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
function makeMonitor(reqs) {
|
|
20
|
-
const findProvenTxReqs = jest.fn(async ({ paged, partial, status }) => {
|
|
21
|
-
let filtered = reqs;
|
|
22
|
-
if (partial === null || partial === void 0 ? void 0 : partial.batch)
|
|
23
|
-
filtered = filtered.filter(req => req.batch === partial.batch);
|
|
24
|
-
if (status) {
|
|
25
|
-
const statuses = Array.isArray(status) ? status : [status];
|
|
26
|
-
filtered = filtered.filter(req => statuses.includes(req.status));
|
|
27
|
-
}
|
|
28
|
-
if (paged)
|
|
29
|
-
return filtered.slice(paged.offset, paged.offset + paged.limit);
|
|
30
|
-
return filtered;
|
|
31
|
-
});
|
|
32
|
-
return {
|
|
33
|
-
monitor: {
|
|
34
|
-
storage: {
|
|
35
|
-
findProvenTxReqs
|
|
36
|
-
}
|
|
37
|
-
},
|
|
38
|
-
findProvenTxReqs
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
describe('TaskSendWaiting', () => {
|
|
42
|
-
afterEach(() => {
|
|
43
|
-
jest.restoreAllMocks();
|
|
44
|
-
});
|
|
45
|
-
test('0 uses the normal cadence after a partial waiting chunk and preserves storage order', async () => {
|
|
46
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
47
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
48
|
-
const reqs = [
|
|
49
|
-
makeReq(1, 'tx1', new Date('2026-01-01T11:59:40.000Z')),
|
|
50
|
-
makeReq(2, 'tx2', new Date('2026-01-01T11:59:50.000Z'))
|
|
51
|
-
];
|
|
52
|
-
const m = makeMonitor(reqs);
|
|
53
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 5);
|
|
54
|
-
jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
55
|
-
await task.runTask();
|
|
56
|
-
expect(m.findProvenTxReqs).toHaveBeenCalledWith({
|
|
57
|
-
partial: {},
|
|
58
|
-
status: ['unsent', 'sending'],
|
|
59
|
-
paged: { limit: 5, offset: 0 }
|
|
60
|
-
});
|
|
61
|
-
expect(task.processUnsent).toHaveBeenCalledTimes(1);
|
|
62
|
-
const processedReqs = task.processUnsent.mock.calls[0][0];
|
|
63
|
-
expect(processedReqs.map((r) => r.txid)).toEqual(['tx1', 'tx2']);
|
|
64
|
-
expect(task.triggerNextMsecs).toBe(80);
|
|
65
|
-
});
|
|
66
|
-
test('0a waits only until all fetched reqs reach the aged threshold when some are not ready yet', async () => {
|
|
67
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
68
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
69
|
-
const reqs = [
|
|
70
|
-
makeReq(1, 'tx1', new Date('2026-01-01T11:59:40.000Z')),
|
|
71
|
-
makeReq(2, 'tx2', new Date('2026-01-01T11:59:56.000Z'))
|
|
72
|
-
];
|
|
73
|
-
const m = makeMonitor(reqs);
|
|
74
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 5);
|
|
75
|
-
jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
76
|
-
await task.runTask();
|
|
77
|
-
expect(task.processUnsent).toHaveBeenCalledTimes(1);
|
|
78
|
-
const processedReqs = task.processUnsent.mock.calls[0][0];
|
|
79
|
-
expect(processedReqs.map((r) => r.txid)).toEqual(['tx1']);
|
|
80
|
-
expect(task.triggerNextMsecs).toBe(3000);
|
|
81
|
-
});
|
|
82
|
-
test('0aa gates a whole batch on its youngest req and fetches the full batch before sending', async () => {
|
|
83
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
84
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
85
|
-
const reqs = [
|
|
86
|
-
makeReq(1, 'tx1', new Date('2026-01-01T11:59:40.000Z'), 'batch-1'),
|
|
87
|
-
makeReq(2, 'tx2', new Date('2026-01-01T11:59:56.000Z'), 'batch-1'),
|
|
88
|
-
makeReq(3, 'tx3', new Date('2026-01-01T11:59:40.000Z'))
|
|
89
|
-
];
|
|
90
|
-
const m = makeMonitor(reqs);
|
|
91
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 4);
|
|
92
|
-
jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
93
|
-
await task.runTask();
|
|
94
|
-
expect(m.findProvenTxReqs).toHaveBeenCalledWith({
|
|
95
|
-
partial: { batch: 'batch-1' },
|
|
96
|
-
status: ['unsent', 'sending']
|
|
97
|
-
});
|
|
98
|
-
const processedReqs = task.processUnsent.mock.calls[0][0];
|
|
99
|
-
expect(processedReqs.map((r) => r.txid)).toEqual(['tx3']);
|
|
100
|
-
expect(task.triggerNextMsecs).toBe(3000);
|
|
101
|
-
});
|
|
102
|
-
test('0ab sends the full batch together once the youngest req is aged', async () => {
|
|
103
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
104
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
105
|
-
const reqs = [
|
|
106
|
-
makeReq(1, 'tx1', new Date('2026-01-01T11:59:40.000Z'), 'batch-1'),
|
|
107
|
-
makeReq(2, 'tx2', new Date('2026-01-01T11:59:50.000Z'), 'batch-1')
|
|
108
|
-
];
|
|
109
|
-
const m = makeMonitor(reqs);
|
|
110
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 1);
|
|
111
|
-
jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
112
|
-
await task.runTask();
|
|
113
|
-
const processedReqs = task.processUnsent.mock.calls[0][0];
|
|
114
|
-
expect(processedReqs.map((r) => r.txid)).toEqual(['tx1', 'tx2']);
|
|
115
|
-
expect(task.triggerNextMsecs).toBe(10);
|
|
116
|
-
});
|
|
117
|
-
test('0b switches to quick trigger cadence after consuming a full waiting chunk', async () => {
|
|
118
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
119
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
120
|
-
const reqs = Array.from({ length: 5 }, (_, i) => makeReq(i + 1, `tx${i + 1}`, new Date('2026-01-01T11:59:40.000Z')));
|
|
121
|
-
const m = makeMonitor(reqs);
|
|
122
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 5);
|
|
123
|
-
jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
124
|
-
await task.runTask();
|
|
125
|
-
expect(task.processUnsent).toHaveBeenCalledTimes(1);
|
|
126
|
-
expect(task.triggerNextMsecs).toBe(10);
|
|
127
|
-
});
|
|
128
|
-
test('1 falls back to normal trigger cadence when there is no waiting work', async () => {
|
|
129
|
-
const now = new Date('2026-01-01T12:00:00.000Z');
|
|
130
|
-
jest.spyOn(Date, 'now').mockReturnValue(now.getTime());
|
|
131
|
-
const m = makeMonitor([]);
|
|
132
|
-
const task = new TaskSendWaiting_1.TaskSendWaiting(m.monitor, 80, 7000, 300000, 10, 5);
|
|
133
|
-
const processSpy = jest.spyOn(task, 'processUnsent').mockResolvedValue('');
|
|
134
|
-
await task.runTask();
|
|
135
|
-
expect(processSpy).not.toHaveBeenCalled();
|
|
136
|
-
expect(task.triggerNextMsecs).toBe(80);
|
|
137
|
-
});
|
|
138
|
-
});
|
|
139
|
-
//# sourceMappingURL=TaskSendWaiting.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TaskSendWaiting.test.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/__tests/TaskSendWaiting.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CertificateLifeCycle.test.d.ts","sourceRoot":"","sources":["../../../../src/sdk/__test/CertificateLifeCycle.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const sdk_1 = require("@bsv/sdk");
|
|
4
|
-
describe('CertificateLifeCycle tests', () => {
|
|
5
|
-
jest.setTimeout(99999999);
|
|
6
|
-
test('2a complete flow MasterCertificate and VerifiableCertificate', async () => {
|
|
7
|
-
// Issuer beging with an un-encrypted (decrypted) raw certificate template:
|
|
8
|
-
// The public keys of both the certifier (the authority issuing the certificate),
|
|
9
|
-
// and the subject (who the certificate pertains to) are included in the certificate.
|
|
10
|
-
const { cert: wcert, certifier, subject } = makeSampleCert('1'.repeat(64), '2'.repeat(64), '3'.repeat(64));
|
|
11
|
-
const cert = new sdk_1.Certificate(wcert.type, wcert.serialNumber, wcert.subject, wcert.certifier, wcert.revocationOutpoint, wcert.fields);
|
|
12
|
-
// Next the certifier must encrypt the field values for privacy and sign the certificate
|
|
13
|
-
// such that the values it contains can be attributed to the certifier through its public key.
|
|
14
|
-
// Encryption is done with random symmetric keys and the keys are then encrypted by the certifier
|
|
15
|
-
// such that each key can also be decrypted by the subject:
|
|
16
|
-
const certifierWallet = new sdk_1.ProtoWallet(certifier);
|
|
17
|
-
// encrypt the fields as the certifier for the subject
|
|
18
|
-
const r1 = await sdk_1.MasterCertificate.createCertificateFields(certifierWallet, subject.toPublicKey().toString(), cert.fields);
|
|
19
|
-
// sign the certificate with encrypted fields as the certifier
|
|
20
|
-
const signedCert = new sdk_1.Certificate(wcert.type, wcert.serialNumber, wcert.subject, wcert.certifier, wcert.revocationOutpoint, r1.certificateFields);
|
|
21
|
-
await signedCert.sign(certifierWallet);
|
|
22
|
-
// The subject imports their copy of the new certificate:
|
|
23
|
-
const subjectWallet = new sdk_1.ProtoWallet(subject);
|
|
24
|
-
// The subject's imported certificate should verify
|
|
25
|
-
expect(await signedCert.verify()).toBe(true);
|
|
26
|
-
// Confirm subject can decrypt the certifier's copy of the cert:
|
|
27
|
-
const r2 = await sdk_1.MasterCertificate.decryptFields(subjectWallet, r1.masterKeyring, signedCert.fields, signedCert.certifier);
|
|
28
|
-
// Prepare to send certificate to third party veifier of the 'name' and 'email' fields.
|
|
29
|
-
// The verifier must be able to confirm the signature on the original certificate's encrypted values.
|
|
30
|
-
// And then use a keyRing that their public key will work to reveal decrypted values for 'name' and 'email' only.
|
|
31
|
-
const verifier = sdk_1.PrivateKey.fromRandom();
|
|
32
|
-
// subject makes a keyring for the verifier
|
|
33
|
-
const r3 = await sdk_1.MasterCertificate.createKeyringForVerifier(subjectWallet, certifier.toPublicKey().toString(), verifier.toPublicKey().toString(), signedCert.fields, ['name', 'email'], r1.masterKeyring, signedCert.serialNumber);
|
|
34
|
-
// The verifier uses their own wallet to import the certificate, verify it, and decrypt their designated fields.
|
|
35
|
-
const verifierWallet = new sdk_1.ProtoWallet(verifier);
|
|
36
|
-
const veriCert = new sdk_1.VerifiableCertificate(signedCert.type, signedCert.serialNumber, signedCert.subject, signedCert.certifier, signedCert.revocationOutpoint, signedCert.fields, r3, signedCert.signature);
|
|
37
|
-
const r4 = await veriCert.decryptFields(verifierWallet);
|
|
38
|
-
expect(r4.name).toBe('Alice');
|
|
39
|
-
expect(r4.email).toBe('alice@example.com');
|
|
40
|
-
expect(r4.organization).not.toBe('Example Corp');
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
function makeSampleCert(subjectRootKeyHex, certifierKeyHex, verifierKeyHex) {
|
|
44
|
-
const subject = subjectRootKeyHex ? sdk_1.PrivateKey.fromString(subjectRootKeyHex) : sdk_1.PrivateKey.fromRandom();
|
|
45
|
-
const certifier = certifierKeyHex ? sdk_1.PrivateKey.fromString(certifierKeyHex) : sdk_1.PrivateKey.fromRandom();
|
|
46
|
-
const verifier = verifierKeyHex ? sdk_1.PrivateKey.fromString(verifierKeyHex) : sdk_1.PrivateKey.fromRandom();
|
|
47
|
-
const cert = {
|
|
48
|
-
type: sdk_1.Utils.toBase64(new Array(32).fill(1)),
|
|
49
|
-
serialNumber: sdk_1.Utils.toBase64(new Array(32).fill(2)),
|
|
50
|
-
revocationOutpoint: 'deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef.1',
|
|
51
|
-
subject: subject.toPublicKey().toString(),
|
|
52
|
-
certifier: certifier.toPublicKey().toString(),
|
|
53
|
-
fields: {
|
|
54
|
-
name: 'Alice',
|
|
55
|
-
email: 'alice@example.com',
|
|
56
|
-
organization: 'Example Corp'
|
|
57
|
-
},
|
|
58
|
-
signature: ''
|
|
59
|
-
};
|
|
60
|
-
return { cert, subject, certifier };
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=CertificateLifeCycle.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CertificateLifeCycle.test.js","sourceRoot":"","sources":["../../../../src/sdk/__test/CertificateLifeCycle.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PrivilegedKeyManager.test.d.ts","sourceRoot":"","sources":["../../../../src/sdk/__test/PrivilegedKeyManager.test.ts"],"names":[],"mappings":""}
|