@bsv/wallet-toolbox-client 1.1.0
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/out/src/Wallet.d.ts +83 -0
- package/out/src/Wallet.d.ts.map +1 -0
- package/out/src/Wallet.js +415 -0
- package/out/src/Wallet.js.map +1 -0
- package/out/src/index.client.d.ts +8 -0
- package/out/src/index.client.d.ts.map +1 -0
- package/out/src/index.client.js +47 -0
- package/out/src/index.client.js.map +1 -0
- package/out/src/monitor/Monitor.d.ts +89 -0
- package/out/src/monitor/Monitor.d.ts.map +1 -0
- package/out/src/monitor/Monitor.js +253 -0
- package/out/src/monitor/Monitor.js.map +1 -0
- package/out/src/monitor/tasks/TaskCheckForProofs.d.ts +53 -0
- package/out/src/monitor/tasks/TaskCheckForProofs.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskCheckForProofs.js +197 -0
- package/out/src/monitor/tasks/TaskCheckForProofs.js.map +1 -0
- package/out/src/monitor/tasks/TaskClock.d.ts +14 -0
- package/out/src/monitor/tasks/TaskClock.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskClock.js +27 -0
- package/out/src/monitor/tasks/TaskClock.js.map +1 -0
- package/out/src/monitor/tasks/TaskFailAbandoned.d.ts +20 -0
- package/out/src/monitor/tasks/TaskFailAbandoned.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskFailAbandoned.js +52 -0
- package/out/src/monitor/tasks/TaskFailAbandoned.js.map +1 -0
- package/out/src/monitor/tasks/TaskNewHeader.d.ts +15 -0
- package/out/src/monitor/tasks/TaskNewHeader.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskNewHeader.js +45 -0
- package/out/src/monitor/tasks/TaskNewHeader.js.map +1 -0
- package/out/src/monitor/tasks/TaskPurge.d.ts +45 -0
- package/out/src/monitor/tasks/TaskPurge.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskPurge.js +35 -0
- package/out/src/monitor/tasks/TaskPurge.js.map +1 -0
- package/out/src/monitor/tasks/TaskReviewStatus.d.ts +26 -0
- package/out/src/monitor/tasks/TaskReviewStatus.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskReviewStatus.js +44 -0
- package/out/src/monitor/tasks/TaskReviewStatus.js.map +1 -0
- package/out/src/monitor/tasks/TaskSendWaiting.d.ts +32 -0
- package/out/src/monitor/tasks/TaskSendWaiting.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskSendWaiting.js +99 -0
- package/out/src/monitor/tasks/TaskSendWaiting.js.map +1 -0
- package/out/src/monitor/tasks/TaskSyncWhenIdle.d.ts +12 -0
- package/out/src/monitor/tasks/TaskSyncWhenIdle.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskSyncWhenIdle.js +22 -0
- package/out/src/monitor/tasks/TaskSyncWhenIdle.js.map +1 -0
- package/out/src/monitor/tasks/WalletMonitorTask.d.ts +40 -0
- package/out/src/monitor/tasks/WalletMonitorTask.d.ts.map +1 -0
- package/out/src/monitor/tasks/WalletMonitorTask.js +37 -0
- package/out/src/monitor/tasks/WalletMonitorTask.js.map +1 -0
- package/out/src/sdk/CertOps.d.ts +66 -0
- package/out/src/sdk/CertOps.d.ts.map +1 -0
- package/out/src/sdk/CertOps.js +198 -0
- package/out/src/sdk/CertOps.js.map +1 -0
- package/out/src/sdk/PrivilegedKeyManager.d.ts +125 -0
- package/out/src/sdk/PrivilegedKeyManager.d.ts.map +1 -0
- package/out/src/sdk/PrivilegedKeyManager.js +293 -0
- package/out/src/sdk/PrivilegedKeyManager.js.map +1 -0
- package/out/src/sdk/StorageSyncReader.d.ts +121 -0
- package/out/src/sdk/StorageSyncReader.d.ts.map +1 -0
- package/out/src/sdk/StorageSyncReader.js +3 -0
- package/out/src/sdk/StorageSyncReader.js.map +1 -0
- package/out/src/sdk/StorageSyncReaderWriter.d.ts +89 -0
- package/out/src/sdk/StorageSyncReaderWriter.d.ts.map +1 -0
- package/out/src/sdk/StorageSyncReaderWriter.js +3 -0
- package/out/src/sdk/StorageSyncReaderWriter.js.map +1 -0
- package/out/src/sdk/WERR_errors.d.ts +90 -0
- package/out/src/sdk/WERR_errors.d.ts.map +1 -0
- package/out/src/sdk/WERR_errors.js +128 -0
- package/out/src/sdk/WERR_errors.js.map +1 -0
- package/out/src/sdk/WalletError.d.ts +45 -0
- package/out/src/sdk/WalletError.d.ts.map +1 -0
- package/out/src/sdk/WalletError.js +122 -0
- package/out/src/sdk/WalletError.js.map +1 -0
- package/out/src/sdk/WalletServices.interfaces.d.ts +325 -0
- package/out/src/sdk/WalletServices.interfaces.d.ts.map +1 -0
- package/out/src/sdk/WalletServices.interfaces.js +3 -0
- package/out/src/sdk/WalletServices.interfaces.js.map +1 -0
- package/out/src/sdk/WalletSigner.interfaces.d.ts +10 -0
- package/out/src/sdk/WalletSigner.interfaces.d.ts.map +1 -0
- package/out/src/sdk/WalletSigner.interfaces.js +3 -0
- package/out/src/sdk/WalletSigner.interfaces.js.map +1 -0
- package/out/src/sdk/WalletStorage.interfaces.d.ts +299 -0
- package/out/src/sdk/WalletStorage.interfaces.d.ts.map +1 -0
- package/out/src/sdk/WalletStorage.interfaces.js +3 -0
- package/out/src/sdk/WalletStorage.interfaces.js.map +1 -0
- package/out/src/sdk/index.d.ts +12 -0
- package/out/src/sdk/index.d.ts.map +1 -0
- package/out/src/sdk/index.js +28 -0
- package/out/src/sdk/index.js.map +1 -0
- package/out/src/sdk/types.d.ts +74 -0
- package/out/src/sdk/types.d.ts.map +1 -0
- package/out/src/sdk/types.js +20 -0
- package/out/src/sdk/types.js.map +1 -0
- package/out/src/sdk/validationHelpers.d.ts +288 -0
- package/out/src/sdk/validationHelpers.d.ts.map +1 -0
- package/out/src/sdk/validationHelpers.js +630 -0
- package/out/src/sdk/validationHelpers.js.map +1 -0
- package/out/src/services/ServiceCollection.d.ts +25 -0
- package/out/src/services/ServiceCollection.d.ts.map +1 -0
- package/out/src/services/ServiceCollection.js +43 -0
- package/out/src/services/ServiceCollection.js.map +1 -0
- package/out/src/services/Services.d.ts +60 -0
- package/out/src/services/Services.d.ts.map +1 -0
- package/out/src/services/Services.js +342 -0
- package/out/src/services/Services.js.map +1 -0
- package/out/src/services/chaintracker/ChaintracksChainTracker.d.ts +15 -0
- package/out/src/services/chaintracker/ChaintracksChainTracker.d.ts.map +1 -0
- package/out/src/services/chaintracker/ChaintracksChainTracker.js +51 -0
- package/out/src/services/chaintracker/ChaintracksChainTracker.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts +98 -0
- package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js +38 -0
- package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts +36 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js +130 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.d.ts +3 -0
- package/out/src/services/chaintracker/chaintracks/index.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.js +19 -0
- package/out/src/services/chaintracker/chaintracks/index.js.map +1 -0
- package/out/src/services/chaintracker/index.d.ts +3 -0
- package/out/src/services/chaintracker/index.d.ts.map +1 -0
- package/out/src/services/chaintracker/index.js +19 -0
- package/out/src/services/chaintracker/index.js.map +1 -0
- package/out/src/services/createDefaultWalletServicesOptions.d.ts +3 -0
- package/out/src/services/createDefaultWalletServicesOptions.d.ts.map +1 -0
- package/out/src/services/createDefaultWalletServicesOptions.js +34 -0
- package/out/src/services/createDefaultWalletServicesOptions.js.map +1 -0
- package/out/src/services/providers/arcServices.d.ts +62 -0
- package/out/src/services/providers/arcServices.d.ts.map +1 -0
- package/out/src/services/providers/arcServices.js +368 -0
- package/out/src/services/providers/arcServices.js.map +1 -0
- package/out/src/services/providers/echangeRates.d.ts +12 -0
- package/out/src/services/providers/echangeRates.d.ts.map +1 -0
- package/out/src/services/providers/echangeRates.js +237 -0
- package/out/src/services/providers/echangeRates.js.map +1 -0
- package/out/src/services/providers/whatsonchain.d.ts +17 -0
- package/out/src/services/providers/whatsonchain.d.ts.map +1 -0
- package/out/src/services/providers/whatsonchain.js +130 -0
- package/out/src/services/providers/whatsonchain.js.map +1 -0
- package/out/src/signer/WalletSigner.d.ts +11 -0
- package/out/src/signer/WalletSigner.d.ts.map +1 -0
- package/out/src/signer/WalletSigner.js +13 -0
- package/out/src/signer/WalletSigner.js.map +1 -0
- package/out/src/signer/methods/acquireDirectCertificate.d.ts +4 -0
- package/out/src/signer/methods/acquireDirectCertificate.d.ts.map +1 -0
- package/out/src/signer/methods/acquireDirectCertificate.js +47 -0
- package/out/src/signer/methods/acquireDirectCertificate.js.map +1 -0
- package/out/src/signer/methods/createAction.d.ts +7 -0
- package/out/src/signer/methods/createAction.d.ts.map +1 -0
- package/out/src/signer/methods/createAction.js +250 -0
- package/out/src/signer/methods/createAction.js.map +1 -0
- package/out/src/signer/methods/internalizeAction.d.ts +31 -0
- package/out/src/signer/methods/internalizeAction.d.ts.map +1 -0
- package/out/src/signer/methods/internalizeAction.js +95 -0
- package/out/src/signer/methods/internalizeAction.js.map +1 -0
- package/out/src/signer/methods/proveCertificate.d.ts +4 -0
- package/out/src/signer/methods/proveCertificate.d.ts.map +1 -0
- package/out/src/signer/methods/proveCertificate.js +45 -0
- package/out/src/signer/methods/proveCertificate.js.map +1 -0
- package/out/src/signer/methods/signAction.d.ts +6 -0
- package/out/src/signer/methods/signAction.d.ts.map +1 -0
- package/out/src/signer/methods/signAction.js +79 -0
- package/out/src/signer/methods/signAction.js.map +1 -0
- package/out/src/storage/StorageProvider.d.ts +140 -0
- package/out/src/storage/StorageProvider.d.ts.map +1 -0
- package/out/src/storage/StorageProvider.js +539 -0
- package/out/src/storage/StorageProvider.js.map +1 -0
- package/out/src/storage/StorageReader.d.ts +76 -0
- package/out/src/storage/StorageReader.d.ts.map +1 -0
- package/out/src/storage/StorageReader.js +124 -0
- package/out/src/storage/StorageReader.js.map +1 -0
- package/out/src/storage/StorageReaderWriter.d.ts +87 -0
- package/out/src/storage/StorageReaderWriter.d.ts.map +1 -0
- package/out/src/storage/StorageReaderWriter.js +337 -0
- package/out/src/storage/StorageReaderWriter.js.map +1 -0
- package/out/src/storage/StorageSyncReader.d.ts +33 -0
- package/out/src/storage/StorageSyncReader.d.ts.map +1 -0
- package/out/src/storage/StorageSyncReader.js +142 -0
- package/out/src/storage/StorageSyncReader.js.map +1 -0
- package/out/src/storage/WalletStorageManager.d.ts +103 -0
- package/out/src/storage/WalletStorageManager.d.ts.map +1 -0
- package/out/src/storage/WalletStorageManager.js +408 -0
- package/out/src/storage/WalletStorageManager.js.map +1 -0
- package/out/src/storage/index.client.d.ts +7 -0
- package/out/src/storage/index.client.d.ts.map +1 -0
- package/out/src/storage/index.client.js +46 -0
- package/out/src/storage/index.client.js.map +1 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts +27 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts.map +1 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js +148 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js.map +1 -0
- package/out/src/storage/methods/createAction.d.ts +23 -0
- package/out/src/storage/methods/createAction.d.ts.map +1 -0
- package/out/src/storage/methods/createAction.js +663 -0
- package/out/src/storage/methods/createAction.js.map +1 -0
- package/out/src/storage/methods/generateChange.d.ts +108 -0
- package/out/src/storage/methods/generateChange.d.ts.map +1 -0
- package/out/src/storage/methods/generateChange.js +422 -0
- package/out/src/storage/methods/generateChange.js.map +1 -0
- package/out/src/storage/methods/getBeefForTransaction.d.ts +22 -0
- package/out/src/storage/methods/getBeefForTransaction.d.ts.map +1 -0
- package/out/src/storage/methods/getBeefForTransaction.js +94 -0
- package/out/src/storage/methods/getBeefForTransaction.js.map +1 -0
- package/out/src/storage/methods/getSyncChunk.d.ts +10 -0
- package/out/src/storage/methods/getSyncChunk.d.ts.map +1 -0
- package/out/src/storage/methods/getSyncChunk.js +271 -0
- package/out/src/storage/methods/getSyncChunk.js.map +1 -0
- package/out/src/storage/methods/internalizeAction.d.ts +38 -0
- package/out/src/storage/methods/internalizeAction.d.ts.map +1 -0
- package/out/src/storage/methods/internalizeAction.js +378 -0
- package/out/src/storage/methods/internalizeAction.js.map +1 -0
- package/out/src/storage/methods/listCertificates.d.ts +5 -0
- package/out/src/storage/methods/listCertificates.d.ts.map +1 -0
- package/out/src/storage/methods/listCertificates.js +68 -0
- package/out/src/storage/methods/listCertificates.js.map +1 -0
- package/out/src/storage/methods/processAction.d.ts +35 -0
- package/out/src/storage/methods/processAction.d.ts.map +1 -0
- package/out/src/storage/methods/processAction.js +271 -0
- package/out/src/storage/methods/processAction.js.map +1 -0
- package/out/src/storage/remoting/StorageClient.d.ts +56 -0
- package/out/src/storage/remoting/StorageClient.d.ts.map +1 -0
- package/out/src/storage/remoting/StorageClient.js +181 -0
- package/out/src/storage/remoting/StorageClient.js.map +1 -0
- package/out/src/storage/schema/entities/Certificate.d.ts +43 -0
- package/out/src/storage/schema/entities/Certificate.d.ts.map +1 -0
- package/out/src/storage/schema/entities/Certificate.js +162 -0
- package/out/src/storage/schema/entities/Certificate.js.map +1 -0
- package/out/src/storage/schema/entities/CertificateField.d.ts +32 -0
- package/out/src/storage/schema/entities/CertificateField.d.ts.map +1 -0
- package/out/src/storage/schema/entities/CertificateField.js +114 -0
- package/out/src/storage/schema/entities/CertificateField.js.map +1 -0
- package/out/src/storage/schema/entities/Commission.d.ts +37 -0
- package/out/src/storage/schema/entities/Commission.d.ts.map +1 -0
- package/out/src/storage/schema/entities/Commission.js +130 -0
- package/out/src/storage/schema/entities/Commission.js.map +1 -0
- package/out/src/storage/schema/entities/EntityBase.d.ts +105 -0
- package/out/src/storage/schema/entities/EntityBase.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityBase.js +100 -0
- package/out/src/storage/schema/entities/EntityBase.js.map +1 -0
- package/out/src/storage/schema/entities/MergeEntity.d.ts +34 -0
- package/out/src/storage/schema/entities/MergeEntity.d.ts.map +1 -0
- package/out/src/storage/schema/entities/MergeEntity.js +57 -0
- package/out/src/storage/schema/entities/MergeEntity.js.map +1 -0
- package/out/src/storage/schema/entities/Output.d.ts +67 -0
- package/out/src/storage/schema/entities/Output.d.ts.map +1 -0
- package/out/src/storage/schema/entities/Output.js +281 -0
- package/out/src/storage/schema/entities/Output.js.map +1 -0
- package/out/src/storage/schema/entities/OutputBasket.d.ts +35 -0
- package/out/src/storage/schema/entities/OutputBasket.d.ts.map +1 -0
- package/out/src/storage/schema/entities/OutputBasket.js +133 -0
- package/out/src/storage/schema/entities/OutputBasket.js.map +1 -0
- package/out/src/storage/schema/entities/OutputTag.d.ts +31 -0
- package/out/src/storage/schema/entities/OutputTag.d.ts.map +1 -0
- package/out/src/storage/schema/entities/OutputTag.js +104 -0
- package/out/src/storage/schema/entities/OutputTag.js.map +1 -0
- package/out/src/storage/schema/entities/OutputTagMap.d.ts +28 -0
- package/out/src/storage/schema/entities/OutputTagMap.d.ts.map +1 -0
- package/out/src/storage/schema/entities/OutputTagMap.js +101 -0
- package/out/src/storage/schema/entities/OutputTagMap.js.map +1 -0
- package/out/src/storage/schema/entities/ProvenTx.d.ts +84 -0
- package/out/src/storage/schema/entities/ProvenTx.d.ts.map +1 -0
- package/out/src/storage/schema/entities/ProvenTx.js +283 -0
- package/out/src/storage/schema/entities/ProvenTx.js.map +1 -0
- package/out/src/storage/schema/entities/ProvenTxReq.d.ts +130 -0
- package/out/src/storage/schema/entities/ProvenTxReq.d.ts.map +1 -0
- package/out/src/storage/schema/entities/ProvenTxReq.js +521 -0
- package/out/src/storage/schema/entities/ProvenTxReq.js.map +1 -0
- package/out/src/storage/schema/entities/SyncState.d.ts +66 -0
- package/out/src/storage/schema/entities/SyncState.d.ts.map +1 -0
- package/out/src/storage/schema/entities/SyncState.js +284 -0
- package/out/src/storage/schema/entities/SyncState.js.map +1 -0
- package/out/src/storage/schema/entities/Transaction.d.ts +67 -0
- package/out/src/storage/schema/entities/Transaction.d.ts.map +1 -0
- package/out/src/storage/schema/entities/Transaction.js +264 -0
- package/out/src/storage/schema/entities/Transaction.js.map +1 -0
- package/out/src/storage/schema/entities/TxLabel.d.ts +31 -0
- package/out/src/storage/schema/entities/TxLabel.d.ts.map +1 -0
- package/out/src/storage/schema/entities/TxLabel.js +104 -0
- package/out/src/storage/schema/entities/TxLabel.js.map +1 -0
- package/out/src/storage/schema/entities/TxLabelMap.d.ts +28 -0
- package/out/src/storage/schema/entities/TxLabelMap.d.ts.map +1 -0
- package/out/src/storage/schema/entities/TxLabelMap.js +103 -0
- package/out/src/storage/schema/entities/TxLabelMap.js.map +1 -0
- package/out/src/storage/schema/entities/User.d.ts +29 -0
- package/out/src/storage/schema/entities/User.d.ts.map +1 -0
- package/out/src/storage/schema/entities/User.js +100 -0
- package/out/src/storage/schema/entities/User.js.map +1 -0
- package/out/src/storage/schema/entities/index.d.ts +17 -0
- package/out/src/storage/schema/entities/index.d.ts.map +1 -0
- package/out/src/storage/schema/entities/index.js +33 -0
- package/out/src/storage/schema/entities/index.js.map +1 -0
- package/out/src/storage/schema/tables/Certificate.d.ts +20 -0
- package/out/src/storage/schema/tables/Certificate.d.ts.map +1 -0
- package/out/src/storage/schema/tables/Certificate.js +3 -0
- package/out/src/storage/schema/tables/Certificate.js.map +1 -0
- package/out/src/storage/schema/tables/CertificateField.d.ts +12 -0
- package/out/src/storage/schema/tables/CertificateField.d.ts.map +1 -0
- package/out/src/storage/schema/tables/CertificateField.js +3 -0
- package/out/src/storage/schema/tables/CertificateField.js.map +1 -0
- package/out/src/storage/schema/tables/Commission.d.ts +13 -0
- package/out/src/storage/schema/tables/Commission.d.ts.map +1 -0
- package/out/src/storage/schema/tables/Commission.js +3 -0
- package/out/src/storage/schema/tables/Commission.js.map +1 -0
- package/out/src/storage/schema/tables/MonitorEvent.d.ts +9 -0
- package/out/src/storage/schema/tables/MonitorEvent.d.ts.map +1 -0
- package/out/src/storage/schema/tables/MonitorEvent.js +3 -0
- package/out/src/storage/schema/tables/MonitorEvent.js.map +1 -0
- package/out/src/storage/schema/tables/Output.d.ts +36 -0
- package/out/src/storage/schema/tables/Output.d.ts.map +1 -0
- package/out/src/storage/schema/tables/Output.js +31 -0
- package/out/src/storage/schema/tables/Output.js.map +1 -0
- package/out/src/storage/schema/tables/OutputBasket.d.ts +12 -0
- package/out/src/storage/schema/tables/OutputBasket.d.ts.map +1 -0
- package/out/src/storage/schema/tables/OutputBasket.js +3 -0
- package/out/src/storage/schema/tables/OutputBasket.js.map +1 -0
- package/out/src/storage/schema/tables/OutputTag.d.ts +10 -0
- package/out/src/storage/schema/tables/OutputTag.d.ts.map +1 -0
- package/out/src/storage/schema/tables/OutputTag.js +3 -0
- package/out/src/storage/schema/tables/OutputTag.js.map +1 -0
- package/out/src/storage/schema/tables/OutputTagMap.d.ts +9 -0
- package/out/src/storage/schema/tables/OutputTagMap.d.ts.map +1 -0
- package/out/src/storage/schema/tables/OutputTagMap.js +3 -0
- package/out/src/storage/schema/tables/OutputTagMap.js.map +1 -0
- package/out/src/storage/schema/tables/ProvenTx.d.ts +14 -0
- package/out/src/storage/schema/tables/ProvenTx.d.ts.map +1 -0
- package/out/src/storage/schema/tables/ProvenTx.js +3 -0
- package/out/src/storage/schema/tables/ProvenTx.js.map +1 -0
- package/out/src/storage/schema/tables/ProvenTxReq.d.ts +64 -0
- package/out/src/storage/schema/tables/ProvenTxReq.d.ts.map +1 -0
- package/out/src/storage/schema/tables/ProvenTxReq.js +3 -0
- package/out/src/storage/schema/tables/ProvenTxReq.js.map +1 -0
- package/out/src/storage/schema/tables/Settings.d.ts +17 -0
- package/out/src/storage/schema/tables/Settings.d.ts.map +1 -0
- package/out/src/storage/schema/tables/Settings.js +3 -0
- package/out/src/storage/schema/tables/Settings.js.map +1 -0
- package/out/src/storage/schema/tables/SyncState.d.ts +18 -0
- package/out/src/storage/schema/tables/SyncState.d.ts.map +1 -0
- package/out/src/storage/schema/tables/SyncState.js +3 -0
- package/out/src/storage/schema/tables/SyncState.js.map +1 -0
- package/out/src/storage/schema/tables/Transaction.d.ts +37 -0
- package/out/src/storage/schema/tables/Transaction.d.ts.map +1 -0
- package/out/src/storage/schema/tables/Transaction.js +21 -0
- package/out/src/storage/schema/tables/Transaction.js.map +1 -0
- package/out/src/storage/schema/tables/TxLabel.d.ts +10 -0
- package/out/src/storage/schema/tables/TxLabel.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TxLabel.js +3 -0
- package/out/src/storage/schema/tables/TxLabel.js.map +1 -0
- package/out/src/storage/schema/tables/TxLabelMap.d.ts +9 -0
- package/out/src/storage/schema/tables/TxLabelMap.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TxLabelMap.js +3 -0
- package/out/src/storage/schema/tables/TxLabelMap.js.map +1 -0
- package/out/src/storage/schema/tables/User.d.ts +16 -0
- package/out/src/storage/schema/tables/User.d.ts.map +1 -0
- package/out/src/storage/schema/tables/User.js +3 -0
- package/out/src/storage/schema/tables/User.js.map +1 -0
- package/out/src/storage/schema/tables/index.d.ts +17 -0
- package/out/src/storage/schema/tables/index.d.ts.map +1 -0
- package/out/src/storage/schema/tables/index.js +33 -0
- package/out/src/storage/schema/tables/index.js.map +1 -0
- package/out/src/utility/ScriptTemplateSABPPP.d.ts +25 -0
- package/out/src/utility/ScriptTemplateSABPPP.d.ts.map +1 -0
- package/out/src/utility/ScriptTemplateSABPPP.js +46 -0
- package/out/src/utility/ScriptTemplateSABPPP.js.map +1 -0
- package/out/src/utility/index.client.d.ts +7 -0
- package/out/src/utility/index.client.d.ts.map +1 -0
- package/out/src/utility/index.client.js +23 -0
- package/out/src/utility/index.client.js.map +1 -0
- package/out/src/utility/parseTxScriptOffsets.d.ts +14 -0
- package/out/src/utility/parseTxScriptOffsets.d.ts.map +1 -0
- package/out/src/utility/parseTxScriptOffsets.js +26 -0
- package/out/src/utility/parseTxScriptOffsets.js.map +1 -0
- package/out/src/utility/stampLog.d.ts +18 -0
- package/out/src/utility/stampLog.d.ts.map +1 -0
- package/out/src/utility/stampLog.js +72 -0
- package/out/src/utility/stampLog.js.map +1 -0
- package/out/src/utility/tscProofToMerklePath.d.ts +8 -0
- package/out/src/utility/tscProofToMerklePath.d.ts.map +1 -0
- package/out/src/utility/tscProofToMerklePath.js +41 -0
- package/out/src/utility/tscProofToMerklePath.js.map +1 -0
- package/out/src/utility/utilityHelpers.d.ts +129 -0
- package/out/src/utility/utilityHelpers.d.ts.map +1 -0
- package/out/src/utility/utilityHelpers.js +268 -0
- package/out/src/utility/utilityHelpers.js.map +1 -0
- package/out/src/utility/utilityHelpers.noBuffer.d.ts +9 -0
- package/out/src/utility/utilityHelpers.noBuffer.d.ts.map +1 -0
- package/out/src/utility/utilityHelpers.noBuffer.js +23 -0
- package/out/src/utility/utilityHelpers.noBuffer.js.map +1 -0
- package/out/tsconfig.client.tsbuildinfo +1 -0
- package/package.json +27 -0
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { sdk, Services, WalletStorageManager } from '../index.client';
|
|
2
|
+
import { BlockHeader, ChaintracksServiceClient } from '../services/chaintracker';
|
|
3
|
+
import { TaskPurgeParams } from './tasks/TaskPurge';
|
|
4
|
+
import { WalletMonitorTask } from './tasks/WalletMonitorTask';
|
|
5
|
+
export type MonitorStorage = WalletStorageManager;
|
|
6
|
+
export interface MonitorOptions {
|
|
7
|
+
chain: sdk.Chain;
|
|
8
|
+
services: Services;
|
|
9
|
+
storage: MonitorStorage;
|
|
10
|
+
chaintracks: ChaintracksServiceClient;
|
|
11
|
+
/**
|
|
12
|
+
* How many msecs to wait after each getMerkleProof service request.
|
|
13
|
+
*/
|
|
14
|
+
msecsWaitPerMerkleProofServiceReq: number;
|
|
15
|
+
taskRunWaitMsecs: number;
|
|
16
|
+
abandonedMsecs: number;
|
|
17
|
+
unprovenAttemptsLimitTest: number;
|
|
18
|
+
unprovenAttemptsLimitMain: number;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Background task to make sure transactions are processed, transaction proofs are received and propagated,
|
|
22
|
+
* and potentially that reorgs update proofs that were already received.
|
|
23
|
+
*/
|
|
24
|
+
export declare class Monitor {
|
|
25
|
+
static createDefaultWalletMonitorOptions(chain: sdk.Chain, storage: MonitorStorage, services?: Services): MonitorOptions;
|
|
26
|
+
options: MonitorOptions;
|
|
27
|
+
services: Services;
|
|
28
|
+
chain: sdk.Chain;
|
|
29
|
+
storage: MonitorStorage;
|
|
30
|
+
chaintracks: ChaintracksServiceClient;
|
|
31
|
+
constructor(options: MonitorOptions);
|
|
32
|
+
oneSecond: number;
|
|
33
|
+
oneMinute: number;
|
|
34
|
+
oneHour: number;
|
|
35
|
+
oneDay: number;
|
|
36
|
+
oneWeek: number;
|
|
37
|
+
/**
|
|
38
|
+
* _tasks are typically run by the scheduler but may also be run by runTask.
|
|
39
|
+
*/
|
|
40
|
+
_tasks: WalletMonitorTask[];
|
|
41
|
+
/**
|
|
42
|
+
* _otherTasks can be run by runTask but not by scheduler.
|
|
43
|
+
*/
|
|
44
|
+
_otherTasks: WalletMonitorTask[];
|
|
45
|
+
_tasksRunning: boolean;
|
|
46
|
+
defaultPurgeParams: TaskPurgeParams;
|
|
47
|
+
addAllTasksToOther(): void;
|
|
48
|
+
/**
|
|
49
|
+
* Default tasks with settings appropriate for a single user storage
|
|
50
|
+
* possibly with sync'ing enabled
|
|
51
|
+
*/
|
|
52
|
+
addDefaultTasks(): void;
|
|
53
|
+
/**
|
|
54
|
+
* Tasks appropriate for multi-user storage
|
|
55
|
+
* without sync'ing enabled.
|
|
56
|
+
*/
|
|
57
|
+
addMultiUserTasks(): void;
|
|
58
|
+
addTask(task: WalletMonitorTask): void;
|
|
59
|
+
removeTask(name: string): void;
|
|
60
|
+
setupChaintracksListeners(): Promise<void>;
|
|
61
|
+
runTask(name: string): Promise<string>;
|
|
62
|
+
runOnce(): Promise<void>;
|
|
63
|
+
_runAsyncSetup: boolean;
|
|
64
|
+
startTasks(): Promise<void>;
|
|
65
|
+
logEvent(event: string, details?: string): Promise<void>;
|
|
66
|
+
stopTasks(): void;
|
|
67
|
+
lastNewHeader: BlockHeader | undefined;
|
|
68
|
+
lastNewHeaderWhen: Date | undefined;
|
|
69
|
+
/**
|
|
70
|
+
* Process new chain header event received from Chaintracks
|
|
71
|
+
*
|
|
72
|
+
* Kicks processing 'unconfirmed' and 'unmined' request processing.
|
|
73
|
+
*
|
|
74
|
+
* @param reqs
|
|
75
|
+
*/
|
|
76
|
+
processNewBlockHeader(header: BlockHeader): void;
|
|
77
|
+
/**
|
|
78
|
+
* Process reorg event received from Chaintracks
|
|
79
|
+
*
|
|
80
|
+
* Reorgs can move recent transactions to new blocks at new index positions.
|
|
81
|
+
* Affected transaction proofs become invalid and must be updated.
|
|
82
|
+
*
|
|
83
|
+
* It is possible for a transaction to become invalid.
|
|
84
|
+
*
|
|
85
|
+
* Coinbase transactions always become invalid.
|
|
86
|
+
*/
|
|
87
|
+
processReorg(depth: number, oldTip: BlockHeader, newTip: BlockHeader): void;
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=Monitor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Monitor.d.ts","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAQ,QAAQ,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAA;AAC3E,OAAO,EAAE,WAAW,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAA;AAChF,OAAO,EAAa,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAM9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AAI7D,MAAM,MAAM,cAAc,GAAG,oBAAoB,CAAA;AAIjD,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,GAAG,CAAC,KAAK,CAAA;IAEhB,QAAQ,EAAE,QAAQ,CAAA;IAElB,OAAO,EAAE,cAAc,CAAA;IAEvB,WAAW,EAAE,wBAAwB,CAAA;IAErC;;OAEG;IACH,iCAAiC,EAAE,MAAM,CAAA;IAEzC,gBAAgB,EAAE,MAAM,CAAA;IAExB,cAAc,EAAE,MAAM,CAAA;IAEtB,yBAAyB,EAAE,MAAM,CAAA;IAEjC,yBAAyB,EAAE,MAAM,CAAA;CAClC;AAED;;;GAGG;AACH,qBAAa,OAAO;IAClB,MAAM,CAAC,iCAAiC,CACtC,KAAK,EAAE,GAAG,CAAC,KAAK,EAChB,OAAO,EAAE,cAAc,EACvB,QAAQ,CAAC,EAAE,QAAQ,GAClB,cAAc;IAqBjB,OAAO,EAAE,cAAc,CAAA;IACvB,QAAQ,EAAE,QAAQ,CAAA;IAClB,KAAK,EAAE,GAAG,CAAC,KAAK,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,WAAW,EAAE,wBAAwB,CAAA;gBAEzB,OAAO,EAAE,cAAc;IAQnC,SAAS,SAAO;IAChB,SAAS,SAAsB;IAC/B,OAAO,SAAsB;IAC7B,MAAM,SAAoB;IAC1B,OAAO,SAAkB;IACzB;;OAEG;IACH,MAAM,EAAE,iBAAiB,EAAE,CAAK;IAChC;;OAEG;IACH,WAAW,EAAE,iBAAiB,EAAE,CAAK;IACrC,aAAa,UAAQ;IAErB,kBAAkB,EAAE,eAAe,CAOlC;IAED,kBAAkB,IAAI,IAAI;IAY1B;;;OAGG;IACH,eAAe,IAAI,IAAI;IAcvB;;;OAGG;IACH,iBAAiB,IAAI,IAAI;IAczB,OAAO,CAAC,IAAI,EAAE,iBAAiB,GAAG,IAAI;IAQtC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAIxB,yBAAyB,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ1C,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAWtC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAmD9B,cAAc,EAAE,OAAO,CAAO;IAExB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAa3B,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAY9D,SAAS,IAAI,IAAI;IAIjB,aAAa,EAAE,WAAW,GAAG,SAAS,CAAA;IACtC,iBAAiB,EAAE,IAAI,GAAG,SAAS,CAAA;IAEnC;;;;;;OAMG;IACH,qBAAqB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAShD;;;;;;;;;OASG;IAEH,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,GAAG,IAAI;CAG5E"}
|
|
@@ -0,0 +1,253 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Monitor = void 0;
|
|
4
|
+
const index_client_1 = require("../index.client");
|
|
5
|
+
const TaskPurge_1 = require("./tasks/TaskPurge");
|
|
6
|
+
const TaskReviewStatus_1 = require("./tasks/TaskReviewStatus");
|
|
7
|
+
const TaskSyncWhenIdle_1 = require("./tasks/TaskSyncWhenIdle");
|
|
8
|
+
const TaskFailAbandoned_1 = require("./tasks/TaskFailAbandoned");
|
|
9
|
+
const TaskCheckForProofs_1 = require("./tasks/TaskCheckForProofs");
|
|
10
|
+
const TaskSendWaiting_1 = require("./tasks/TaskSendWaiting");
|
|
11
|
+
const TaskClock_1 = require("./tasks/TaskClock");
|
|
12
|
+
const TaskNewHeader_1 = require("./tasks/TaskNewHeader");
|
|
13
|
+
/**
|
|
14
|
+
* Background task to make sure transactions are processed, transaction proofs are received and propagated,
|
|
15
|
+
* and potentially that reorgs update proofs that were already received.
|
|
16
|
+
*/
|
|
17
|
+
class Monitor {
|
|
18
|
+
static createDefaultWalletMonitorOptions(chain, storage, services) {
|
|
19
|
+
services || (services = new index_client_1.Services(chain));
|
|
20
|
+
if (!services.options.chaintracks)
|
|
21
|
+
throw new index_client_1.sdk.WERR_INVALID_PARAMETER('services.options.chaintracks', 'valid');
|
|
22
|
+
const o = {
|
|
23
|
+
chain,
|
|
24
|
+
services,
|
|
25
|
+
storage,
|
|
26
|
+
msecsWaitPerMerkleProofServiceReq: 500,
|
|
27
|
+
taskRunWaitMsecs: 5000,
|
|
28
|
+
abandonedMsecs: 1000 * 60 * 5,
|
|
29
|
+
unprovenAttemptsLimitTest: 10,
|
|
30
|
+
unprovenAttemptsLimitMain: 144,
|
|
31
|
+
chaintracks: services.options.chaintracks
|
|
32
|
+
};
|
|
33
|
+
return o;
|
|
34
|
+
}
|
|
35
|
+
constructor(options) {
|
|
36
|
+
this.oneSecond = 1000;
|
|
37
|
+
this.oneMinute = 60 * this.oneSecond;
|
|
38
|
+
this.oneHour = 60 * this.oneMinute;
|
|
39
|
+
this.oneDay = 24 * this.oneHour;
|
|
40
|
+
this.oneWeek = 7 * this.oneDay;
|
|
41
|
+
/**
|
|
42
|
+
* _tasks are typically run by the scheduler but may also be run by runTask.
|
|
43
|
+
*/
|
|
44
|
+
this._tasks = [];
|
|
45
|
+
/**
|
|
46
|
+
* _otherTasks can be run by runTask but not by scheduler.
|
|
47
|
+
*/
|
|
48
|
+
this._otherTasks = [];
|
|
49
|
+
this._tasksRunning = false;
|
|
50
|
+
this.defaultPurgeParams = {
|
|
51
|
+
purgeSpent: false,
|
|
52
|
+
purgeCompleted: false,
|
|
53
|
+
purgeFailed: true,
|
|
54
|
+
purgeSpentAge: 2 * this.oneWeek,
|
|
55
|
+
purgeCompletedAge: 2 * this.oneWeek,
|
|
56
|
+
purgeFailedAge: 5 * this.oneDay
|
|
57
|
+
};
|
|
58
|
+
this._runAsyncSetup = true;
|
|
59
|
+
this.options = { ...options };
|
|
60
|
+
this.services = options.services;
|
|
61
|
+
this.chain = this.services.chain;
|
|
62
|
+
this.storage = options.storage;
|
|
63
|
+
this.chaintracks = options.chaintracks;
|
|
64
|
+
}
|
|
65
|
+
addAllTasksToOther() {
|
|
66
|
+
this._otherTasks.push(new TaskClock_1.TaskClock(this));
|
|
67
|
+
this._otherTasks.push(new TaskNewHeader_1.TaskNewHeader(this));
|
|
68
|
+
this._otherTasks.push(new TaskPurge_1.TaskPurge(this, this.defaultPurgeParams));
|
|
69
|
+
this._otherTasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
70
|
+
this._otherTasks.push(new TaskSendWaiting_1.TaskSendWaiting(this));
|
|
71
|
+
this._otherTasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this));
|
|
72
|
+
this._otherTasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this));
|
|
73
|
+
this._otherTasks.push(new TaskSyncWhenIdle_1.TaskSyncWhenIdle(this));
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Default tasks with settings appropriate for a single user storage
|
|
77
|
+
* possibly with sync'ing enabled
|
|
78
|
+
*/
|
|
79
|
+
addDefaultTasks() {
|
|
80
|
+
this._tasks.push(new TaskClock_1.TaskClock(this));
|
|
81
|
+
this._tasks.push(new TaskNewHeader_1.TaskNewHeader(this));
|
|
82
|
+
this._tasks.push(new TaskSendWaiting_1.TaskSendWaiting(this, 8 * this.oneSecond, 7 * this.oneSecond)); // Check every 8 seconds but must be 7 seconds old
|
|
83
|
+
this._tasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this, 2 * this.oneHour)); // Every two hours if no block found
|
|
84
|
+
this._tasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this, 8 * this.oneMinute));
|
|
85
|
+
this._tasks.push(new TaskPurge_1.TaskPurge(this, this.defaultPurgeParams, 6 * this.oneHour));
|
|
86
|
+
this._tasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Tasks appropriate for multi-user storage
|
|
90
|
+
* without sync'ing enabled.
|
|
91
|
+
*/
|
|
92
|
+
addMultiUserTasks() {
|
|
93
|
+
this._tasks.push(new TaskClock_1.TaskClock(this));
|
|
94
|
+
this._tasks.push(new TaskNewHeader_1.TaskNewHeader(this));
|
|
95
|
+
this._tasks.push(new TaskSendWaiting_1.TaskSendWaiting(this, 8 * this.oneSecond, 7 * this.oneSecond)); // Check every 8 seconds but must be 7 seconds old
|
|
96
|
+
this._tasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this, 2 * this.oneHour)); // Every two hours if no block found
|
|
97
|
+
this._tasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this, 8 * this.oneMinute));
|
|
98
|
+
this._tasks.push(new TaskPurge_1.TaskPurge(this, this.defaultPurgeParams, 6 * this.oneHour));
|
|
99
|
+
this._tasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
100
|
+
}
|
|
101
|
+
addTask(task) {
|
|
102
|
+
if (this._tasks.some(t => t.name === task.name))
|
|
103
|
+
throw new index_client_1.sdk.WERR_BAD_REQUEST(`task ${task.name} has already been added.`);
|
|
104
|
+
this._tasks.push(task);
|
|
105
|
+
}
|
|
106
|
+
removeTask(name) {
|
|
107
|
+
this._tasks = this._tasks.filter(t => t.name !== name);
|
|
108
|
+
}
|
|
109
|
+
async setupChaintracksListeners() {
|
|
110
|
+
try {
|
|
111
|
+
// TODO: Use a task monitoring the newest block headere to trigger processNewHeader and reorg handling.
|
|
112
|
+
}
|
|
113
|
+
catch (err) {
|
|
114
|
+
/* this chaintracks doesn't support event subscriptions */
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async runTask(name) {
|
|
118
|
+
let task = this._tasks.find(t => t.name === name);
|
|
119
|
+
let log = '';
|
|
120
|
+
if (!task)
|
|
121
|
+
task = this._otherTasks.find(t => t.name === name);
|
|
122
|
+
if (task) {
|
|
123
|
+
await task.asyncSetup();
|
|
124
|
+
log = await task.runTask();
|
|
125
|
+
}
|
|
126
|
+
return log;
|
|
127
|
+
}
|
|
128
|
+
async runOnce() {
|
|
129
|
+
if (this._runAsyncSetup) {
|
|
130
|
+
for (const t of this._tasks) {
|
|
131
|
+
try {
|
|
132
|
+
await t.asyncSetup();
|
|
133
|
+
}
|
|
134
|
+
catch (eu) {
|
|
135
|
+
const e = index_client_1.sdk.WalletError.fromUnknown(eu);
|
|
136
|
+
const details = `monitor task ${t.name} asyncSetup error ${e.code} ${e.description}`;
|
|
137
|
+
console.log(details);
|
|
138
|
+
await this.logEvent('error0', details);
|
|
139
|
+
}
|
|
140
|
+
if (!this._tasksRunning)
|
|
141
|
+
break;
|
|
142
|
+
}
|
|
143
|
+
this._runAsyncSetup = false;
|
|
144
|
+
}
|
|
145
|
+
if (this.storage.getActive().isStorageProvider()) {
|
|
146
|
+
const tasksToRun = [];
|
|
147
|
+
const now = new Date().getTime();
|
|
148
|
+
for (const t of this._tasks) {
|
|
149
|
+
try {
|
|
150
|
+
if (t.trigger(now).run)
|
|
151
|
+
tasksToRun.push(t);
|
|
152
|
+
}
|
|
153
|
+
catch (eu) {
|
|
154
|
+
const e = index_client_1.sdk.WalletError.fromUnknown(eu);
|
|
155
|
+
const details = `monitor task ${t.name} trigger error ${e.code} ${e.description}`;
|
|
156
|
+
console.log(details);
|
|
157
|
+
await this.logEvent('error0', details);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
for (const ttr of tasksToRun) {
|
|
161
|
+
try {
|
|
162
|
+
if (this.storage.getActive().isStorageProvider()) {
|
|
163
|
+
const log = await ttr.runTask();
|
|
164
|
+
if (log && log.length > 0) {
|
|
165
|
+
console.log(`Task${ttr.name} ${log}`);
|
|
166
|
+
await this.logEvent(ttr.name, log);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
catch (eu) {
|
|
171
|
+
const e = index_client_1.sdk.WalletError.fromUnknown(eu);
|
|
172
|
+
const details = `monitor task ${ttr.name} runTask error ${e.code} ${e.description}\n${e.stack}`;
|
|
173
|
+
console.log(details);
|
|
174
|
+
await this.logEvent('error1', details);
|
|
175
|
+
}
|
|
176
|
+
finally {
|
|
177
|
+
ttr.lastRunMsecsSinceEpoch = new Date().getTime();
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
async startTasks() {
|
|
183
|
+
if (this._tasksRunning)
|
|
184
|
+
throw new index_client_1.sdk.WERR_BAD_REQUEST('monitor tasks are already runnining.');
|
|
185
|
+
this._tasksRunning = true;
|
|
186
|
+
for (; this._tasksRunning;) {
|
|
187
|
+
await this.runOnce();
|
|
188
|
+
// console.log(`${new Date().toISOString()} tasks run, waiting...`)
|
|
189
|
+
await (0, index_client_1.wait)(this.options.taskRunWaitMsecs);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
async logEvent(event, details) {
|
|
193
|
+
await this.storage.runAsStorageProvider(async (sp) => {
|
|
194
|
+
await sp.insertMonitorEvent({
|
|
195
|
+
created_at: new Date(),
|
|
196
|
+
updated_at: new Date(),
|
|
197
|
+
id: 0,
|
|
198
|
+
event,
|
|
199
|
+
details
|
|
200
|
+
});
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
stopTasks() {
|
|
204
|
+
this._tasksRunning = false;
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Process new chain header event received from Chaintracks
|
|
208
|
+
*
|
|
209
|
+
* Kicks processing 'unconfirmed' and 'unmined' request processing.
|
|
210
|
+
*
|
|
211
|
+
* @param reqs
|
|
212
|
+
*/
|
|
213
|
+
processNewBlockHeader(header) {
|
|
214
|
+
const h = header;
|
|
215
|
+
this.lastNewHeader = h;
|
|
216
|
+
this.lastNewHeaderWhen = new Date();
|
|
217
|
+
console.log(`WalletMonitor notified of new block header ${h.height}`);
|
|
218
|
+
// Nudge the proof checker to try again.
|
|
219
|
+
TaskCheckForProofs_1.TaskCheckForProofs.checkNow = true;
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Process reorg event received from Chaintracks
|
|
223
|
+
*
|
|
224
|
+
* Reorgs can move recent transactions to new blocks at new index positions.
|
|
225
|
+
* Affected transaction proofs become invalid and must be updated.
|
|
226
|
+
*
|
|
227
|
+
* It is possible for a transaction to become invalid.
|
|
228
|
+
*
|
|
229
|
+
* Coinbase transactions always become invalid.
|
|
230
|
+
*/
|
|
231
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
232
|
+
processReorg(depth, oldTip, newTip) {
|
|
233
|
+
/* */
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
exports.Monitor = Monitor;
|
|
237
|
+
function sum(a, getNum) {
|
|
238
|
+
let s = 0;
|
|
239
|
+
for (const v of a)
|
|
240
|
+
s += getNum(v);
|
|
241
|
+
return s;
|
|
242
|
+
}
|
|
243
|
+
function filter(a, pred) {
|
|
244
|
+
const ts = [];
|
|
245
|
+
const fs = [];
|
|
246
|
+
for (const v of a)
|
|
247
|
+
if (pred(v))
|
|
248
|
+
ts.push(v);
|
|
249
|
+
else
|
|
250
|
+
fs.push(v);
|
|
251
|
+
return { ts, fs };
|
|
252
|
+
}
|
|
253
|
+
//# sourceMappingURL=Monitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Monitor.js","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { table } from '../../index.client';
|
|
2
|
+
import { Monitor } from '../Monitor';
|
|
3
|
+
import { WalletMonitorTask } from './WalletMonitorTask';
|
|
4
|
+
/**
|
|
5
|
+
* `TaskCheckForProofs` is a WalletMonitor task that retreives merkle proofs for
|
|
6
|
+
* transactions.
|
|
7
|
+
*
|
|
8
|
+
* It is normally triggered by the Chaintracks new block header event.
|
|
9
|
+
*
|
|
10
|
+
* When a new block is found, cwi-external-services are used to obtain proofs for
|
|
11
|
+
* any transactions that are currently in the 'unmined' or 'unknown' state.
|
|
12
|
+
*
|
|
13
|
+
* If a proof is obtained and validated, a new ProvenTx record is created and
|
|
14
|
+
* the original ProvenTxReq status is advanced to 'notifying'.
|
|
15
|
+
*/
|
|
16
|
+
export declare class TaskCheckForProofs extends WalletMonitorTask {
|
|
17
|
+
triggerMsecs: number;
|
|
18
|
+
static taskName: string;
|
|
19
|
+
/**
|
|
20
|
+
* An external service such as the chaintracks new block header
|
|
21
|
+
* listener can set this true to cause
|
|
22
|
+
*/
|
|
23
|
+
static checkNow: boolean;
|
|
24
|
+
constructor(monitor: Monitor, triggerMsecs?: number);
|
|
25
|
+
/**
|
|
26
|
+
* Normally triggered by checkNow getting set by new block header found event from chaintracks
|
|
27
|
+
*/
|
|
28
|
+
trigger(nowMsecsSinceEpoch: number): {
|
|
29
|
+
run: boolean;
|
|
30
|
+
};
|
|
31
|
+
runTask(): Promise<string>;
|
|
32
|
+
/**
|
|
33
|
+
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
34
|
+
*
|
|
35
|
+
* If req is invalid, set status 'invalid'
|
|
36
|
+
*
|
|
37
|
+
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
38
|
+
*
|
|
39
|
+
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
40
|
+
* depending on chaintracks succeeding on proof verification.
|
|
41
|
+
*
|
|
42
|
+
* Increments attempts if proofs where requested.
|
|
43
|
+
*
|
|
44
|
+
* @param reqs
|
|
45
|
+
* @returns reqs partitioned by status
|
|
46
|
+
*/
|
|
47
|
+
getProofs(reqs: table.ProvenTxReq[], indent?: number, countsAsAttempt?: boolean, ignoreStatus?: boolean): Promise<{
|
|
48
|
+
proven: table.ProvenTxReq[];
|
|
49
|
+
invalid: table.ProvenTxReq[];
|
|
50
|
+
log: string;
|
|
51
|
+
}>;
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=TaskCheckForProofs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskCheckForProofs.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":"AAAA,OAAO,EAKL,KAAK,EACN,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD;;;;;;;;;;;GAWG;AAEH,qBAAa,kBAAmB,SAAQ,iBAAiB;IAW9C,YAAY;IAVrB,MAAM,CAAC,QAAQ,SAAmB;IAElC;;;OAGG;IACH,MAAM,CAAC,QAAQ,UAAQ;gBAGrB,OAAO,EAAE,OAAO,EACT,YAAY,SAAI;IAKzB;;OAEG;IACH,OAAO,CAAC,kBAAkB,EAAE,MAAM,GAAG;QAAE,GAAG,EAAE,OAAO,CAAA;KAAE;IAS/C,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;IA+BhC;;;;;;;;;;;;;;OAcG;IACG,SAAS,CACb,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,EACzB,MAAM,SAAI,EACV,eAAe,UAAQ,EACvB,YAAY,UAAQ,GACnB,OAAO,CAAC;QACT,MAAM,EAAE,KAAK,CAAC,WAAW,EAAE,CAAA;QAC3B,OAAO,EAAE,KAAK,CAAC,WAAW,EAAE,CAAA;QAC5B,GAAG,EAAE,MAAM,CAAA;KACZ,CAAC;CAgIH"}
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TaskCheckForProofs = void 0;
|
|
4
|
+
const index_client_1 = require("../../index.client");
|
|
5
|
+
const WalletMonitorTask_1 = require("./WalletMonitorTask");
|
|
6
|
+
/**
|
|
7
|
+
* `TaskCheckForProofs` is a WalletMonitor task that retreives merkle proofs for
|
|
8
|
+
* transactions.
|
|
9
|
+
*
|
|
10
|
+
* It is normally triggered by the Chaintracks new block header event.
|
|
11
|
+
*
|
|
12
|
+
* When a new block is found, cwi-external-services are used to obtain proofs for
|
|
13
|
+
* any transactions that are currently in the 'unmined' or 'unknown' state.
|
|
14
|
+
*
|
|
15
|
+
* If a proof is obtained and validated, a new ProvenTx record is created and
|
|
16
|
+
* the original ProvenTxReq status is advanced to 'notifying'.
|
|
17
|
+
*/
|
|
18
|
+
class TaskCheckForProofs extends WalletMonitorTask_1.WalletMonitorTask {
|
|
19
|
+
constructor(monitor, triggerMsecs = 0) {
|
|
20
|
+
super(monitor, TaskCheckForProofs.taskName);
|
|
21
|
+
this.triggerMsecs = triggerMsecs;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Normally triggered by checkNow getting set by new block header found event from chaintracks
|
|
25
|
+
*/
|
|
26
|
+
trigger(nowMsecsSinceEpoch) {
|
|
27
|
+
return {
|
|
28
|
+
run: TaskCheckForProofs.checkNow ||
|
|
29
|
+
(this.triggerMsecs > 0 &&
|
|
30
|
+
nowMsecsSinceEpoch - this.lastRunMsecsSinceEpoch > this.triggerMsecs)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
async runTask() {
|
|
34
|
+
let log = '';
|
|
35
|
+
const countsAsAttempt = TaskCheckForProofs.checkNow;
|
|
36
|
+
TaskCheckForProofs.checkNow = false;
|
|
37
|
+
const limit = 100;
|
|
38
|
+
let offset = 0;
|
|
39
|
+
for (;;) {
|
|
40
|
+
const reqs = await this.storage.findProvenTxReqs({
|
|
41
|
+
partial: {},
|
|
42
|
+
status: [
|
|
43
|
+
'callback',
|
|
44
|
+
'unmined',
|
|
45
|
+
'nosend',
|
|
46
|
+
'sending',
|
|
47
|
+
'unknown',
|
|
48
|
+
'unconfirmed'
|
|
49
|
+
],
|
|
50
|
+
paged: { limit, offset }
|
|
51
|
+
});
|
|
52
|
+
if (reqs.length === 0)
|
|
53
|
+
break;
|
|
54
|
+
log += `${reqs.length} reqs with status 'callback', 'unmined', 'nosend', 'sending', 'unknown', or 'unconfirmed'\n`;
|
|
55
|
+
const r = await this.getProofs(reqs, 2, countsAsAttempt);
|
|
56
|
+
log += `${r.log}\n`;
|
|
57
|
+
//console.log(log);
|
|
58
|
+
if (reqs.length < limit)
|
|
59
|
+
break;
|
|
60
|
+
offset += limit;
|
|
61
|
+
}
|
|
62
|
+
return log;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
66
|
+
*
|
|
67
|
+
* If req is invalid, set status 'invalid'
|
|
68
|
+
*
|
|
69
|
+
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
70
|
+
*
|
|
71
|
+
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
72
|
+
* depending on chaintracks succeeding on proof verification.
|
|
73
|
+
*
|
|
74
|
+
* Increments attempts if proofs where requested.
|
|
75
|
+
*
|
|
76
|
+
* @param reqs
|
|
77
|
+
* @returns reqs partitioned by status
|
|
78
|
+
*/
|
|
79
|
+
async getProofs(reqs, indent = 0, countsAsAttempt = false, ignoreStatus = false) {
|
|
80
|
+
const proven = [];
|
|
81
|
+
const invalid = [];
|
|
82
|
+
let log = '';
|
|
83
|
+
for (const reqApi of reqs) {
|
|
84
|
+
log += ' '.repeat(indent);
|
|
85
|
+
log += `reqId ${reqApi.provenTxReqId} txid ${reqApi.txid}: `;
|
|
86
|
+
if (!ignoreStatus &&
|
|
87
|
+
reqApi.status !== 'callback' &&
|
|
88
|
+
reqApi.status !== 'unmined' &&
|
|
89
|
+
reqApi.status !== 'unknown' &&
|
|
90
|
+
reqApi.status !== 'unconfirmed' &&
|
|
91
|
+
reqApi.status !== 'nosend' &&
|
|
92
|
+
reqApi.status !== 'sending') {
|
|
93
|
+
log += `status of '${reqApi.status}' is not ready to be proven.\n`;
|
|
94
|
+
continue;
|
|
95
|
+
}
|
|
96
|
+
const req = new index_client_1.entity.ProvenTxReq(reqApi);
|
|
97
|
+
if (Number.isInteger(req.provenTxId)) {
|
|
98
|
+
log += `Already linked to provenTxId ${req.provenTxId}.\n`;
|
|
99
|
+
req.notified = false;
|
|
100
|
+
req.status = 'completed';
|
|
101
|
+
await req.updateStorageDynamicProperties(this.storage);
|
|
102
|
+
proven.push(reqApi);
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
log += '\n';
|
|
106
|
+
let reqIsValid = false;
|
|
107
|
+
if (req.rawTx) {
|
|
108
|
+
const txid = (0, index_client_1.asString)((0, index_client_1.doubleSha256BE)(req.rawTx));
|
|
109
|
+
if (txid === req.txid)
|
|
110
|
+
reqIsValid = true;
|
|
111
|
+
}
|
|
112
|
+
if (!reqIsValid) {
|
|
113
|
+
log += ` rawTx doesn't hash to txid. status => invalid.\n`;
|
|
114
|
+
req.notified = false;
|
|
115
|
+
req.status = 'invalid';
|
|
116
|
+
await req.updateStorageDynamicProperties(this.storage);
|
|
117
|
+
invalid.push(reqApi);
|
|
118
|
+
continue;
|
|
119
|
+
}
|
|
120
|
+
const limit = this.monitor.chain === 'main'
|
|
121
|
+
? this.monitor.options.unprovenAttemptsLimitMain
|
|
122
|
+
: this.monitor.options.unprovenAttemptsLimitTest;
|
|
123
|
+
if (!ignoreStatus && req.attempts > limit) {
|
|
124
|
+
log += ` too many failed attempts ${req.attempts}\n`;
|
|
125
|
+
req.notified = false;
|
|
126
|
+
req.status = 'invalid';
|
|
127
|
+
await req.updateStorageDynamicProperties(this.storage);
|
|
128
|
+
invalid.push(reqApi);
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
const since = new Date();
|
|
132
|
+
let r;
|
|
133
|
+
let ptx;
|
|
134
|
+
// External services will try multiple providers until one returns a proof,
|
|
135
|
+
// or they all fail.
|
|
136
|
+
// There may also be an array of proofs to consider when a transaction
|
|
137
|
+
// is recently mined and appears in orphan blocks in addition to active chain blocks.
|
|
138
|
+
// Since orphan blocks can end up on chain again, multiple proofs has value.
|
|
139
|
+
//
|
|
140
|
+
// On failure, there may be a mapi response, or an error.
|
|
141
|
+
//
|
|
142
|
+
// The proofs returned are considered sequentially, validating and chaintracks confirming.
|
|
143
|
+
//
|
|
144
|
+
// If a good proof is found, proceed to using it.
|
|
145
|
+
//
|
|
146
|
+
// When all received proofs fail, force a bump to the next service provider and try
|
|
147
|
+
// one more time.
|
|
148
|
+
//
|
|
149
|
+
r = await this.monitor.services.getMerklePath(req.txid);
|
|
150
|
+
ptx = await index_client_1.entity.ProvenTx.fromReq(req, r, countsAsAttempt && req.status !== 'nosend');
|
|
151
|
+
if (ptx) {
|
|
152
|
+
// We have a merklePath proof for the request (and a block header)
|
|
153
|
+
const { provenTxReqId, status, txid, attempts, history } = req.toApi();
|
|
154
|
+
const { index, height, blockHash, merklePath, merkleRoot } = ptx.toApi();
|
|
155
|
+
const r = await this.storage.runAsStorageProvider(async (sp) => {
|
|
156
|
+
return await sp.updateProvenTxReqWithNewProvenTx({
|
|
157
|
+
provenTxReqId,
|
|
158
|
+
status,
|
|
159
|
+
txid,
|
|
160
|
+
attempts,
|
|
161
|
+
history,
|
|
162
|
+
index,
|
|
163
|
+
height,
|
|
164
|
+
blockHash,
|
|
165
|
+
merklePath,
|
|
166
|
+
merkleRoot
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
req.status = r.status;
|
|
170
|
+
req.apiHistory = r.history;
|
|
171
|
+
req.provenTxId = r.provenTxId;
|
|
172
|
+
req.notified = true;
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
if (countsAsAttempt && req.status !== 'nosend') {
|
|
176
|
+
req.attempts++;
|
|
177
|
+
}
|
|
178
|
+
await req.updateStorageDynamicProperties(this.storage);
|
|
179
|
+
await req.refreshFromStorage(this.storage);
|
|
180
|
+
}
|
|
181
|
+
log += req.historyPretty(since, indent + 2) + '\n';
|
|
182
|
+
if (req.status === 'completed')
|
|
183
|
+
proven.push(req.api);
|
|
184
|
+
if (req.status === 'invalid')
|
|
185
|
+
invalid.push(req.api);
|
|
186
|
+
}
|
|
187
|
+
return { proven, invalid, log };
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
exports.TaskCheckForProofs = TaskCheckForProofs;
|
|
191
|
+
TaskCheckForProofs.taskName = 'CheckForProofs';
|
|
192
|
+
/**
|
|
193
|
+
* An external service such as the chaintracks new block header
|
|
194
|
+
* listener can set this true to cause
|
|
195
|
+
*/
|
|
196
|
+
TaskCheckForProofs.checkNow = false;
|
|
197
|
+
//# sourceMappingURL=TaskCheckForProofs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskCheckForProofs.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Monitor } from '../Monitor';
|
|
2
|
+
import { WalletMonitorTask } from './WalletMonitorTask';
|
|
3
|
+
export declare class TaskClock extends WalletMonitorTask {
|
|
4
|
+
triggerMsecs: number;
|
|
5
|
+
static taskName: string;
|
|
6
|
+
nextMinute: number;
|
|
7
|
+
constructor(monitor: Monitor, triggerMsecs?: number);
|
|
8
|
+
trigger(nowMsecsSinceEpoch: number): {
|
|
9
|
+
run: boolean;
|
|
10
|
+
};
|
|
11
|
+
runTask(): Promise<string>;
|
|
12
|
+
getNextMinute(): number;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=TaskClock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskClock.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskClock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD,qBAAa,SAAU,SAAQ,iBAAiB;IAMrC,YAAY;IALrB,MAAM,CAAC,QAAQ,SAAU;IACzB,UAAU,EAAE,MAAM,CAAA;gBAGhB,OAAO,EAAE,OAAO,EACT,YAAY,SAAwB;IAM7C,OAAO,CAAC,kBAAkB,EAAE,MAAM,GAAG;QAAE,GAAG,EAAE,OAAO,CAAA;KAAE;IAQ/C,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;IAMhC,aAAa,IAAI,MAAM;CAKxB"}
|