@bsv/wallet-toolbox-client 1.7.15 → 1.7.16
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/CWIStyleWalletManager.d.ts +439 -0
- package/out/src/CWIStyleWalletManager.d.ts.map +1 -0
- package/out/src/CWIStyleWalletManager.js +1317 -0
- package/out/src/CWIStyleWalletManager.js.map +1 -0
- package/out/src/SetupClient.d.ts +130 -0
- package/out/src/SetupClient.d.ts.map +1 -0
- package/out/src/SetupClient.js +226 -0
- package/out/src/SetupClient.js.map +1 -0
- package/out/src/SetupWallet.d.ts +103 -0
- package/out/src/SetupWallet.d.ts.map +1 -0
- package/out/src/SetupWallet.js +3 -0
- package/out/src/SetupWallet.js.map +1 -0
- package/out/src/SimpleWalletManager.d.ts +169 -0
- package/out/src/SimpleWalletManager.d.ts.map +1 -0
- package/out/src/SimpleWalletManager.js +315 -0
- package/out/src/SimpleWalletManager.js.map +1 -0
- package/out/src/Wallet.d.ts +206 -0
- package/out/src/Wallet.d.ts.map +1 -0
- package/out/src/Wallet.js +797 -0
- package/out/src/Wallet.js.map +1 -0
- package/out/src/WalletAuthenticationManager.d.ts +33 -0
- package/out/src/WalletAuthenticationManager.d.ts.map +1 -0
- package/out/src/WalletAuthenticationManager.js +113 -0
- package/out/src/WalletAuthenticationManager.js.map +1 -0
- package/out/src/WalletLogger.d.ts +65 -0
- package/out/src/WalletLogger.d.ts.map +1 -0
- package/out/src/WalletLogger.js +167 -0
- package/out/src/WalletLogger.js.map +1 -0
- package/out/src/WalletPermissionsManager.d.ts +760 -0
- package/out/src/WalletPermissionsManager.d.ts.map +1 -0
- package/out/src/WalletPermissionsManager.js +2679 -0
- package/out/src/WalletPermissionsManager.js.map +1 -0
- package/out/src/WalletSettingsManager.d.ts +53 -0
- package/out/src/WalletSettingsManager.d.ts.map +1 -0
- package/out/src/WalletSettingsManager.js +83 -0
- package/out/src/WalletSettingsManager.js.map +1 -0
- package/out/src/index.client.d.ts +23 -0
- package/out/src/index.client.d.ts.map +1 -0
- package/out/src/index.client.js +62 -0
- package/out/src/index.client.js.map +1 -0
- package/out/src/monitor/Monitor.d.ts +148 -0
- package/out/src/monitor/Monitor.d.ts.map +1 -0
- package/out/src/monitor/Monitor.js +317 -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 +213 -0
- package/out/src/monitor/tasks/TaskCheckForProofs.js.map +1 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts +33 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.js +71 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.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 +28 -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/TaskMonitorCallHistory.d.ts +12 -0
- package/out/src/monitor/tasks/TaskMonitorCallHistory.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskMonitorCallHistory.js +24 -0
- package/out/src/monitor/tasks/TaskMonitorCallHistory.js.map +1 -0
- package/out/src/monitor/tasks/TaskNewHeader.d.ts +50 -0
- package/out/src/monitor/tasks/TaskNewHeader.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskNewHeader.js +84 -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 +34 -0
- package/out/src/monitor/tasks/TaskPurge.js.map +1 -0
- package/out/src/monitor/tasks/TaskReorg.d.ts +43 -0
- package/out/src/monitor/tasks/TaskReorg.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskReorg.js +82 -0
- package/out/src/monitor/tasks/TaskReorg.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 +43 -0
- package/out/src/monitor/tasks/TaskReviewStatus.js.map +1 -0
- package/out/src/monitor/tasks/TaskSendWaiting.d.ts +35 -0
- package/out/src/monitor/tasks/TaskSendWaiting.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskSendWaiting.js +117 -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/TaskUnFail.d.ts +41 -0
- package/out/src/monitor/tasks/TaskUnFail.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskUnFail.js +145 -0
- package/out/src/monitor/tasks/TaskUnFail.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/CertOpsWallet.d.ts +7 -0
- package/out/src/sdk/CertOpsWallet.d.ts.map +1 -0
- package/out/src/sdk/CertOpsWallet.js +3 -0
- package/out/src/sdk/CertOpsWallet.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/WERR_errors.d.ts +136 -0
- package/out/src/sdk/WERR_errors.d.ts.map +1 -0
- package/out/src/sdk/WERR_errors.js +218 -0
- package/out/src/sdk/WERR_errors.js.map +1 -0
- package/out/src/sdk/WalletError.d.ts +63 -0
- package/out/src/sdk/WalletError.d.ts.map +1 -0
- package/out/src/sdk/WalletError.js +169 -0
- package/out/src/sdk/WalletError.js.map +1 -0
- package/out/src/sdk/WalletErrorFromJson.d.ts +12 -0
- package/out/src/sdk/WalletErrorFromJson.d.ts.map +1 -0
- package/out/src/sdk/WalletErrorFromJson.js +69 -0
- package/out/src/sdk/WalletErrorFromJson.js.map +1 -0
- package/out/src/sdk/WalletServices.interfaces.d.ts +618 -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 +522 -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 +11 -0
- package/out/src/sdk/index.d.ts.map +1 -0
- package/out/src/sdk/index.js +29 -0
- package/out/src/sdk/index.js.map +1 -0
- package/out/src/sdk/types.d.ts +169 -0
- package/out/src/sdk/types.d.ts.map +1 -0
- package/out/src/sdk/types.js +90 -0
- package/out/src/sdk/types.js.map +1 -0
- package/out/src/services/ServiceCollection.d.ts +79 -0
- package/out/src/services/ServiceCollection.d.ts.map +1 -0
- package/out/src/services/ServiceCollection.js +192 -0
- package/out/src/services/ServiceCollection.js.map +1 -0
- package/out/src/services/Services.d.ts +71 -0
- package/out/src/services/Services.d.ts.map +1 -0
- package/out/src/services/Services.js +532 -0
- package/out/src/services/Services.js.map +1 -0
- package/out/src/services/chaintracker/BHServiceClient.d.ts +39 -0
- package/out/src/services/chaintracker/BHServiceClient.d.ts.map +1 -0
- package/out/src/services/chaintracker/BHServiceClient.js +174 -0
- package/out/src/services/chaintracker/BHServiceClient.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 +53 -0
- package/out/src/services/chaintracker/ChaintracksChainTracker.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BlockHeaderApi.d.ts +55 -0
- package/out/src/services/chaintracker/chaintracks/Api/BlockHeaderApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BlockHeaderApi.js +38 -0
- package/out/src/services/chaintracker/chaintracks/Api/BlockHeaderApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkIngestorApi.d.ts +70 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkIngestorApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkIngestorApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkIngestorApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkStorageApi.d.ts +81 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkStorageApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkStorageApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/BulkStorageApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksApi.d.ts +54 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksClientApi.d.ts +163 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksClientApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksClientApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksClientApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFetchApi.d.ts +18 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFetchApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFetchApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFetchApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFsApi.d.ts +55 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFsApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFsApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksFsApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksStorageApi.d.ts +338 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksStorageApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksStorageApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/ChaintracksStorageApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/LiveIngestorApi.d.ts +19 -0
- package/out/src/services/chaintracker/chaintracks/Api/LiveIngestorApi.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Api/LiveIngestorApi.js +3 -0
- package/out/src/services/chaintracker/chaintracks/Api/LiveIngestorApi.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Chaintracks.d.ts +101 -0
- package/out/src/services/chaintracker/chaintracks/Chaintracks.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Chaintracks.js +550 -0
- package/out/src/services/chaintracker/chaintracks/Chaintracks.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts +38 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js +139 -0
- package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.d.ts +60 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.js +119 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.d.ts +76 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.js +114 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDNBabbage.d.ts +13 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDNBabbage.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDNBabbage.js +20 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDNBabbage.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.d.ts +62 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.js +59 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.d.ts +62 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.js +42 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.d.ts +51 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.js +55 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.d.ts +171 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.js +501 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.d.ts +89 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.js +137 -0
- package/out/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.d.ts +23 -0
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.js +68 -0
- package/out/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.d.ts +68 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.js +290 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.d.ts +92 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.js +465 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.d.ts +37 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.js +260 -0
- package/out/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.d.ts +5 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.js +68 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.d.ts +5 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.js +68 -0
- package/out/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.d.ts +13 -0
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.js +27 -0
- package/out/src/services/chaintracker/chaintracks/createIdbChaintracks.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.d.ts +13 -0
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.js +27 -0
- package/out/src/services/chaintracker/chaintracks/createNoDbChaintracks.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.client.d.ts +4 -0
- package/out/src/services/chaintracker/chaintracks/index.client.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.client.js +20 -0
- package/out/src/services/chaintracker/chaintracks/index.client.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.mobile.d.ts +30 -0
- package/out/src/services/chaintracker/chaintracks/index.mobile.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/index.mobile.js +68 -0
- package/out/src/services/chaintracker/chaintracks/index.mobile.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.d.ts +155 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.js +848 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFileDataManager.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.d.ts +78 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.js +261 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkFilesReader.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.d.ts +129 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.js +145 -0
- package/out/src/services/chaintracker/chaintracks/util/BulkHeaderFile.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.d.ts +14 -0
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.js +67 -0
- package/out/src/services/chaintracker/chaintracks/util/ChaintracksFetch.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.d.ts +90 -0
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.js +140 -0
- package/out/src/services/chaintracker/chaintracks/util/HeightRange.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.d.ts +14 -0
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.js +88 -0
- package/out/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.d.ts +159 -0
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js +520 -0
- package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.d.ts +20 -0
- package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.js +31 -0
- package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.js.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.d.ts +37 -0
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.d.ts.map +1 -0
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.js +432 -0
- package/out/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.js.map +1 -0
- package/out/src/services/chaintracker/index.client.d.ts +4 -0
- package/out/src/services/chaintracker/index.client.d.ts.map +1 -0
- package/out/src/services/chaintracker/index.client.js +20 -0
- package/out/src/services/chaintracker/index.client.js.map +1 -0
- package/out/src/services/createDefaultWalletServicesOptions.d.ts +7 -0
- package/out/src/services/createDefaultWalletServicesOptions.d.ts.map +1 -0
- package/out/src/services/createDefaultWalletServicesOptions.js +65 -0
- package/out/src/services/createDefaultWalletServicesOptions.js.map +1 -0
- package/out/src/services/providers/ARC.d.ts +92 -0
- package/out/src/services/providers/ARC.d.ts.map +1 -0
- package/out/src/services/providers/ARC.js +270 -0
- package/out/src/services/providers/ARC.js.map +1 -0
- package/out/src/services/providers/Bitails.d.ts +50 -0
- package/out/src/services/providers/Bitails.d.ts.map +1 -0
- package/out/src/services/providers/Bitails.js +224 -0
- package/out/src/services/providers/Bitails.js.map +1 -0
- package/out/src/services/providers/SdkWhatsOnChain.d.ts +21 -0
- package/out/src/services/providers/SdkWhatsOnChain.d.ts.map +1 -0
- package/out/src/services/providers/SdkWhatsOnChain.js +67 -0
- package/out/src/services/providers/SdkWhatsOnChain.js.map +1 -0
- package/out/src/services/providers/WhatsOnChain.d.ts +130 -0
- package/out/src/services/providers/WhatsOnChain.d.ts.map +1 -0
- package/out/src/services/providers/WhatsOnChain.js +679 -0
- package/out/src/services/providers/WhatsOnChain.js.map +1 -0
- package/out/src/services/providers/exchangeRates.d.ts +12 -0
- package/out/src/services/providers/exchangeRates.d.ts.map +1 -0
- package/out/src/services/providers/exchangeRates.js +237 -0
- package/out/src/services/providers/exchangeRates.js.map +1 -0
- package/out/src/services/providers/getBeefForTxid.d.ts +4 -0
- package/out/src/services/providers/getBeefForTxid.d.ts.map +1 -0
- package/out/src/services/providers/getBeefForTxid.js +286 -0
- package/out/src/services/providers/getBeefForTxid.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 +5 -0
- package/out/src/signer/methods/acquireDirectCertificate.d.ts.map +1 -0
- package/out/src/signer/methods/acquireDirectCertificate.js +45 -0
- package/out/src/signer/methods/acquireDirectCertificate.js.map +1 -0
- package/out/src/signer/methods/buildSignableTransaction.d.ts +15 -0
- package/out/src/signer/methods/buildSignableTransaction.d.ts.map +1 -0
- package/out/src/signer/methods/buildSignableTransaction.js +142 -0
- package/out/src/signer/methods/buildSignableTransaction.js.map +1 -0
- package/out/src/signer/methods/completeSignedTransaction.d.ts +10 -0
- package/out/src/signer/methods/completeSignedTransaction.d.ts.map +1 -0
- package/out/src/signer/methods/completeSignedTransaction.js +106 -0
- package/out/src/signer/methods/completeSignedTransaction.js.map +1 -0
- package/out/src/signer/methods/createAction.d.ts +14 -0
- package/out/src/signer/methods/createAction.d.ts.map +1 -0
- package/out/src/signer/methods/createAction.js +117 -0
- package/out/src/signer/methods/createAction.js.map +1 -0
- package/out/src/signer/methods/internalizeAction.d.ts +32 -0
- package/out/src/signer/methods/internalizeAction.d.ts.map +1 -0
- package/out/src/signer/methods/internalizeAction.js +93 -0
- package/out/src/signer/methods/internalizeAction.js.map +1 -0
- package/out/src/signer/methods/proveCertificate.d.ts +5 -0
- package/out/src/signer/methods/proveCertificate.d.ts.map +1 -0
- package/out/src/signer/methods/proveCertificate.js +29 -0
- package/out/src/signer/methods/proveCertificate.js.map +1 -0
- package/out/src/signer/methods/signAction.d.ts +11 -0
- package/out/src/signer/methods/signAction.d.ts.map +1 -0
- package/out/src/signer/methods/signAction.js +41 -0
- package/out/src/signer/methods/signAction.js.map +1 -0
- package/out/src/storage/StorageIdb.d.ts +210 -0
- package/out/src/storage/StorageIdb.d.ts.map +1 -0
- package/out/src/storage/StorageIdb.js +2297 -0
- package/out/src/storage/StorageIdb.js.map +1 -0
- package/out/src/storage/StorageProvider.d.ts +222 -0
- package/out/src/storage/StorageProvider.d.ts.map +1 -0
- package/out/src/storage/StorageProvider.js +567 -0
- package/out/src/storage/StorageProvider.js.map +1 -0
- package/out/src/storage/StorageReader.d.ts +77 -0
- package/out/src/storage/StorageReader.d.ts.map +1 -0
- package/out/src/storage/StorageReader.js +163 -0
- package/out/src/storage/StorageReader.js.map +1 -0
- package/out/src/storage/StorageReaderWriter.d.ts +102 -0
- package/out/src/storage/StorageReaderWriter.d.ts.map +1 -0
- package/out/src/storage/StorageReaderWriter.js +338 -0
- package/out/src/storage/StorageReaderWriter.js.map +1 -0
- package/out/src/storage/StorageSyncReader.d.ts +18 -0
- package/out/src/storage/StorageSyncReader.d.ts.map +1 -0
- package/out/src/storage/StorageSyncReader.js +71 -0
- package/out/src/storage/StorageSyncReader.js.map +1 -0
- package/out/src/storage/WalletStorageManager.d.ts +221 -0
- package/out/src/storage/WalletStorageManager.d.ts.map +1 -0
- package/out/src/storage/WalletStorageManager.js +819 -0
- package/out/src/storage/WalletStorageManager.js.map +1 -0
- package/out/src/storage/index.client.d.ts +8 -0
- package/out/src/storage/index.client.d.ts.map +1 -0
- package/out/src/storage/index.client.js +24 -0
- package/out/src/storage/index.client.js.map +1 -0
- package/out/src/storage/methods/ListActionsSpecOp.d.ts +18 -0
- package/out/src/storage/methods/ListActionsSpecOp.d.ts.map +1 -0
- package/out/src/storage/methods/ListActionsSpecOp.js +40 -0
- package/out/src/storage/methods/ListActionsSpecOp.js.map +1 -0
- package/out/src/storage/methods/ListOutputsSpecOp.d.ts +26 -0
- package/out/src/storage/methods/ListOutputsSpecOp.d.ts.map +1 -0
- package/out/src/storage/methods/ListOutputsSpecOp.js +75 -0
- package/out/src/storage/methods/ListOutputsSpecOp.js.map +1 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts +41 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts.map +1 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js +324 -0
- package/out/src/storage/methods/attemptToPostReqsToNetwork.js.map +1 -0
- package/out/src/storage/methods/createAction.d.ts +13 -0
- package/out/src/storage/methods/createAction.d.ts.map +1 -0
- package/out/src/storage/methods/createAction.js +732 -0
- package/out/src/storage/methods/createAction.js.map +1 -0
- package/out/src/storage/methods/generateChange.d.ts +96 -0
- package/out/src/storage/methods/generateChange.d.ts.map +1 -0
- package/out/src/storage/methods/generateChange.js +405 -0
- package/out/src/storage/methods/generateChange.js.map +1 -0
- package/out/src/storage/methods/getBeefForTransaction.d.ts +23 -0
- package/out/src/storage/methods/getBeefForTransaction.d.ts.map +1 -0
- package/out/src/storage/methods/getBeefForTransaction.js +109 -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 +272 -0
- package/out/src/storage/methods/getSyncChunk.js.map +1 -0
- package/out/src/storage/methods/internalizeAction.d.ts +31 -0
- package/out/src/storage/methods/internalizeAction.d.ts.map +1 -0
- package/out/src/storage/methods/internalizeAction.js +462 -0
- package/out/src/storage/methods/internalizeAction.js.map +1 -0
- package/out/src/storage/methods/listActionsIdb.d.ts +5 -0
- package/out/src/storage/methods/listActionsIdb.d.ts.map +1 -0
- package/out/src/storage/methods/listActionsIdb.js +155 -0
- package/out/src/storage/methods/listActionsIdb.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/listOutputsIdb.d.ts +5 -0
- package/out/src/storage/methods/listOutputsIdb.d.ts.map +1 -0
- package/out/src/storage/methods/listOutputsIdb.js +185 -0
- package/out/src/storage/methods/listOutputsIdb.js.map +1 -0
- package/out/src/storage/methods/offsetKey.d.ts +24 -0
- package/out/src/storage/methods/offsetKey.d.ts.map +1 -0
- package/out/src/storage/methods/offsetKey.js +67 -0
- package/out/src/storage/methods/offsetKey.js.map +1 -0
- package/out/src/storage/methods/processAction.d.ts +54 -0
- package/out/src/storage/methods/processAction.d.ts.map +1 -0
- package/out/src/storage/methods/processAction.js +267 -0
- package/out/src/storage/methods/processAction.js.map +1 -0
- package/out/src/storage/methods/purgeDataIdb.d.ts +4 -0
- package/out/src/storage/methods/purgeDataIdb.d.ts.map +1 -0
- package/out/src/storage/methods/purgeDataIdb.js +9 -0
- package/out/src/storage/methods/purgeDataIdb.js.map +1 -0
- package/out/src/storage/methods/reviewStatusIdb.d.ts +20 -0
- package/out/src/storage/methods/reviewStatusIdb.d.ts.map +1 -0
- package/out/src/storage/methods/reviewStatusIdb.js +35 -0
- package/out/src/storage/methods/reviewStatusIdb.js.map +1 -0
- package/out/src/storage/methods/utils.d.ts +25 -0
- package/out/src/storage/methods/utils.d.ts.map +1 -0
- package/out/src/storage/methods/utils.js +53 -0
- package/out/src/storage/methods/utils.js.map +1 -0
- package/out/src/storage/remoting/StorageClient.d.ts +292 -0
- package/out/src/storage/remoting/StorageClient.d.ts.map +1 -0
- package/out/src/storage/remoting/StorageClient.js +497 -0
- package/out/src/storage/remoting/StorageClient.js.map +1 -0
- package/out/src/storage/schema/StorageIdbSchema.d.ts +133 -0
- package/out/src/storage/schema/StorageIdbSchema.d.ts.map +1 -0
- package/out/src/storage/schema/StorageIdbSchema.js +3 -0
- package/out/src/storage/schema/StorageIdbSchema.js.map +1 -0
- package/out/src/storage/schema/entities/EntityBase.d.ts +106 -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/EntityCertificate.d.ts +44 -0
- package/out/src/storage/schema/entities/EntityCertificate.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityCertificate.js +162 -0
- package/out/src/storage/schema/entities/EntityCertificate.js.map +1 -0
- package/out/src/storage/schema/entities/EntityCertificateField.d.ts +33 -0
- package/out/src/storage/schema/entities/EntityCertificateField.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityCertificateField.js +112 -0
- package/out/src/storage/schema/entities/EntityCertificateField.js.map +1 -0
- package/out/src/storage/schema/entities/EntityCommission.d.ts +38 -0
- package/out/src/storage/schema/entities/EntityCommission.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityCommission.js +127 -0
- package/out/src/storage/schema/entities/EntityCommission.js.map +1 -0
- package/out/src/storage/schema/entities/EntityOutput.d.ts +68 -0
- package/out/src/storage/schema/entities/EntityOutput.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityOutput.js +264 -0
- package/out/src/storage/schema/entities/EntityOutput.js.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputBasket.d.ts +36 -0
- package/out/src/storage/schema/entities/EntityOutputBasket.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputBasket.js +133 -0
- package/out/src/storage/schema/entities/EntityOutputBasket.js.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputTag.d.ts +32 -0
- package/out/src/storage/schema/entities/EntityOutputTag.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputTag.js +104 -0
- package/out/src/storage/schema/entities/EntityOutputTag.js.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputTagMap.d.ts +29 -0
- package/out/src/storage/schema/entities/EntityOutputTagMap.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityOutputTagMap.js +98 -0
- package/out/src/storage/schema/entities/EntityOutputTagMap.js.map +1 -0
- package/out/src/storage/schema/entities/EntityProvenTx.d.ts +87 -0
- package/out/src/storage/schema/entities/EntityProvenTx.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityProvenTx.js +278 -0
- package/out/src/storage/schema/entities/EntityProvenTx.js.map +1 -0
- package/out/src/storage/schema/entities/EntityProvenTxReq.d.ts +139 -0
- package/out/src/storage/schema/entities/EntityProvenTxReq.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityProvenTxReq.js +524 -0
- package/out/src/storage/schema/entities/EntityProvenTxReq.js.map +1 -0
- package/out/src/storage/schema/entities/EntitySyncState.d.ts +69 -0
- package/out/src/storage/schema/entities/EntitySyncState.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntitySyncState.js +334 -0
- package/out/src/storage/schema/entities/EntitySyncState.js.map +1 -0
- package/out/src/storage/schema/entities/EntityTransaction.d.ts +71 -0
- package/out/src/storage/schema/entities/EntityTransaction.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityTransaction.js +255 -0
- package/out/src/storage/schema/entities/EntityTransaction.js.map +1 -0
- package/out/src/storage/schema/entities/EntityTxLabel.d.ts +32 -0
- package/out/src/storage/schema/entities/EntityTxLabel.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityTxLabel.js +104 -0
- package/out/src/storage/schema/entities/EntityTxLabel.js.map +1 -0
- package/out/src/storage/schema/entities/EntityTxLabelMap.d.ts +29 -0
- package/out/src/storage/schema/entities/EntityTxLabelMap.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityTxLabelMap.js +98 -0
- package/out/src/storage/schema/entities/EntityTxLabelMap.js.map +1 -0
- package/out/src/storage/schema/entities/EntityUser.d.ts +30 -0
- package/out/src/storage/schema/entities/EntityUser.d.ts.map +1 -0
- package/out/src/storage/schema/entities/EntityUser.js +99 -0
- package/out/src/storage/schema/entities/EntityUser.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 +63 -0
- package/out/src/storage/schema/entities/MergeEntity.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/TableCertificate.d.ts +20 -0
- package/out/src/storage/schema/tables/TableCertificate.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableCertificate.js +3 -0
- package/out/src/storage/schema/tables/TableCertificate.js.map +1 -0
- package/out/src/storage/schema/tables/TableCertificateField.d.ts +12 -0
- package/out/src/storage/schema/tables/TableCertificateField.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableCertificateField.js +3 -0
- package/out/src/storage/schema/tables/TableCertificateField.js.map +1 -0
- package/out/src/storage/schema/tables/TableCommission.d.ts +13 -0
- package/out/src/storage/schema/tables/TableCommission.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableCommission.js +3 -0
- package/out/src/storage/schema/tables/TableCommission.js.map +1 -0
- package/out/src/storage/schema/tables/TableMonitorEvent.d.ts +9 -0
- package/out/src/storage/schema/tables/TableMonitorEvent.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableMonitorEvent.js +3 -0
- package/out/src/storage/schema/tables/TableMonitorEvent.js.map +1 -0
- package/out/src/storage/schema/tables/TableOutput.d.ts +36 -0
- package/out/src/storage/schema/tables/TableOutput.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableOutput.js +31 -0
- package/out/src/storage/schema/tables/TableOutput.js.map +1 -0
- package/out/src/storage/schema/tables/TableOutputBasket.d.ts +12 -0
- package/out/src/storage/schema/tables/TableOutputBasket.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableOutputBasket.js +3 -0
- package/out/src/storage/schema/tables/TableOutputBasket.js.map +1 -0
- package/out/src/storage/schema/tables/TableOutputTag.d.ts +10 -0
- package/out/src/storage/schema/tables/TableOutputTag.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableOutputTag.js +3 -0
- package/out/src/storage/schema/tables/TableOutputTag.js.map +1 -0
- package/out/src/storage/schema/tables/TableOutputTagMap.d.ts +9 -0
- package/out/src/storage/schema/tables/TableOutputTagMap.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableOutputTagMap.js +3 -0
- package/out/src/storage/schema/tables/TableOutputTagMap.js.map +1 -0
- package/out/src/storage/schema/tables/TableProvenTx.d.ts +14 -0
- package/out/src/storage/schema/tables/TableProvenTx.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableProvenTx.js +3 -0
- package/out/src/storage/schema/tables/TableProvenTx.js.map +1 -0
- package/out/src/storage/schema/tables/TableProvenTxReq.d.ts +64 -0
- package/out/src/storage/schema/tables/TableProvenTxReq.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableProvenTxReq.js +3 -0
- package/out/src/storage/schema/tables/TableProvenTxReq.js.map +1 -0
- package/out/src/storage/schema/tables/TableSettings.d.ts +17 -0
- package/out/src/storage/schema/tables/TableSettings.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableSettings.js +3 -0
- package/out/src/storage/schema/tables/TableSettings.js.map +1 -0
- package/out/src/storage/schema/tables/TableSyncState.d.ts +18 -0
- package/out/src/storage/schema/tables/TableSyncState.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableSyncState.js +3 -0
- package/out/src/storage/schema/tables/TableSyncState.js.map +1 -0
- package/out/src/storage/schema/tables/TableTransaction.d.ts +37 -0
- package/out/src/storage/schema/tables/TableTransaction.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableTransaction.js +21 -0
- package/out/src/storage/schema/tables/TableTransaction.js.map +1 -0
- package/out/src/storage/schema/tables/TableTxLabel.d.ts +10 -0
- package/out/src/storage/schema/tables/TableTxLabel.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableTxLabel.js +3 -0
- package/out/src/storage/schema/tables/TableTxLabel.js.map +1 -0
- package/out/src/storage/schema/tables/TableTxLabelMap.d.ts +9 -0
- package/out/src/storage/schema/tables/TableTxLabelMap.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableTxLabelMap.js +3 -0
- package/out/src/storage/schema/tables/TableTxLabelMap.js.map +1 -0
- package/out/src/storage/schema/tables/TableUser.d.ts +16 -0
- package/out/src/storage/schema/tables/TableUser.d.ts.map +1 -0
- package/out/src/storage/schema/tables/TableUser.js +3 -0
- package/out/src/storage/schema/tables/TableUser.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/ReaderUint8Array.d.ts +28 -0
- package/out/src/utility/ReaderUint8Array.d.ts.map +1 -0
- package/out/src/utility/ReaderUint8Array.js +166 -0
- package/out/src/utility/ReaderUint8Array.js.map +1 -0
- package/out/src/utility/ScriptTemplateBRC29.d.ts +25 -0
- package/out/src/utility/ScriptTemplateBRC29.d.ts.map +1 -0
- package/out/src/utility/ScriptTemplateBRC29.js +48 -0
- package/out/src/utility/ScriptTemplateBRC29.js.map +1 -0
- package/out/src/utility/aggregateResults.d.ts +8 -0
- package/out/src/utility/aggregateResults.d.ts.map +1 -0
- package/out/src/utility/aggregateResults.js +59 -0
- package/out/src/utility/aggregateResults.js.map +1 -0
- package/out/src/utility/identityUtils.d.ts +31 -0
- package/out/src/utility/identityUtils.d.ts.map +1 -0
- package/out/src/utility/identityUtils.js +116 -0
- package/out/src/utility/identityUtils.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 +138 -0
- package/out/src/utility/utilityHelpers.d.ts.map +1 -0
- package/out/src/utility/utilityHelpers.js +294 -0
- package/out/src/utility/utilityHelpers.js.map +1 -0
- package/out/src/utility/utilityHelpers.noBuffer.d.ts +26 -0
- package/out/src/utility/utilityHelpers.noBuffer.d.ts.map +1 -0
- package/out/src/utility/utilityHelpers.noBuffer.js +64 -0
- package/out/src/utility/utilityHelpers.noBuffer.js.map +1 -0
- package/out/src/wab-client/WABClient.d.ts +49 -0
- package/out/src/wab-client/WABClient.d.ts.map +1 -0
- package/out/src/wab-client/WABClient.js +80 -0
- package/out/src/wab-client/WABClient.js.map +1 -0
- package/out/src/wab-client/auth-method-interactors/AuthMethodInteractor.d.ts +34 -0
- package/out/src/wab-client/auth-method-interactors/AuthMethodInteractor.d.ts.map +1 -0
- package/out/src/wab-client/auth-method-interactors/AuthMethodInteractor.js +16 -0
- package/out/src/wab-client/auth-method-interactors/AuthMethodInteractor.js.map +1 -0
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.d.ts +29 -0
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.d.ts.map +1 -0
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.js +70 -0
- package/out/src/wab-client/auth-method-interactors/DevConsoleInteractor.js.map +1 -0
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.d.ts +7 -0
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.d.ts.map +1 -0
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.js +36 -0
- package/out/src/wab-client/auth-method-interactors/PersonaIDInteractor.js.map +1 -0
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.d.ts +28 -0
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.d.ts.map +1 -0
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.js +69 -0
- package/out/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.js.map +1 -0
- package/out/tsconfig.client.tsbuildinfo +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.acquireDirectCertificate = acquireDirectCertificate;
|
|
4
|
+
async function acquireDirectCertificate(wallet, auth, vargs) {
|
|
5
|
+
var _a;
|
|
6
|
+
const now = new Date();
|
|
7
|
+
const newCert = {
|
|
8
|
+
certificateId: 0, // replaced by storage insert
|
|
9
|
+
created_at: now,
|
|
10
|
+
updated_at: now,
|
|
11
|
+
userId: auth.userId,
|
|
12
|
+
type: vargs.type,
|
|
13
|
+
subject: vargs.subject,
|
|
14
|
+
verifier: vargs.keyringRevealer === 'certifier' ? vargs.certifier : vargs.keyringRevealer,
|
|
15
|
+
serialNumber: vargs.serialNumber,
|
|
16
|
+
certifier: vargs.certifier,
|
|
17
|
+
revocationOutpoint: vargs.revocationOutpoint,
|
|
18
|
+
signature: vargs.signature,
|
|
19
|
+
fields: [],
|
|
20
|
+
isDeleted: false
|
|
21
|
+
};
|
|
22
|
+
for (const [name, value] of Object.entries(vargs.fields)) {
|
|
23
|
+
(_a = newCert.fields) === null || _a === void 0 ? void 0 : _a.push({
|
|
24
|
+
certificateId: 0, // replaced by storage insert
|
|
25
|
+
created_at: now,
|
|
26
|
+
updated_at: now,
|
|
27
|
+
userId: auth.userId,
|
|
28
|
+
fieldName: name,
|
|
29
|
+
fieldValue: value,
|
|
30
|
+
masterKey: vargs.keyringForSubject[name] || ''
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
const count = await wallet.storage.insertCertificate(newCert);
|
|
34
|
+
const r = {
|
|
35
|
+
type: vargs.type,
|
|
36
|
+
subject: vargs.subject,
|
|
37
|
+
serialNumber: vargs.serialNumber,
|
|
38
|
+
certifier: vargs.certifier,
|
|
39
|
+
revocationOutpoint: vargs.revocationOutpoint,
|
|
40
|
+
signature: vargs.signature,
|
|
41
|
+
fields: vargs.fields
|
|
42
|
+
};
|
|
43
|
+
return r;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=acquireDirectCertificate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acquireDirectCertificate.js","sourceRoot":"","sources":["../../../../../src/signer/methods/acquireDirectCertificate.ts"],"names":[],"mappings":";;AAKA,4DA8CC;AA9CM,KAAK,UAAU,wBAAwB,CAC5C,MAAc,EACd,IAAY,EACZ,KAAmD;;IAEnD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;IACtB,MAAM,OAAO,GAAsB;QACjC,aAAa,EAAE,CAAC,EAAE,6BAA6B;QAC/C,UAAU,EAAE,GAAG;QACf,UAAU,EAAE,GAAG;QACf,MAAM,EAAE,IAAI,CAAC,MAAO;QACpB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,QAAQ,EAAE,KAAK,CAAC,eAAe,KAAK,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe;QACzF,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;QAC5C,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,EAAE;QACV,SAAS,EAAE,KAAK;KACjB,CAAA;IACD,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;QACzD,MAAA,OAAO,CAAC,MAAM,0CAAE,IAAI,CAAC;YACnB,aAAa,EAAE,CAAC,EAAE,6BAA6B;YAC/C,UAAU,EAAE,GAAG;YACf,UAAU,EAAE,GAAG;YACf,MAAM,EAAE,IAAI,CAAC,MAAO;YACpB,SAAS,EAAE,IAAI;YACf,UAAU,EAAE,KAAK;YACjB,SAAS,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE;SAC/C,CAAC,CAAA;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAA;IAE7D,MAAM,CAAC,GAA6B;QAClC,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;QAC5C,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,KAAK,CAAC,MAAM;KACrB,CAAA;IAED,OAAO,CAAC,CAAA;AACV,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Script, Transaction, Validation } from '@bsv/sdk';
|
|
2
|
+
import { Wallet, PendingStorageInput } from '../../Wallet';
|
|
3
|
+
import { StorageCreateActionResult, StorageCreateTransactionSdkOutput } from '../../sdk/WalletStorage.interfaces';
|
|
4
|
+
import { KeyPair } from '../../sdk/types';
|
|
5
|
+
export declare function buildSignableTransaction(dctr: StorageCreateActionResult, args: Validation.ValidCreateActionArgs, wallet: Wallet): {
|
|
6
|
+
tx: Transaction;
|
|
7
|
+
amount: number;
|
|
8
|
+
pdi: PendingStorageInput[];
|
|
9
|
+
log: string;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Derive a change output locking script
|
|
13
|
+
*/
|
|
14
|
+
export declare function makeChangeLock(out: StorageCreateTransactionSdkOutput, dctr: StorageCreateActionResult, args: Validation.ValidCreateActionArgs, changeKeys: KeyPair, wallet: Wallet): Script;
|
|
15
|
+
//# sourceMappingURL=buildSignableTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildSignableTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/signer/methods/buildSignableTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,MAAM,EAAE,WAAW,EAAuC,UAAU,EAAE,MAAM,UAAU,CAAA;AACrG,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAA;AAC1D,OAAO,EACL,yBAAyB,EAEzB,iCAAiC,EAClC,MAAM,oCAAoC,CAAA;AAG3C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAGzC,wBAAgB,wBAAwB,CACtC,IAAI,EAAE,yBAAyB,EAC/B,IAAI,EAAE,UAAU,CAAC,qBAAqB,EACtC,MAAM,EAAE,MAAM,GACb;IACD,EAAE,EAAE,WAAW,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;IACd,GAAG,EAAE,mBAAmB,EAAE,CAAA;IAC1B,GAAG,EAAE,MAAM,CAAA;CACZ,CA4IA;AAED;;GAEG;AACH,wBAAgB,cAAc,CAC5B,GAAG,EAAE,iCAAiC,EACtC,IAAI,EAAE,yBAAyB,EAC/B,IAAI,EAAE,UAAU,CAAC,qBAAqB,EACtC,UAAU,EAAE,OAAO,EACnB,MAAM,EAAE,MAAM,GACb,MAAM,CAUR"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildSignableTransaction = buildSignableTransaction;
|
|
4
|
+
exports.makeChangeLock = makeChangeLock;
|
|
5
|
+
const sdk_1 = require("@bsv/sdk");
|
|
6
|
+
const WERR_errors_1 = require("../../sdk/WERR_errors");
|
|
7
|
+
const utilityHelpers_1 = require("../../utility/utilityHelpers");
|
|
8
|
+
const ScriptTemplateBRC29_1 = require("../../utility/ScriptTemplateBRC29");
|
|
9
|
+
function buildSignableTransaction(dctr, args, wallet) {
|
|
10
|
+
var _a;
|
|
11
|
+
const changeKeys = wallet.getClientChangeKeyPair();
|
|
12
|
+
const inputBeef = args.inputBEEF ? sdk_1.Beef.fromBinary(args.inputBEEF) : undefined;
|
|
13
|
+
const { inputs: storageInputs, outputs: storageOutputs } = dctr;
|
|
14
|
+
const tx = new sdk_1.Transaction(args.version, [], [], args.lockTime);
|
|
15
|
+
// The order of outputs in storageOutputs is always:
|
|
16
|
+
// CreateActionArgs.outputs in the original order
|
|
17
|
+
// Commission output
|
|
18
|
+
// Change outputs
|
|
19
|
+
// The Vout values will be randomized if args.options.randomizeOutputs is true. Default is true.
|
|
20
|
+
const voutToIndex = Array(storageOutputs.length);
|
|
21
|
+
for (let vout = 0; vout < storageOutputs.length; vout++) {
|
|
22
|
+
const i = storageOutputs.findIndex(o => o.vout === vout);
|
|
23
|
+
if (i < 0)
|
|
24
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('output.vout', `sequential. ${vout} is missing`);
|
|
25
|
+
voutToIndex[vout] = i;
|
|
26
|
+
}
|
|
27
|
+
//////////////
|
|
28
|
+
// Add OUTPUTS
|
|
29
|
+
/////////////
|
|
30
|
+
for (let vout = 0; vout < storageOutputs.length; vout++) {
|
|
31
|
+
const i = voutToIndex[vout];
|
|
32
|
+
const out = storageOutputs[i];
|
|
33
|
+
if (vout !== out.vout)
|
|
34
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('output.vout', `equal to array index. ${out.vout} !== ${vout}`);
|
|
35
|
+
const change = out.providedBy === 'storage' && out.purpose === 'change';
|
|
36
|
+
const lockingScript = change
|
|
37
|
+
? makeChangeLock(out, dctr, args, changeKeys, wallet)
|
|
38
|
+
: (0, utilityHelpers_1.asBsvSdkScript)(out.lockingScript);
|
|
39
|
+
const output = {
|
|
40
|
+
satoshis: out.satoshis,
|
|
41
|
+
lockingScript,
|
|
42
|
+
change
|
|
43
|
+
};
|
|
44
|
+
tx.addOutput(output);
|
|
45
|
+
}
|
|
46
|
+
if (storageOutputs.length === 0) {
|
|
47
|
+
// Add a dummy output to avoid transaction rejection by processors for having no outputs.
|
|
48
|
+
const output = {
|
|
49
|
+
satoshis: 0,
|
|
50
|
+
lockingScript: sdk_1.Script.fromASM('OP_FALSE OP_RETURN 42'),
|
|
51
|
+
change: false
|
|
52
|
+
};
|
|
53
|
+
tx.addOutput(output);
|
|
54
|
+
}
|
|
55
|
+
//////////////
|
|
56
|
+
// Merge and sort INPUTS info by vin order.
|
|
57
|
+
/////////////
|
|
58
|
+
const inputs = [];
|
|
59
|
+
for (const storageInput of storageInputs) {
|
|
60
|
+
const argsInput = storageInput.vin !== undefined && storageInput.vin < args.inputs.length
|
|
61
|
+
? args.inputs[storageInput.vin]
|
|
62
|
+
: undefined;
|
|
63
|
+
inputs.push({ argsInput, storageInput });
|
|
64
|
+
}
|
|
65
|
+
inputs.sort((a, b) => a.storageInput.vin < b.storageInput.vin ? -1 : a.storageInput.vin === b.storageInput.vin ? 0 : 1);
|
|
66
|
+
const pendingStorageInputs = [];
|
|
67
|
+
//////////////
|
|
68
|
+
// Add INPUTS
|
|
69
|
+
/////////////
|
|
70
|
+
let totalChangeInputs = 0;
|
|
71
|
+
for (const { storageInput, argsInput } of inputs) {
|
|
72
|
+
// Two types of inputs are handled: user specified wth/without unlockingScript and storage specified using SABPPP template.
|
|
73
|
+
if (argsInput) {
|
|
74
|
+
// Type 1: User supplied input, with or without an explicit unlockingScript.
|
|
75
|
+
// If without, signAction must be used to provide the actual unlockScript.
|
|
76
|
+
const hasUnlock = typeof argsInput.unlockingScript === 'string';
|
|
77
|
+
const unlock = hasUnlock ? (0, utilityHelpers_1.asBsvSdkScript)(argsInput.unlockingScript) : new sdk_1.Script();
|
|
78
|
+
const sourceTransaction = args.isSignAction ? (_a = inputBeef === null || inputBeef === void 0 ? void 0 : inputBeef.findTxid(argsInput.outpoint.txid)) === null || _a === void 0 ? void 0 : _a.tx : undefined;
|
|
79
|
+
const inputToAdd = {
|
|
80
|
+
sourceTXID: argsInput.outpoint.txid,
|
|
81
|
+
sourceOutputIndex: argsInput.outpoint.vout,
|
|
82
|
+
// Include the source transaction for access to the outputs locking script and output satoshis for user side fee calculation.
|
|
83
|
+
// TODO: Make this conditional to improve performance when user can supply locking scripts themselves.
|
|
84
|
+
sourceTransaction,
|
|
85
|
+
unlockingScript: unlock,
|
|
86
|
+
sequence: argsInput.sequenceNumber
|
|
87
|
+
};
|
|
88
|
+
tx.addInput(inputToAdd);
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
// Type2: SABPPP protocol inputs which are signed using ScriptTemplateBRC29.
|
|
92
|
+
if (storageInput.type !== 'P2PKH')
|
|
93
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('type', `vin ${storageInput.vin}, "${storageInput.type}" is not a supported unlocking script type.`);
|
|
94
|
+
pendingStorageInputs.push({
|
|
95
|
+
vin: tx.inputs.length,
|
|
96
|
+
derivationPrefix: (0, utilityHelpers_1.verifyTruthy)(storageInput.derivationPrefix),
|
|
97
|
+
derivationSuffix: (0, utilityHelpers_1.verifyTruthy)(storageInput.derivationSuffix),
|
|
98
|
+
unlockerPubKey: storageInput.senderIdentityKey,
|
|
99
|
+
sourceSatoshis: storageInput.sourceSatoshis,
|
|
100
|
+
lockingScript: storageInput.sourceLockingScript
|
|
101
|
+
});
|
|
102
|
+
const inputToAdd = {
|
|
103
|
+
sourceTXID: storageInput.sourceTxid,
|
|
104
|
+
sourceOutputIndex: storageInput.sourceVout,
|
|
105
|
+
sourceTransaction: storageInput.sourceTransaction
|
|
106
|
+
? sdk_1.Transaction.fromBinary(storageInput.sourceTransaction)
|
|
107
|
+
: undefined,
|
|
108
|
+
unlockingScript: new sdk_1.Script(),
|
|
109
|
+
sequence: 0xffffffff
|
|
110
|
+
};
|
|
111
|
+
tx.addInput(inputToAdd);
|
|
112
|
+
totalChangeInputs += sdk_1.Validation.validateSatoshis(storageInput.sourceSatoshis, 'storageInput.sourceSatoshis');
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// The amount is the total of non-foreign inputs minus change outputs
|
|
116
|
+
// Note that the amount can be negative when we are redeeming more inputs than we are spending
|
|
117
|
+
const totalChangeOutputs = storageOutputs
|
|
118
|
+
.filter(x => x.purpose === 'change')
|
|
119
|
+
.reduce((acc, el) => acc + el.satoshis, 0);
|
|
120
|
+
const amount = totalChangeInputs - totalChangeOutputs;
|
|
121
|
+
return {
|
|
122
|
+
tx,
|
|
123
|
+
amount,
|
|
124
|
+
pdi: pendingStorageInputs,
|
|
125
|
+
log: ''
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Derive a change output locking script
|
|
130
|
+
*/
|
|
131
|
+
function makeChangeLock(out, dctr, args, changeKeys, wallet) {
|
|
132
|
+
const derivationPrefix = dctr.derivationPrefix;
|
|
133
|
+
const derivationSuffix = (0, utilityHelpers_1.verifyTruthy)(out.derivationSuffix);
|
|
134
|
+
const sabppp = new ScriptTemplateBRC29_1.ScriptTemplateBRC29({
|
|
135
|
+
derivationPrefix,
|
|
136
|
+
derivationSuffix,
|
|
137
|
+
keyDeriver: wallet.keyDeriver
|
|
138
|
+
});
|
|
139
|
+
const lockingScript = sabppp.lock(changeKeys.privateKey, changeKeys.publicKey);
|
|
140
|
+
return lockingScript;
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=buildSignableTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildSignableTransaction.js","sourceRoot":"","sources":["../../../../../src/signer/methods/buildSignableTransaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Beef, SignActionSpend, Transaction } from '@bsv/sdk';
|
|
2
|
+
import { PendingSignAction, Wallet } from '../../Wallet';
|
|
3
|
+
export declare function completeSignedTransaction(prior: PendingSignAction, spends: Record<number, SignActionSpend>, wallet: Wallet): Promise<Transaction>;
|
|
4
|
+
/**
|
|
5
|
+
* @param txid The TXID of a transaction in the beef for which all unlocking scripts must be valid.
|
|
6
|
+
* @param beef Must contain transactions for txid and all its inputs.
|
|
7
|
+
* @throws WERR_INVALID_PARAMETER if any unlocking script is invalid, if sourceTXID is invalid, if beef doesn't contain required transactions.
|
|
8
|
+
*/
|
|
9
|
+
export declare function verifyUnlockScripts(txid: string, beef: Beef): void;
|
|
10
|
+
//# sourceMappingURL=completeSignedTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"completeSignedTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/signer/methods/completeSignedTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAoB,eAAe,EAAS,WAAW,EAAE,MAAM,UAAU,CAAA;AACtF,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAMxD,wBAAsB,yBAAyB,CAC7C,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,EACvC,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,CAmDtB;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI,CA+ClE"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.completeSignedTransaction = completeSignedTransaction;
|
|
4
|
+
exports.verifyUnlockScripts = verifyUnlockScripts;
|
|
5
|
+
const sdk_1 = require("@bsv/sdk");
|
|
6
|
+
const WERR_errors_1 = require("../../sdk/WERR_errors");
|
|
7
|
+
const utilityHelpers_1 = require("../../utility/utilityHelpers");
|
|
8
|
+
const ScriptTemplateBRC29_1 = require("../../utility/ScriptTemplateBRC29");
|
|
9
|
+
const WalletError_1 = require("../../sdk/WalletError");
|
|
10
|
+
async function completeSignedTransaction(prior, spends, wallet) {
|
|
11
|
+
/////////////////////
|
|
12
|
+
// Insert the user provided unlocking scripts from "spends" arg
|
|
13
|
+
/////////////////////
|
|
14
|
+
for (const [key, spend] of Object.entries(spends)) {
|
|
15
|
+
const vin = Number(key);
|
|
16
|
+
const createInput = prior.args.inputs[vin];
|
|
17
|
+
const input = prior.tx.inputs[vin];
|
|
18
|
+
if (!createInput || !input || createInput.unlockingScript || !Number.isInteger(createInput.unlockingScriptLength))
|
|
19
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('args', `spend does not correspond to prior input with valid unlockingScriptLength.`);
|
|
20
|
+
if (spend.unlockingScript.length / 2 > createInput.unlockingScriptLength)
|
|
21
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('args', `spend unlockingScript length ${spend.unlockingScript.length} exceeds expected length ${createInput.unlockingScriptLength}`);
|
|
22
|
+
input.unlockingScript = (0, utilityHelpers_1.asBsvSdkScript)(spend.unlockingScript);
|
|
23
|
+
if (spend.sequenceNumber !== undefined)
|
|
24
|
+
input.sequence = spend.sequenceNumber;
|
|
25
|
+
}
|
|
26
|
+
const results = {
|
|
27
|
+
sdk: {}
|
|
28
|
+
};
|
|
29
|
+
/////////////////////
|
|
30
|
+
// Insert SABPPP unlock templates for wallet signed inputs
|
|
31
|
+
/////////////////////
|
|
32
|
+
for (const pdi of prior.pdi) {
|
|
33
|
+
const sabppp = new ScriptTemplateBRC29_1.ScriptTemplateBRC29({
|
|
34
|
+
derivationPrefix: pdi.derivationPrefix,
|
|
35
|
+
derivationSuffix: pdi.derivationSuffix,
|
|
36
|
+
keyDeriver: wallet.keyDeriver
|
|
37
|
+
});
|
|
38
|
+
const keys = wallet.getClientChangeKeyPair();
|
|
39
|
+
const lockerPrivKey = keys.privateKey;
|
|
40
|
+
const unlockerPubKey = pdi.unlockerPubKey || keys.publicKey;
|
|
41
|
+
const sourceSatoshis = pdi.sourceSatoshis;
|
|
42
|
+
const lockingScript = (0, utilityHelpers_1.asBsvSdkScript)(pdi.lockingScript);
|
|
43
|
+
const unlockTemplate = sabppp.unlock(lockerPrivKey, unlockerPubKey, sourceSatoshis, lockingScript);
|
|
44
|
+
const input = prior.tx.inputs[pdi.vin];
|
|
45
|
+
input.unlockingScriptTemplate = unlockTemplate;
|
|
46
|
+
}
|
|
47
|
+
/////////////////////
|
|
48
|
+
// Sign wallet signed inputs making transaction fully valid.
|
|
49
|
+
/////////////////////
|
|
50
|
+
await prior.tx.sign();
|
|
51
|
+
return prior.tx;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* @param txid The TXID of a transaction in the beef for which all unlocking scripts must be valid.
|
|
55
|
+
* @param beef Must contain transactions for txid and all its inputs.
|
|
56
|
+
* @throws WERR_INVALID_PARAMETER if any unlocking script is invalid, if sourceTXID is invalid, if beef doesn't contain required transactions.
|
|
57
|
+
*/
|
|
58
|
+
function verifyUnlockScripts(txid, beef) {
|
|
59
|
+
var _a, _b, _c, _d;
|
|
60
|
+
const tx = (_a = beef.findTxid(txid)) === null || _a === void 0 ? void 0 : _a.tx;
|
|
61
|
+
if (!tx)
|
|
62
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER(`txid`, `contained in beef, txid ${txid}`);
|
|
63
|
+
for (let i = 0; i < tx.inputs.length; i++) {
|
|
64
|
+
const input = tx.inputs[i];
|
|
65
|
+
if (!input.sourceTXID)
|
|
66
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER(`inputs[${i}].sourceTXID`, `valid`);
|
|
67
|
+
if (!input.unlockingScript)
|
|
68
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER(`inputs[${i}].unlockingScript`, `valid`);
|
|
69
|
+
input.sourceTransaction = (_b = beef.findTxid(input.sourceTXID)) === null || _b === void 0 ? void 0 : _b.tx;
|
|
70
|
+
if (!input.sourceTransaction) {
|
|
71
|
+
// The beef doesn't contain all the source transactions only if advanced features
|
|
72
|
+
// such as knownTxids are used.
|
|
73
|
+
// Skip unlock script checks.
|
|
74
|
+
return;
|
|
75
|
+
// throw new WERR_INVALID_PARAMETER(`inputs[${i}].sourceTXID`, `contained in beef`)
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
for (let i = 0; i < tx.inputs.length; i++) {
|
|
79
|
+
const input = tx.inputs[i];
|
|
80
|
+
const sourceOutput = input.sourceTransaction.outputs[input.sourceOutputIndex];
|
|
81
|
+
const otherInputs = tx.inputs.filter((_, idx) => idx !== i);
|
|
82
|
+
const spend = new sdk_1.Spend({
|
|
83
|
+
sourceTXID: input.sourceTXID,
|
|
84
|
+
sourceOutputIndex: input.sourceOutputIndex,
|
|
85
|
+
lockingScript: sourceOutput.lockingScript,
|
|
86
|
+
sourceSatoshis: (_c = sourceOutput.satoshis) !== null && _c !== void 0 ? _c : 0,
|
|
87
|
+
transactionVersion: tx.version,
|
|
88
|
+
otherInputs,
|
|
89
|
+
unlockingScript: input.unlockingScript,
|
|
90
|
+
inputSequence: (_d = input.sequence) !== null && _d !== void 0 ? _d : 0,
|
|
91
|
+
inputIndex: i,
|
|
92
|
+
outputs: tx.outputs,
|
|
93
|
+
lockTime: tx.lockTime
|
|
94
|
+
});
|
|
95
|
+
try {
|
|
96
|
+
const spendValid = spend.validate();
|
|
97
|
+
if (!spendValid)
|
|
98
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER(`inputs[${i}].unlockScript`, `valid`);
|
|
99
|
+
}
|
|
100
|
+
catch (eu) {
|
|
101
|
+
const e = WalletError_1.WalletError.fromUnknown(eu);
|
|
102
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER(`inputs[${i}].unlockScript`, `valid. ${e.message}`);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=completeSignedTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"completeSignedTransaction.js","sourceRoot":"","sources":["../../../../../src/signer/methods/completeSignedTransaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AtomicBEEF, CreateActionResult, OutpointString, SendWithResult, SignableTransaction, TXIDHexString, Validation } from '@bsv/sdk';
|
|
2
|
+
import { AuthId, ReviewActionResult, StorageProcessActionResults } from '../../sdk/WalletStorage.interfaces';
|
|
3
|
+
import { PendingSignAction, Wallet } from '../../Wallet';
|
|
4
|
+
export interface CreateActionResultX extends CreateActionResult {
|
|
5
|
+
txid?: TXIDHexString;
|
|
6
|
+
tx?: AtomicBEEF;
|
|
7
|
+
noSendChange?: OutpointString[];
|
|
8
|
+
sendWithResults?: SendWithResult[];
|
|
9
|
+
signableTransaction?: SignableTransaction;
|
|
10
|
+
notDelayedResults?: ReviewActionResult[];
|
|
11
|
+
}
|
|
12
|
+
export declare function createAction(wallet: Wallet, auth: AuthId, vargs: Validation.ValidCreateActionArgs): Promise<CreateActionResultX>;
|
|
13
|
+
export declare function processAction(prior: PendingSignAction | undefined, wallet: Wallet, auth: AuthId, vargs: Validation.ValidProcessActionArgs): Promise<StorageProcessActionResults>;
|
|
14
|
+
//# sourceMappingURL=createAction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createAction.d.ts","sourceRoot":"","sources":["../../../../../src/signer/methods/createAction.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EAEV,kBAAkB,EAClB,cAAc,EACd,cAAc,EACd,mBAAmB,EACnB,aAAa,EAGb,UAAU,EACX,MAAM,UAAU,CAAA;AAEjB,OAAO,EACL,MAAM,EACN,kBAAkB,EAElB,2BAA2B,EAC5B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAGxD,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAC7D,IAAI,CAAC,EAAE,aAAa,CAAA;IACpB,EAAE,CAAC,EAAE,UAAU,CAAA;IACf,YAAY,CAAC,EAAE,cAAc,EAAE,CAAA;IAC/B,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;IAClC,mBAAmB,CAAC,EAAE,mBAAmB,CAAA;IACzC,iBAAiB,CAAC,EAAE,kBAAkB,EAAE,CAAA;CACzC;AAED,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,UAAU,CAAC,qBAAqB,GACtC,OAAO,CAAC,mBAAmB,CAAC,CAuC9B;AAqED,wBAAsB,aAAa,CACjC,KAAK,EAAE,iBAAiB,GAAG,SAAS,EACpC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,UAAU,CAAC,sBAAsB,GACvC,OAAO,CAAC,2BAA2B,CAAC,CAetC"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createAction = createAction;
|
|
4
|
+
exports.processAction = processAction;
|
|
5
|
+
const sdk_1 = require("@bsv/sdk");
|
|
6
|
+
const buildSignableTransaction_1 = require("./buildSignableTransaction");
|
|
7
|
+
const completeSignedTransaction_1 = require("./completeSignedTransaction");
|
|
8
|
+
const WERR_errors_1 = require("../../sdk/WERR_errors");
|
|
9
|
+
async function createAction(wallet, auth, vargs) {
|
|
10
|
+
var _a;
|
|
11
|
+
const r = {};
|
|
12
|
+
const logger = vargs.logger;
|
|
13
|
+
let prior = undefined;
|
|
14
|
+
if (vargs.isNewTx || vargs.isTestWerrReviewActions) {
|
|
15
|
+
prior = await createNewTx(wallet, vargs);
|
|
16
|
+
logger === null || logger === void 0 ? void 0 : logger.log('created new transaction');
|
|
17
|
+
if (vargs.isSignAction) {
|
|
18
|
+
const r = makeSignableTransactionResult(prior, wallet, vargs);
|
|
19
|
+
logger === null || logger === void 0 ? void 0 : logger.log('created signable transaction result');
|
|
20
|
+
return r;
|
|
21
|
+
}
|
|
22
|
+
prior.tx = await (0, completeSignedTransaction_1.completeSignedTransaction)(prior, {}, wallet);
|
|
23
|
+
logger === null || logger === void 0 ? void 0 : logger.log('completed signed transaction');
|
|
24
|
+
r.txid = prior.tx.id('hex');
|
|
25
|
+
const beef = new sdk_1.Beef();
|
|
26
|
+
if (prior.dcr.inputBeef)
|
|
27
|
+
beef.mergeBeef(prior.dcr.inputBeef);
|
|
28
|
+
beef.mergeTransaction(prior.tx);
|
|
29
|
+
logger === null || logger === void 0 ? void 0 : logger.log('merged beef');
|
|
30
|
+
(0, completeSignedTransaction_1.verifyUnlockScripts)(r.txid, beef);
|
|
31
|
+
logger === null || logger === void 0 ? void 0 : logger.log('verified unlock scripts');
|
|
32
|
+
r.noSendChange = (_a = prior.dcr.noSendChangeOutputVouts) === null || _a === void 0 ? void 0 : _a.map(vout => `${r.txid}.${vout}`);
|
|
33
|
+
if (!vargs.options.returnTXIDOnly)
|
|
34
|
+
r.tx = beef.toBinaryAtomic(r.txid);
|
|
35
|
+
}
|
|
36
|
+
const { sendWithResults, notDelayedResults } = await processAction(prior, wallet, auth, vargs);
|
|
37
|
+
logger === null || logger === void 0 ? void 0 : logger.log('processed transaction');
|
|
38
|
+
r.sendWithResults = sendWithResults;
|
|
39
|
+
r.notDelayedResults = notDelayedResults;
|
|
40
|
+
return r;
|
|
41
|
+
}
|
|
42
|
+
async function createNewTx(wallet, vargs) {
|
|
43
|
+
const logger = vargs.logger;
|
|
44
|
+
const storageArgs = removeUnlockScripts(vargs);
|
|
45
|
+
const dcr = await wallet.storage.createAction(storageArgs);
|
|
46
|
+
const reference = dcr.reference;
|
|
47
|
+
const { tx, amount, pdi } = (0, buildSignableTransaction_1.buildSignableTransaction)(dcr, vargs, wallet);
|
|
48
|
+
logger === null || logger === void 0 ? void 0 : logger.log('built signable transaction');
|
|
49
|
+
const prior = { reference, dcr, args: vargs, amount, tx, pdi };
|
|
50
|
+
return prior;
|
|
51
|
+
}
|
|
52
|
+
function makeSignableTransactionResult(prior, wallet, args) {
|
|
53
|
+
var _a;
|
|
54
|
+
if (!prior.dcr.inputBeef)
|
|
55
|
+
throw new WERR_errors_1.WERR_INTERNAL('prior.dcr.inputBeef must be valid');
|
|
56
|
+
const txid = prior.tx.id('hex');
|
|
57
|
+
const r = {
|
|
58
|
+
noSendChange: args.isNoSend ? (_a = prior.dcr.noSendChangeOutputVouts) === null || _a === void 0 ? void 0 : _a.map(vout => `${txid}.${vout}`) : undefined,
|
|
59
|
+
signableTransaction: {
|
|
60
|
+
reference: prior.dcr.reference,
|
|
61
|
+
tx: makeSignableTransactionBeef(prior.tx, prior.dcr.inputBeef)
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
wallet.pendingSignActions[r.signableTransaction.reference] = prior;
|
|
65
|
+
return r;
|
|
66
|
+
}
|
|
67
|
+
function makeSignableTransactionBeef(tx, inputBEEF) {
|
|
68
|
+
// This is a special case beef for transaction signing.
|
|
69
|
+
// We only need the transaction being signed, and for each input, the raw source transaction.
|
|
70
|
+
const beef = new sdk_1.Beef();
|
|
71
|
+
for (const input of tx.inputs) {
|
|
72
|
+
if (!input.sourceTransaction)
|
|
73
|
+
throw new WERR_errors_1.WERR_INTERNAL('Every signableTransaction input must have a sourceTransaction');
|
|
74
|
+
beef.mergeRawTx(input.sourceTransaction.toBinary());
|
|
75
|
+
}
|
|
76
|
+
beef.mergeRawTx(tx.toBinary());
|
|
77
|
+
return beef.toBinaryAtomic(tx.id('hex'));
|
|
78
|
+
}
|
|
79
|
+
function removeUnlockScripts(args) {
|
|
80
|
+
let storageArgs = args;
|
|
81
|
+
if (!storageArgs.inputs.every(i => i.unlockingScript === undefined)) {
|
|
82
|
+
// Never send unlocking scripts to storage, all it needs is the script length.
|
|
83
|
+
storageArgs = { ...args, inputs: [] };
|
|
84
|
+
for (const i of args.inputs) {
|
|
85
|
+
const di = {
|
|
86
|
+
...i,
|
|
87
|
+
unlockingScriptLength: i.unlockingScript !== undefined ? i.unlockingScript.length : i.unlockingScriptLength
|
|
88
|
+
};
|
|
89
|
+
delete di.unlockingScript;
|
|
90
|
+
storageArgs.inputs.push(di);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return storageArgs;
|
|
94
|
+
}
|
|
95
|
+
async function processAction(prior, wallet, auth, vargs) {
|
|
96
|
+
const args = {
|
|
97
|
+
isNewTx: vargs.isNewTx,
|
|
98
|
+
isSendWith: vargs.isSendWith,
|
|
99
|
+
isNoSend: vargs.isNoSend,
|
|
100
|
+
isDelayed: vargs.isDelayed,
|
|
101
|
+
reference: prior ? prior.reference : undefined,
|
|
102
|
+
txid: prior ? prior.tx.id('hex') : undefined,
|
|
103
|
+
rawTx: prior ? prior.tx.toBinary() : undefined,
|
|
104
|
+
sendWith: vargs.isSendWith ? vargs.options.sendWith : [],
|
|
105
|
+
logger: vargs.logger
|
|
106
|
+
};
|
|
107
|
+
const r = await wallet.storage.processAction(args);
|
|
108
|
+
return r;
|
|
109
|
+
}
|
|
110
|
+
function makeDummyTransactionForOutputSatoshis(vout, satoshis) {
|
|
111
|
+
const tx = new sdk_1.Transaction();
|
|
112
|
+
for (let i = 0; i < vout; i++)
|
|
113
|
+
tx.addOutput({ lockingScript: new sdk_1.Script(), satoshis: 0 });
|
|
114
|
+
tx.addOutput({ lockingScript: new sdk_1.Script(), satoshis });
|
|
115
|
+
return tx;
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=createAction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createAction.js","sourceRoot":"","sources":["../../../../../src/signer/methods/createAction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { InternalizeActionArgs } from '@bsv/sdk';
|
|
2
|
+
import { Wallet } from '../../Wallet';
|
|
3
|
+
import { AuthId, StorageInternalizeActionResult } from '../../sdk/WalletStorage.interfaces';
|
|
4
|
+
/**
|
|
5
|
+
* Internalize Action allows a wallet to take ownership of outputs in a pre-existing transaction.
|
|
6
|
+
* The transaction may, or may not already be known to both the storage and user.
|
|
7
|
+
*
|
|
8
|
+
* Two types of outputs are handled: "wallet payments" and "basket insertions".
|
|
9
|
+
*
|
|
10
|
+
* A "basket insertion" output is considered a custom output and has no effect on the wallet's "balance".
|
|
11
|
+
*
|
|
12
|
+
* A "wallet payment" adds an outputs value to the wallet's change "balance". These outputs are assigned to the "default" basket.
|
|
13
|
+
*
|
|
14
|
+
* Processing starts with simple validation and then checks for a pre-existing transaction.
|
|
15
|
+
* If the transaction is already known to the user, then the outputs are reviewed against the existing outputs treatment,
|
|
16
|
+
* and merge rules are added to the arguments passed to the storage layer.
|
|
17
|
+
* The existing transaction must be in the 'unproven' or 'completed' status. Any other status is an error.
|
|
18
|
+
*
|
|
19
|
+
* When the transaction already exists, the description is updated. The isOutgoing sense is not changed.
|
|
20
|
+
*
|
|
21
|
+
* "basket insertion" Merge Rules:
|
|
22
|
+
* 1. The "default" basket may not be specified as the insertion basket.
|
|
23
|
+
* 2. A change output in the "default" basket may not be target of an insertion into a different basket.
|
|
24
|
+
* 3. These baskets do not affect the wallet's balance and are typed "custom".
|
|
25
|
+
*
|
|
26
|
+
* "wallet payment" Merge Rules:
|
|
27
|
+
* 1. Targetting an existing change "default" basket output results in a no-op. No error. No alterations made.
|
|
28
|
+
* 2. Targetting a previously "custom" non-change output converts it into a change output. This alters the transaction's `amount`, and the wallet balance.
|
|
29
|
+
*
|
|
30
|
+
*/
|
|
31
|
+
export declare function internalizeAction(wallet: Wallet, auth: AuthId, args: InternalizeActionArgs): Promise<StorageInternalizeActionResult>;
|
|
32
|
+
//# sourceMappingURL=internalizeAction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internalizeAction.d.ts","sourceRoot":"","sources":["../../../../../src/signer/methods/internalizeAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,qBAAqB,EAAwD,MAAM,UAAU,CAAA;AAC5G,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAA;AAG3F;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,qBAAqB,GAC1B,OAAO,CAAC,8BAA8B,CAAC,CAqEzC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.internalizeAction = internalizeAction;
|
|
4
|
+
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
const WERR_errors_1 = require("../../sdk/WERR_errors");
|
|
6
|
+
/**
|
|
7
|
+
* Internalize Action allows a wallet to take ownership of outputs in a pre-existing transaction.
|
|
8
|
+
* The transaction may, or may not already be known to both the storage and user.
|
|
9
|
+
*
|
|
10
|
+
* Two types of outputs are handled: "wallet payments" and "basket insertions".
|
|
11
|
+
*
|
|
12
|
+
* A "basket insertion" output is considered a custom output and has no effect on the wallet's "balance".
|
|
13
|
+
*
|
|
14
|
+
* A "wallet payment" adds an outputs value to the wallet's change "balance". These outputs are assigned to the "default" basket.
|
|
15
|
+
*
|
|
16
|
+
* Processing starts with simple validation and then checks for a pre-existing transaction.
|
|
17
|
+
* If the transaction is already known to the user, then the outputs are reviewed against the existing outputs treatment,
|
|
18
|
+
* and merge rules are added to the arguments passed to the storage layer.
|
|
19
|
+
* The existing transaction must be in the 'unproven' or 'completed' status. Any other status is an error.
|
|
20
|
+
*
|
|
21
|
+
* When the transaction already exists, the description is updated. The isOutgoing sense is not changed.
|
|
22
|
+
*
|
|
23
|
+
* "basket insertion" Merge Rules:
|
|
24
|
+
* 1. The "default" basket may not be specified as the insertion basket.
|
|
25
|
+
* 2. A change output in the "default" basket may not be target of an insertion into a different basket.
|
|
26
|
+
* 3. These baskets do not affect the wallet's balance and are typed "custom".
|
|
27
|
+
*
|
|
28
|
+
* "wallet payment" Merge Rules:
|
|
29
|
+
* 1. Targetting an existing change "default" basket output results in a no-op. No error. No alterations made.
|
|
30
|
+
* 2. Targetting a previously "custom" non-change output converts it into a change output. This alters the transaction's `amount`, and the wallet balance.
|
|
31
|
+
*
|
|
32
|
+
*/
|
|
33
|
+
async function internalizeAction(wallet, auth, args) {
|
|
34
|
+
const vargs = sdk_1.Validation.validateInternalizeActionArgs(args);
|
|
35
|
+
const { ab, tx, txid } = await validateAtomicBeef();
|
|
36
|
+
const brc29ProtocolID = [2, '3241645161d8'];
|
|
37
|
+
for (const o of vargs.outputs) {
|
|
38
|
+
if (o.outputIndex < 0 || o.outputIndex >= tx.outputs.length)
|
|
39
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('outputIndex', `a valid output index in range 0 to ${tx.outputs.length - 1}`);
|
|
40
|
+
switch (o.protocol) {
|
|
41
|
+
case 'basket insertion':
|
|
42
|
+
setupBasketInsertionForOutput(o, vargs);
|
|
43
|
+
break;
|
|
44
|
+
case 'wallet payment':
|
|
45
|
+
setupWalletPaymentForOutput(o, vargs);
|
|
46
|
+
break;
|
|
47
|
+
default:
|
|
48
|
+
throw new WERR_errors_1.WERR_INTERNAL(`unexpected protocol ${o.protocol}`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
const r = await wallet.storage.internalizeAction(args);
|
|
52
|
+
return r;
|
|
53
|
+
function setupWalletPaymentForOutput(o, dargs) {
|
|
54
|
+
const p = o.paymentRemittance;
|
|
55
|
+
const output = tx.outputs[o.outputIndex];
|
|
56
|
+
if (!p)
|
|
57
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('paymentRemittance', `valid for protocol ${o.protocol}`);
|
|
58
|
+
const keyID = `${p.derivationPrefix} ${p.derivationSuffix}`;
|
|
59
|
+
const privKey = wallet.keyDeriver.derivePrivateKey(brc29ProtocolID, keyID, p.senderIdentityKey);
|
|
60
|
+
const expectedLockScript = new sdk_1.P2PKH().lock(privKey.toAddress());
|
|
61
|
+
if (output.lockingScript.toHex() !== expectedLockScript.toHex())
|
|
62
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('paymentRemittance', `locked by script conforming to BRC-29`);
|
|
63
|
+
}
|
|
64
|
+
function setupBasketInsertionForOutput(o, dargs) {
|
|
65
|
+
/*
|
|
66
|
+
No additional validations...
|
|
67
|
+
*/
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Verifies that the `tx` argument passed to internalizeAction is a valid AtomicBEEF,
|
|
71
|
+
* and the proofs are valid according to the wallet's configured chainTracker.
|
|
72
|
+
* THIS DOES NOT GUARANTEE:
|
|
73
|
+
* 1. That the transaction has been broadcast. (Is known to the network).
|
|
74
|
+
* 2. That the proofs are for the same block as recorded in the wallet's configured storage in the event of a reorg.
|
|
75
|
+
*/
|
|
76
|
+
async function validateAtomicBeef() {
|
|
77
|
+
const ab = sdk_1.Beef.fromBinary(vargs.tx);
|
|
78
|
+
// TODO: Add support for known txids...which would speed up processing by avoiding a network call,
|
|
79
|
+
// unless a local chaintracker is used.
|
|
80
|
+
const txValid = await ab.verify(await wallet.getServices().getChainTracker(), false);
|
|
81
|
+
if (!txValid || !ab.atomicTxid) {
|
|
82
|
+
console.log(`internalizeAction beef is invalid: ${ab.toLogString()}`);
|
|
83
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('tx', 'valid AtomicBEEF');
|
|
84
|
+
}
|
|
85
|
+
const txid = ab.atomicTxid;
|
|
86
|
+
const btx = ab.findTxid(txid);
|
|
87
|
+
if (!btx)
|
|
88
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('tx', `valid AtomicBEEF with newest txid of ${txid}`);
|
|
89
|
+
const tx = btx.tx;
|
|
90
|
+
return { ab, tx, txid };
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=internalizeAction.js.map
|