@bopen-io/wallet-toolbox 1.7.18

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.
Files changed (390) hide show
  1. package/.claude/settings.local.json +10 -0
  2. package/.env.template +22 -0
  3. package/.github/ISSUE_TEMPLATE/bug_report.md +40 -0
  4. package/.github/ISSUE_TEMPLATE/discussion.md +24 -0
  5. package/.github/pull_request_template.md +22 -0
  6. package/.github/workflows/push.yaml +145 -0
  7. package/.prettierrc +10 -0
  8. package/CHANGELOG.md +280 -0
  9. package/CONTRIBUTING.md +89 -0
  10. package/README.md +43 -0
  11. package/docs/README.md +85 -0
  12. package/docs/client.md +19627 -0
  13. package/docs/monitor.md +953 -0
  14. package/docs/open-rpc/index.html +46 -0
  15. package/docs/services.md +6377 -0
  16. package/docs/setup.md +1268 -0
  17. package/docs/storage.md +5367 -0
  18. package/docs/wallet.md +19626 -0
  19. package/jest.config.ts +25 -0
  20. package/license.md +28 -0
  21. package/out/tsconfig.all.tsbuildinfo +1 -0
  22. package/package.json +63 -0
  23. package/src/CWIStyleWalletManager.ts +1999 -0
  24. package/src/Setup.ts +579 -0
  25. package/src/SetupClient.ts +322 -0
  26. package/src/SetupWallet.ts +108 -0
  27. package/src/SimpleWalletManager.ts +526 -0
  28. package/src/Wallet.ts +1169 -0
  29. package/src/WalletAuthenticationManager.ts +153 -0
  30. package/src/WalletLogger.ts +213 -0
  31. package/src/WalletPermissionsManager.ts +3660 -0
  32. package/src/WalletSettingsManager.ts +114 -0
  33. package/src/__tests/CWIStyleWalletManager.test.d.ts.map +1 -0
  34. package/src/__tests/CWIStyleWalletManager.test.js.map +1 -0
  35. package/src/__tests/CWIStyleWalletManager.test.ts +675 -0
  36. package/src/__tests/WalletPermissionsManager.callbacks.test.ts +323 -0
  37. package/src/__tests/WalletPermissionsManager.checks.test.ts +844 -0
  38. package/src/__tests/WalletPermissionsManager.encryption.test.ts +412 -0
  39. package/src/__tests/WalletPermissionsManager.fixtures.ts +307 -0
  40. package/src/__tests/WalletPermissionsManager.flows.test.ts +462 -0
  41. package/src/__tests/WalletPermissionsManager.initialization.test.ts +300 -0
  42. package/src/__tests/WalletPermissionsManager.pmodules.test.ts +798 -0
  43. package/src/__tests/WalletPermissionsManager.proxying.test.ts +724 -0
  44. package/src/__tests/WalletPermissionsManager.tokens.test.ts +503 -0
  45. package/src/index.all.ts +27 -0
  46. package/src/index.client.ts +25 -0
  47. package/src/index.mobile.ts +21 -0
  48. package/src/index.ts +1 -0
  49. package/src/monitor/Monitor.ts +412 -0
  50. package/src/monitor/MonitorDaemon.ts +188 -0
  51. package/src/monitor/README.md +3 -0
  52. package/src/monitor/__test/MonitorDaemon.man.test.ts +45 -0
  53. package/src/monitor/tasks/TaskCheckForProofs.ts +243 -0
  54. package/src/monitor/tasks/TaskCheckNoSends.ts +73 -0
  55. package/src/monitor/tasks/TaskClock.ts +33 -0
  56. package/src/monitor/tasks/TaskFailAbandoned.ts +54 -0
  57. package/src/monitor/tasks/TaskMonitorCallHistory.ts +26 -0
  58. package/src/monitor/tasks/TaskNewHeader.ts +93 -0
  59. package/src/monitor/tasks/TaskPurge.ts +68 -0
  60. package/src/monitor/tasks/TaskReorg.ts +89 -0
  61. package/src/monitor/tasks/TaskReviewStatus.ts +48 -0
  62. package/src/monitor/tasks/TaskSendWaiting.ts +122 -0
  63. package/src/monitor/tasks/TaskSyncWhenIdle.ts +26 -0
  64. package/src/monitor/tasks/TaskUnFail.ts +151 -0
  65. package/src/monitor/tasks/WalletMonitorTask.ts +47 -0
  66. package/src/sdk/CertOpsWallet.ts +18 -0
  67. package/src/sdk/PrivilegedKeyManager.ts +372 -0
  68. package/src/sdk/README.md +13 -0
  69. package/src/sdk/WERR_errors.ts +234 -0
  70. package/src/sdk/WalletError.ts +170 -0
  71. package/src/sdk/WalletErrorFromJson.ts +80 -0
  72. package/src/sdk/WalletServices.interfaces.ts +700 -0
  73. package/src/sdk/WalletSigner.interfaces.ts +11 -0
  74. package/src/sdk/WalletStorage.interfaces.ts +606 -0
  75. package/src/sdk/__test/CertificateLifeCycle.test.ts +131 -0
  76. package/src/sdk/__test/PrivilegedKeyManager.test.ts +738 -0
  77. package/src/sdk/__test/WalletError.test.ts +318 -0
  78. package/src/sdk/__test/validationHelpers.test.ts +21 -0
  79. package/src/sdk/index.ts +10 -0
  80. package/src/sdk/types.ts +226 -0
  81. package/src/services/README.md +11 -0
  82. package/src/services/ServiceCollection.ts +248 -0
  83. package/src/services/Services.ts +603 -0
  84. package/src/services/__tests/ARC.man.test.ts +123 -0
  85. package/src/services/__tests/ARC.timeout.man.test.ts +79 -0
  86. package/src/services/__tests/ArcGorillaPool.man.test.ts +108 -0
  87. package/src/services/__tests/arcServices.test.ts +8 -0
  88. package/src/services/__tests/bitrails.test.ts +56 -0
  89. package/src/services/__tests/getMerklePath.test.ts +15 -0
  90. package/src/services/__tests/getRawTx.test.ts +13 -0
  91. package/src/services/__tests/postBeef.test.ts +104 -0
  92. package/src/services/__tests/verifyBeef.test.ts +50 -0
  93. package/src/services/chaintracker/BHServiceClient.ts +212 -0
  94. package/src/services/chaintracker/ChaintracksChainTracker.ts +71 -0
  95. package/src/services/chaintracker/__tests/ChaintracksChainTracker.test.ts +33 -0
  96. package/src/services/chaintracker/__tests/ChaintracksServiceClient.test.ts +29 -0
  97. package/src/services/chaintracker/chaintracks/Api/BlockHeaderApi.ts +72 -0
  98. package/src/services/chaintracker/chaintracks/Api/BulkIngestorApi.ts +83 -0
  99. package/src/services/chaintracker/chaintracks/Api/BulkStorageApi.ts +92 -0
  100. package/src/services/chaintracker/chaintracks/Api/ChaintracksApi.ts +64 -0
  101. package/src/services/chaintracker/chaintracks/Api/ChaintracksClientApi.ts +189 -0
  102. package/src/services/chaintracker/chaintracks/Api/ChaintracksFetchApi.ts +18 -0
  103. package/src/services/chaintracker/chaintracks/Api/ChaintracksFsApi.ts +58 -0
  104. package/src/services/chaintracker/chaintracks/Api/ChaintracksStorageApi.ts +386 -0
  105. package/src/services/chaintracker/chaintracks/Api/LiveIngestorApi.ts +25 -0
  106. package/src/services/chaintracker/chaintracks/Chaintracks.ts +609 -0
  107. package/src/services/chaintracker/chaintracks/ChaintracksService.ts +199 -0
  108. package/src/services/chaintracker/chaintracks/ChaintracksServiceClient.ts +154 -0
  109. package/src/services/chaintracker/chaintracks/Ingest/BulkIngestorBase.ts +176 -0
  110. package/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDN.ts +174 -0
  111. package/src/services/chaintracker/chaintracks/Ingest/BulkIngestorCDNBabbage.ts +18 -0
  112. package/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainCdn.ts +113 -0
  113. package/src/services/chaintracker/chaintracks/Ingest/BulkIngestorWhatsOnChainWs.ts +81 -0
  114. package/src/services/chaintracker/chaintracks/Ingest/LiveIngestorBase.ts +86 -0
  115. package/src/services/chaintracker/chaintracks/Ingest/LiveIngestorTeranodeP2P.ts +59 -0
  116. package/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainPoll.ts +104 -0
  117. package/src/services/chaintracker/chaintracks/Ingest/LiveIngestorWhatsOnChainWs.ts +66 -0
  118. package/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainIngestorWs.ts +566 -0
  119. package/src/services/chaintracker/chaintracks/Ingest/WhatsOnChainServices.ts +219 -0
  120. package/src/services/chaintracker/chaintracks/Ingest/__tests/BulkIngestorCDNBabbage.test.ts +54 -0
  121. package/src/services/chaintracker/chaintracks/Ingest/__tests/LiveIngestorWhatsOnChainPoll.test.ts +33 -0
  122. package/src/services/chaintracker/chaintracks/Ingest/__tests/WhatsOnChainServices.test.ts +124 -0
  123. package/src/services/chaintracker/chaintracks/Storage/BulkStorageBase.ts +92 -0
  124. package/src/services/chaintracker/chaintracks/Storage/ChaintracksKnexMigrations.ts +104 -0
  125. package/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageBase.ts +382 -0
  126. package/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageIdb.ts +574 -0
  127. package/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageKnex.ts +438 -0
  128. package/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageMemory.ts +29 -0
  129. package/src/services/chaintracker/chaintracks/Storage/ChaintracksStorageNoDb.ts +304 -0
  130. package/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageIdb.test.ts +102 -0
  131. package/src/services/chaintracker/chaintracks/Storage/__tests/ChaintracksStorageKnex.test.ts +45 -0
  132. package/src/services/chaintracker/chaintracks/__tests/Chaintracks.test.ts +77 -0
  133. package/src/services/chaintracker/chaintracks/__tests/ChaintracksClientApi.test.ts +192 -0
  134. package/src/services/chaintracker/chaintracks/__tests/LocalCdnServer.ts +75 -0
  135. package/src/services/chaintracker/chaintracks/__tests/createIdbChaintracks.test.ts +62 -0
  136. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest349/mainNetBlockHeaders.json +1 -0
  137. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest349/mainNet_0.headers +0 -0
  138. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest349/mainNet_1.headers +0 -0
  139. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest349/mainNet_2.headers +0 -0
  140. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest349/mainNet_3.headers +0 -0
  141. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest379/mainNetBlockHeaders.json +1 -0
  142. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest379/mainNet_0.headers +0 -0
  143. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest379/mainNet_1.headers +0 -0
  144. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest379/mainNet_2.headers +0 -0
  145. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest379/mainNet_3.headers +0 -0
  146. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest399/mainNetBlockHeaders.json +1 -0
  147. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest399/mainNet_0.headers +0 -0
  148. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest399/mainNet_1.headers +0 -0
  149. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest399/mainNet_2.headers +0 -0
  150. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest399/mainNet_3.headers +0 -0
  151. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNetBlockHeaders.json +1 -0
  152. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNet_0.headers +0 -0
  153. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNet_1.headers +0 -0
  154. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNet_2.headers +0 -0
  155. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNet_3.headers +0 -0
  156. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest402/mainNet_4.headers +0 -0
  157. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNetBlockHeaders.json +1 -0
  158. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNet_0.headers +0 -0
  159. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNet_1.headers +0 -0
  160. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNet_2.headers +0 -0
  161. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNet_3.headers +0 -0
  162. package/src/services/chaintracker/chaintracks/__tests/data/cdnTest499/mainNet_4.headers +0 -0
  163. package/src/services/chaintracker/chaintracks/createDefaultIdbChaintracksOptions.ts +92 -0
  164. package/src/services/chaintracker/chaintracks/createDefaultKnexChaintracksOptions.ts +111 -0
  165. package/src/services/chaintracker/chaintracks/createDefaultNoDbChaintracksOptions.ts +91 -0
  166. package/src/services/chaintracker/chaintracks/createIdbChaintracks.ts +60 -0
  167. package/src/services/chaintracker/chaintracks/createKnexChaintracks.ts +65 -0
  168. package/src/services/chaintracker/chaintracks/createNoDbChaintracks.ts +60 -0
  169. package/src/services/chaintracker/chaintracks/index.all.ts +12 -0
  170. package/src/services/chaintracker/chaintracks/index.client.ts +4 -0
  171. package/src/services/chaintracker/chaintracks/index.mobile.ts +37 -0
  172. package/src/services/chaintracker/chaintracks/util/BulkFileDataManager.ts +975 -0
  173. package/src/services/chaintracker/chaintracks/util/BulkFileDataReader.ts +60 -0
  174. package/src/services/chaintracker/chaintracks/util/BulkFilesReader.ts +336 -0
  175. package/src/services/chaintracker/chaintracks/util/BulkHeaderFile.ts +247 -0
  176. package/src/services/chaintracker/chaintracks/util/ChaintracksFetch.ts +69 -0
  177. package/src/services/chaintracker/chaintracks/util/ChaintracksFs.ts +141 -0
  178. package/src/services/chaintracker/chaintracks/util/HeightRange.ts +153 -0
  179. package/src/services/chaintracker/chaintracks/util/SingleWriterMultiReaderLock.ts +76 -0
  180. package/src/services/chaintracker/chaintracks/util/__tests/BulkFileDataManager.test.ts +304 -0
  181. package/src/services/chaintracker/chaintracks/util/__tests/ChaintracksFetch.test.ts +60 -0
  182. package/src/services/chaintracker/chaintracks/util/__tests/HeightRange.test.ts +67 -0
  183. package/src/services/chaintracker/chaintracks/util/__tests/SingleWriterMultiReaderLock.test.ts +49 -0
  184. package/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.ts +573 -0
  185. package/src/services/chaintracker/chaintracks/util/dirtyHashes.ts +29 -0
  186. package/src/services/chaintracker/chaintracks/util/validBulkHeaderFilesByFileHash.ts +432 -0
  187. package/src/services/chaintracker/index.all.ts +4 -0
  188. package/src/services/chaintracker/index.client.ts +4 -0
  189. package/src/services/chaintracker/index.mobile.ts +4 -0
  190. package/src/services/createDefaultWalletServicesOptions.ts +77 -0
  191. package/src/services/index.ts +1 -0
  192. package/src/services/processingErrors/arcSuccessError.json +76 -0
  193. package/src/services/providers/ARC.ts +350 -0
  194. package/src/services/providers/Bitails.ts +256 -0
  195. package/src/services/providers/SdkWhatsOnChain.ts +83 -0
  196. package/src/services/providers/WhatsOnChain.ts +883 -0
  197. package/src/services/providers/__tests/WhatsOnChain.test.ts +242 -0
  198. package/src/services/providers/__tests/exchangeRates.test.ts +18 -0
  199. package/src/services/providers/exchangeRates.ts +265 -0
  200. package/src/services/providers/getBeefForTxid.ts +369 -0
  201. package/src/signer/README.md +5 -0
  202. package/src/signer/WalletSigner.ts +17 -0
  203. package/src/signer/methods/acquireDirectCertificate.ts +52 -0
  204. package/src/signer/methods/buildSignableTransaction.ts +183 -0
  205. package/src/signer/methods/completeSignedTransaction.ts +117 -0
  206. package/src/signer/methods/createAction.ts +172 -0
  207. package/src/signer/methods/internalizeAction.ts +106 -0
  208. package/src/signer/methods/proveCertificate.ts +43 -0
  209. package/src/signer/methods/signAction.ts +54 -0
  210. package/src/storage/README.md +14 -0
  211. package/src/storage/StorageIdb.ts +2304 -0
  212. package/src/storage/StorageKnex.ts +1425 -0
  213. package/src/storage/StorageProvider.ts +810 -0
  214. package/src/storage/StorageReader.ts +194 -0
  215. package/src/storage/StorageReaderWriter.ts +432 -0
  216. package/src/storage/StorageSyncReader.ts +34 -0
  217. package/src/storage/WalletStorageManager.ts +943 -0
  218. package/src/storage/__test/StorageIdb.test.ts +43 -0
  219. package/src/storage/__test/WalletStorageManager.test.ts +275 -0
  220. package/src/storage/__test/adminStats.man.test.ts +89 -0
  221. package/src/storage/__test/getBeefForTransaction.test.ts +385 -0
  222. package/src/storage/index.all.ts +11 -0
  223. package/src/storage/index.client.ts +7 -0
  224. package/src/storage/index.mobile.ts +6 -0
  225. package/src/storage/methods/ListActionsSpecOp.ts +70 -0
  226. package/src/storage/methods/ListOutputsSpecOp.ts +129 -0
  227. package/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.ts +1057 -0
  228. package/src/storage/methods/__test/GenerateChange/randomValsUsed1.ts +20 -0
  229. package/src/storage/methods/__test/offsetKey.test.ts +274 -0
  230. package/src/storage/methods/attemptToPostReqsToNetwork.ts +389 -0
  231. package/src/storage/methods/createAction.ts +947 -0
  232. package/src/storage/methods/generateChange.ts +556 -0
  233. package/src/storage/methods/getBeefForTransaction.ts +139 -0
  234. package/src/storage/methods/getSyncChunk.ts +293 -0
  235. package/src/storage/methods/internalizeAction.ts +562 -0
  236. package/src/storage/methods/listActionsIdb.ts +183 -0
  237. package/src/storage/methods/listActionsKnex.ts +226 -0
  238. package/src/storage/methods/listCertificates.ts +73 -0
  239. package/src/storage/methods/listOutputsIdb.ts +203 -0
  240. package/src/storage/methods/listOutputsKnex.ts +263 -0
  241. package/src/storage/methods/offsetKey.ts +89 -0
  242. package/src/storage/methods/processAction.ts +420 -0
  243. package/src/storage/methods/purgeData.ts +251 -0
  244. package/src/storage/methods/purgeDataIdb.ts +10 -0
  245. package/src/storage/methods/reviewStatus.ts +101 -0
  246. package/src/storage/methods/reviewStatusIdb.ts +43 -0
  247. package/src/storage/methods/utils.Buffer.ts +33 -0
  248. package/src/storage/methods/utils.ts +56 -0
  249. package/src/storage/remoting/StorageClient.ts +567 -0
  250. package/src/storage/remoting/StorageMobile.ts +544 -0
  251. package/src/storage/remoting/StorageServer.ts +291 -0
  252. package/src/storage/remoting/__test/StorageClient.test.ts +113 -0
  253. package/src/storage/schema/KnexMigrations.ts +489 -0
  254. package/src/storage/schema/StorageIdbSchema.ts +150 -0
  255. package/src/storage/schema/entities/EntityBase.ts +210 -0
  256. package/src/storage/schema/entities/EntityCertificate.ts +188 -0
  257. package/src/storage/schema/entities/EntityCertificateField.ts +136 -0
  258. package/src/storage/schema/entities/EntityCommission.ts +148 -0
  259. package/src/storage/schema/entities/EntityOutput.ts +290 -0
  260. package/src/storage/schema/entities/EntityOutputBasket.ts +153 -0
  261. package/src/storage/schema/entities/EntityOutputTag.ts +121 -0
  262. package/src/storage/schema/entities/EntityOutputTagMap.ts +123 -0
  263. package/src/storage/schema/entities/EntityProvenTx.ts +319 -0
  264. package/src/storage/schema/entities/EntityProvenTxReq.ts +580 -0
  265. package/src/storage/schema/entities/EntitySyncState.ts +389 -0
  266. package/src/storage/schema/entities/EntityTransaction.ts +306 -0
  267. package/src/storage/schema/entities/EntityTxLabel.ts +121 -0
  268. package/src/storage/schema/entities/EntityTxLabelMap.ts +123 -0
  269. package/src/storage/schema/entities/EntityUser.ts +112 -0
  270. package/src/storage/schema/entities/MergeEntity.ts +73 -0
  271. package/src/storage/schema/entities/__tests/CertificateFieldTests.test.ts +353 -0
  272. package/src/storage/schema/entities/__tests/CertificateTests.test.ts +354 -0
  273. package/src/storage/schema/entities/__tests/CommissionTests.test.ts +371 -0
  274. package/src/storage/schema/entities/__tests/OutputBasketTests.test.ts +278 -0
  275. package/src/storage/schema/entities/__tests/OutputTagMapTests.test.ts +242 -0
  276. package/src/storage/schema/entities/__tests/OutputTagTests.test.ts +288 -0
  277. package/src/storage/schema/entities/__tests/OutputTests.test.ts +464 -0
  278. package/src/storage/schema/entities/__tests/ProvenTxReqTests.test.ts +340 -0
  279. package/src/storage/schema/entities/__tests/ProvenTxTests.test.ts +504 -0
  280. package/src/storage/schema/entities/__tests/SyncStateTests.test.ts +288 -0
  281. package/src/storage/schema/entities/__tests/TransactionTests.test.ts +604 -0
  282. package/src/storage/schema/entities/__tests/TxLabelMapTests.test.ts +361 -0
  283. package/src/storage/schema/entities/__tests/TxLabelTests.test.ts +198 -0
  284. package/src/storage/schema/entities/__tests/stampLogTests.test.ts +90 -0
  285. package/src/storage/schema/entities/__tests/usersTests.test.ts +340 -0
  286. package/src/storage/schema/entities/index.ts +16 -0
  287. package/src/storage/schema/tables/TableCertificate.ts +21 -0
  288. package/src/storage/schema/tables/TableCertificateField.ts +12 -0
  289. package/src/storage/schema/tables/TableCommission.ts +13 -0
  290. package/src/storage/schema/tables/TableMonitorEvent.ts +9 -0
  291. package/src/storage/schema/tables/TableOutput.ts +64 -0
  292. package/src/storage/schema/tables/TableOutputBasket.ts +12 -0
  293. package/src/storage/schema/tables/TableOutputTag.ts +10 -0
  294. package/src/storage/schema/tables/TableOutputTagMap.ts +9 -0
  295. package/src/storage/schema/tables/TableProvenTx.ts +14 -0
  296. package/src/storage/schema/tables/TableProvenTxReq.ts +65 -0
  297. package/src/storage/schema/tables/TableSettings.ts +17 -0
  298. package/src/storage/schema/tables/TableSyncState.ts +18 -0
  299. package/src/storage/schema/tables/TableTransaction.ts +54 -0
  300. package/src/storage/schema/tables/TableTxLabel.ts +10 -0
  301. package/src/storage/schema/tables/TableTxLabelMap.ts +9 -0
  302. package/src/storage/schema/tables/TableUser.ts +16 -0
  303. package/src/storage/schema/tables/index.ts +16 -0
  304. package/src/storage/sync/StorageMySQLDojoReader.ts +696 -0
  305. package/src/storage/sync/index.ts +1 -0
  306. package/src/utility/Format.ts +133 -0
  307. package/src/utility/README.md +3 -0
  308. package/src/utility/ReaderUint8Array.ts +187 -0
  309. package/src/utility/ScriptTemplateBRC29.ts +73 -0
  310. package/src/utility/__tests/utilityHelpers.noBuffer.test.ts +109 -0
  311. package/src/utility/aggregateResults.ts +68 -0
  312. package/src/utility/identityUtils.ts +159 -0
  313. package/src/utility/index.all.ts +7 -0
  314. package/src/utility/index.client.ts +7 -0
  315. package/src/utility/parseTxScriptOffsets.ts +29 -0
  316. package/src/utility/stampLog.ts +69 -0
  317. package/src/utility/tscProofToMerklePath.ts +48 -0
  318. package/src/utility/utilityHelpers.buffer.ts +34 -0
  319. package/src/utility/utilityHelpers.noBuffer.ts +60 -0
  320. package/src/utility/utilityHelpers.ts +275 -0
  321. package/src/wab-client/WABClient.ts +94 -0
  322. package/src/wab-client/__tests/WABClient.man.test.ts +59 -0
  323. package/src/wab-client/auth-method-interactors/AuthMethodInteractor.ts +47 -0
  324. package/src/wab-client/auth-method-interactors/DevConsoleInteractor.ts +73 -0
  325. package/src/wab-client/auth-method-interactors/PersonaIDInteractor.ts +35 -0
  326. package/src/wab-client/auth-method-interactors/TwilioPhoneInteractor.ts +72 -0
  327. package/syncVersions.js +71 -0
  328. package/test/Wallet/StorageClient/storageClient.man.test.ts +75 -0
  329. package/test/Wallet/action/abortAction.test.ts +47 -0
  330. package/test/Wallet/action/createAction.test.ts +299 -0
  331. package/test/Wallet/action/createAction2.test.ts +1273 -0
  332. package/test/Wallet/action/createActionToGenerateBeefs.man.test.ts +293 -0
  333. package/test/Wallet/action/internalizeAction.a.test.ts +286 -0
  334. package/test/Wallet/action/internalizeAction.test.ts +682 -0
  335. package/test/Wallet/action/relinquishOutput.test.ts +37 -0
  336. package/test/Wallet/certificate/acquireCertificate.test.ts +298 -0
  337. package/test/Wallet/certificate/listCertificates.test.ts +346 -0
  338. package/test/Wallet/construct/Wallet.constructor.test.ts +57 -0
  339. package/test/Wallet/get/getHeaderForHeight.test.ts +82 -0
  340. package/test/Wallet/get/getHeight.test.ts +52 -0
  341. package/test/Wallet/get/getKnownTxids.test.ts +86 -0
  342. package/test/Wallet/get/getNetwork.test.ts +27 -0
  343. package/test/Wallet/get/getVersion.test.ts +27 -0
  344. package/test/Wallet/list/listActions.test.ts +279 -0
  345. package/test/Wallet/list/listActions2.test.ts +1381 -0
  346. package/test/Wallet/list/listCertificates.test.ts +118 -0
  347. package/test/Wallet/list/listOutputs.test.ts +447 -0
  348. package/test/Wallet/live/walletLive.man.test.ts +521 -0
  349. package/test/Wallet/local/localWallet.man.test.ts +93 -0
  350. package/test/Wallet/local/localWallet2.man.test.ts +277 -0
  351. package/test/Wallet/signAction/mountaintop.man.test.ts +130 -0
  352. package/test/Wallet/specOps/specOps.man.test.ts +220 -0
  353. package/test/Wallet/support/janitor.man.test.ts +40 -0
  354. package/test/Wallet/support/operations.man.test.ts +407 -0
  355. package/test/Wallet/support/reqErrorReview.2025.05.06.man.test.ts +347 -0
  356. package/test/Wallet/sync/Wallet.sync.test.ts +215 -0
  357. package/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.ts +203 -0
  358. package/test/Wallet/sync/setActive.test.ts +170 -0
  359. package/test/WalletClient/LocalKVStore.man.test.ts +114 -0
  360. package/test/WalletClient/WERR.man.test.ts +35 -0
  361. package/test/bsv-ts-sdk/LocalKVStore.test.ts +102 -0
  362. package/test/checkDB.ts +57 -0
  363. package/test/checkdb +0 -0
  364. package/test/examples/backup.man.test.ts +59 -0
  365. package/test/examples/pushdrop.test.ts +282 -0
  366. package/test/monitor/Monitor.test.ts +620 -0
  367. package/test/services/Services.test.ts +263 -0
  368. package/test/storage/KnexMigrations.test.ts +86 -0
  369. package/test/storage/StorageMySQLDojoReader.man.test.ts +60 -0
  370. package/test/storage/count.test.ts +177 -0
  371. package/test/storage/find.test.ts +195 -0
  372. package/test/storage/findLegacy.test.ts +67 -0
  373. package/test/storage/idb/allocateChange.test.ts +251 -0
  374. package/test/storage/idb/count.test.ts +158 -0
  375. package/test/storage/idb/find.test.ts +177 -0
  376. package/test/storage/idb/idbSpeed.test.ts +36 -0
  377. package/test/storage/idb/insert.test.ts +268 -0
  378. package/test/storage/idb/transactionAbort.test.ts +108 -0
  379. package/test/storage/idb/update.test.ts +999 -0
  380. package/test/storage/insert.test.ts +278 -0
  381. package/test/storage/update.test.ts +1021 -0
  382. package/test/storage/update2.test.ts +897 -0
  383. package/test/utils/TestUtilsWalletStorage.ts +2526 -0
  384. package/test/utils/localWalletMethods.ts +363 -0
  385. package/test/utils/removeFailedFromDatabase.sql +17 -0
  386. package/ts2md.json +44 -0
  387. package/tsconfig.all.json +31 -0
  388. package/tsconfig.client.json +29 -0
  389. package/tsconfig.json +17 -0
  390. package/tsconfig.mobile.json +28 -0
@@ -0,0 +1,57 @@
1
+ import { sdk } from '../../../src/index.client'
2
+ import { _tu, TestSetup1Wallet } from '../../utils/TestUtilsWalletStorage'
3
+
4
+ describe('Wallet constructor tests', () => {
5
+ jest.setTimeout(99999999)
6
+
7
+ const chain: sdk.Chain = 'test'
8
+ const ctxs: TestSetup1Wallet[] = []
9
+ const env = _tu.getEnv(chain)
10
+
11
+ beforeAll(async () => {
12
+ if (env.runMySQL) {
13
+ ctxs.push(
14
+ await _tu.createMySQLTestSetup1Wallet({
15
+ databaseName: 'walletConstruct',
16
+ chain,
17
+ rootKeyHex: '1'.repeat(64)
18
+ })
19
+ )
20
+ }
21
+ ctxs.push(
22
+ await _tu.createSQLiteTestSetup1Wallet({
23
+ databaseName: 'walletConstruct',
24
+ chain,
25
+ rootKeyHex: '2'.repeat(64)
26
+ })
27
+ )
28
+ })
29
+
30
+ afterAll(async () => {
31
+ for (const ctx of ctxs) {
32
+ await ctx.storage.destroy()
33
+ }
34
+ })
35
+
36
+ test('0', async () => {
37
+ for (const { activeStorage: storage, userId, wallet } of ctxs) {
38
+ {
39
+ const labels = await storage.findTxLabels({ partial: { userId } })
40
+ const label = labels[0].label
41
+ const r = await wallet.listActions({
42
+ labels: [label]
43
+ })
44
+ expect(r.totalActions).toBe(1)
45
+ }
46
+
47
+ {
48
+ const baskets = await storage.findOutputBaskets({ partial: { userId } })
49
+ const basket = baskets[0].name
50
+ const r = await wallet.listOutputs({
51
+ basket
52
+ })
53
+ expect(r.totalOutputs).toBe(1)
54
+ }
55
+ }
56
+ })
57
+ })
@@ -0,0 +1,82 @@
1
+ import { Utils } from '@bsv/sdk'
2
+ import {
3
+ blockHash,
4
+ deserializeBaseBlockHeader
5
+ } from '../../../src/services/chaintracker/chaintracks/util/blockHeaderUtilities'
6
+ import { _tu, TestWalletNoSetup } from '../../utils/TestUtilsWalletStorage'
7
+
8
+ const includeTestChaintracks = false
9
+
10
+ describe('getHeaderForHeight tests', () => {
11
+ jest.setTimeout(99999999)
12
+
13
+ const env = _tu.getEnv('test')
14
+ const ctxs: TestWalletNoSetup[] = []
15
+
16
+ beforeAll(async () => {
17
+ if (includeTestChaintracks) {
18
+ if (env.runMySQL) ctxs.push(await _tu.createLegacyWalletMySQLCopy('getHeaderForHeightTests'))
19
+ ctxs.push(await _tu.createLegacyWalletSQLiteCopy('getHeaderForHeightTests'))
20
+ }
21
+ })
22
+
23
+ afterAll(async () => {
24
+ for (const ctx of ctxs) {
25
+ await ctx.storage.destroy()
26
+ }
27
+ })
28
+
29
+ test('0 invalid params', async () => {
30
+ for (const { wallet } of ctxs) {
31
+ try {
32
+ await wallet.getHeaderForHeight({ height: -1 })
33
+ throw new Error('Expected error was not thrown')
34
+ } catch (e) {
35
+ const errorMessage = typeof e === 'object' && e !== null && 'message' in e ? (e as Error).message : String(e)
36
+ expect(errorMessage).toMatch(/Height -1 must be a non-negative integer/i)
37
+ }
38
+ }
39
+ })
40
+
41
+ test('1 valid block height', async () => {
42
+ for (const { wallet } of ctxs) {
43
+ // Query an existing valid block height
44
+ const height = 1 // Ensure this height exists in the test database
45
+ const result = await wallet.getHeaderForHeight({ height })
46
+ const headerHex = result.header
47
+ const headerA = Utils.toArray(headerHex, 'hex')
48
+ const hash = blockHash(headerA)
49
+ expect(hash).toBe('00000000b873e79784647a6c82962c70d228557d24a747ea4d1b8bbe878e1206')
50
+ const header = deserializeBaseBlockHeader(headerA)
51
+
52
+ expect(result).toHaveProperty('header')
53
+ expect(typeof result.header).toBe('string')
54
+ expect(result.header).not.toBe('')
55
+ }
56
+ })
57
+
58
+ test('2 unexpected service errors', async () => {
59
+ for (const { wallet } of ctxs) {
60
+ try {
61
+ // Query a height that doesn't exist or triggers an unexpected error
62
+ const invalidHeight = 999999
63
+ await wallet.getHeaderForHeight({ height: invalidHeight })
64
+ throw new Error('Expected error was not thrown')
65
+ } catch (e) {
66
+ const errorMessage = typeof e === 'object' && e !== null && 'message' in e ? (e as Error).message : String(e)
67
+ expect(errorMessage).toMatch(/error|not found/i)
68
+ }
69
+ }
70
+ })
71
+
72
+ test('3 valid block height always returns a header', async () => {
73
+ for (const { wallet } of ctxs) {
74
+ const height = 9999
75
+ const result = await wallet.getHeaderForHeight({ height })
76
+
77
+ expect(result).toHaveProperty('header')
78
+ expect(typeof result.header).toBe('string')
79
+ expect(result.header).not.toBe('')
80
+ }
81
+ })
82
+ })
@@ -0,0 +1,52 @@
1
+ import { _tu, expectToThrowWERR } from '../../utils/TestUtilsWalletStorage'
2
+ import { sdk } from '../../../src/index.client'
3
+
4
+ const includeTestChaintracks = false
5
+
6
+ describe('getHeight tests', () => {
7
+ jest.setTimeout(99999999)
8
+
9
+ const ctxs: any[] = []
10
+ const env = _tu.getEnv('test')
11
+
12
+ beforeAll(async () => {
13
+ if (includeTestChaintracks) {
14
+ ctxs.push(await _tu.createSQLiteTestWallet({ databaseName: 'getHeightTestsSQLite' }))
15
+ if (env.runMySQL) {
16
+ ctxs.push(await _tu.createMySQLTestWallet({ databaseName: 'getHeightTestsMySQL' }))
17
+ }
18
+ }
19
+ })
20
+
21
+ afterAll(async () => {
22
+ for (const ctx of ctxs) {
23
+ await ctx.storage.destroy()
24
+ }
25
+ })
26
+
27
+ test('0 valid height', async () => {
28
+ for (const { wallet } of ctxs) {
29
+ const result = await wallet.getHeight({})
30
+
31
+ // Validate the height (assuming it's a positive integer)
32
+ expect(result).toHaveProperty('height')
33
+ expect(result.height).toBeGreaterThan(0)
34
+ }
35
+ })
36
+
37
+ test('1 handles errors from services gracefully', async () => {
38
+ for (const { wallet } of ctxs) {
39
+ try {
40
+ // Trigger an invalid scenario that should throw an error
41
+ await wallet.getHeight({ invalidParam: true })
42
+ } catch (e) {
43
+ // Narrow the type of 'e' to 'Error'
44
+ if (e instanceof Error) {
45
+ expect(e.message).toContain('invalid')
46
+ } else {
47
+ throw new Error('Unexpected error type thrown')
48
+ }
49
+ }
50
+ }
51
+ })
52
+ })
@@ -0,0 +1,86 @@
1
+ import { _tu, expectToThrowWERR, TestWalletNoSetup } from '../../utils/TestUtilsWalletStorage'
2
+ import * as bsv from '@bsv/sdk'
3
+
4
+ describe('getKnownTxids Tests', () => {
5
+ jest.setTimeout(99999999)
6
+
7
+ const env = _tu.getEnv('test')
8
+ const ctxs: TestWalletNoSetup[] = []
9
+
10
+ beforeAll(async () => {
11
+ if (env.runMySQL) {
12
+ ctxs.push(await _tu.createLegacyWalletMySQLCopy('getKnownTxidsTests'))
13
+ }
14
+ ctxs.push(await _tu.createLegacyWalletSQLiteCopy('getKnownTxidsTests'))
15
+ })
16
+
17
+ afterAll(async () => {
18
+ for (const ctx of ctxs) {
19
+ await ctx.storage.destroy()
20
+ }
21
+ })
22
+
23
+ /*********************************************************************************************************
24
+ * TODOTONE: Duplicates not being handled correctly.
25
+ **********************************************************************************************************/
26
+ test('0 should return an empty array when no txids are provided', async () => {
27
+ for (const { wallet } of ctxs) {
28
+ const result = wallet.getKnownTxids()
29
+ expect(result).toEqual([])
30
+ }
31
+ })
32
+
33
+ // Duplicate txids are not being handled correctly
34
+ test('1 should add new known txids', async () => {
35
+ for (const { wallet } of ctxs) {
36
+ const txids = ['txid1']
37
+ const resultBefore = wallet.getKnownTxids()
38
+ expect(resultBefore).toEqual([])
39
+
40
+ wallet.getKnownTxids(txids)
41
+ const resultAfter = wallet.getKnownTxids()
42
+ expect(resultAfter).toEqual(txids)
43
+ }
44
+ })
45
+
46
+ // Duplicate txids are not being handled correctly
47
+ test('2 should avoid duplicating txids', async () => {
48
+ for (const { wallet } of ctxs) {
49
+ const txids = ['txid1', 'txid2']
50
+ wallet.getKnownTxids(txids)
51
+
52
+ const resultBefore = wallet.getKnownTxids()
53
+ expect(resultBefore).toEqual(txids)
54
+
55
+ wallet.getKnownTxids(['txid2']) // Add duplicate txid
56
+ const resultAfter = wallet.getKnownTxids()
57
+ expect(resultAfter).toEqual(txids) // Ensure no duplicates are added
58
+ }
59
+ })
60
+
61
+ // Duplicate txids are not being handled correctly
62
+ test('3 should return sorted txids', async () => {
63
+ for (const { wallet } of ctxs) {
64
+ const unsortedTxids = ['txid3', 'txid1', 'txid2']
65
+ wallet.getKnownTxids(unsortedTxids)
66
+
67
+ const result = wallet.getKnownTxids()
68
+ expect(result).toEqual(['txid1', 'txid2', 'txid3']) // Ensure txids are sorted
69
+ }
70
+ })
71
+
72
+ test('4 should handle invalid txids gracefully', async () => {
73
+ for (const { wallet } of ctxs) {
74
+ const invalidTxids = ['invalid_txid']
75
+ const validTxids = ['txid1', 'txid2', 'txid3']
76
+ const inputTxids = [...validTxids, ...invalidTxids]
77
+
78
+ // Call the method with both valid and invalid txids
79
+ const result = wallet.getKnownTxids(inputTxids)
80
+
81
+ // Validate the result includes all txids
82
+ expect(Array.isArray(result)).toBe(true)
83
+ expect(result).toEqual(expect.arrayContaining(inputTxids))
84
+ }
85
+ })
86
+ })
@@ -0,0 +1,27 @@
1
+ import { _tu, TestWalletNoSetup } from '../../utils/TestUtilsWalletStorage'
2
+
3
+ describe('Wallet getNetwork Tests', () => {
4
+ jest.setTimeout(99999999)
5
+
6
+ const env = _tu.getEnv('test')
7
+ const ctxs: TestWalletNoSetup[] = []
8
+
9
+ beforeAll(async () => {
10
+ if (env.runMySQL) ctxs.push(await _tu.createLegacyWalletMySQLCopy('getNetworkTests'))
11
+ ctxs.push(await _tu.createLegacyWalletSQLiteCopy('getNetworkTests'))
12
+ })
13
+
14
+ afterAll(async () => {
15
+ for (const ctx of ctxs) {
16
+ await ctx.storage.destroy()
17
+ }
18
+ })
19
+
20
+ test('should return the correct network', async () => {
21
+ for (const { wallet } of ctxs) {
22
+ const result = await wallet.getNetwork({})
23
+ // Replace 'testnet' with the expected network for your test environment
24
+ expect(result).toEqual({ network: 'testnet' })
25
+ }
26
+ })
27
+ })
@@ -0,0 +1,27 @@
1
+ import { sdk } from '../../../src/index.client'
2
+ import { _tu, TestWalletNoSetup } from '../../utils/TestUtilsWalletStorage'
3
+
4
+ describe('Wallet getVersion Tests', () => {
5
+ jest.setTimeout(99999999)
6
+
7
+ const env = _tu.getEnv('test')
8
+ const ctxs: TestWalletNoSetup[] = []
9
+
10
+ beforeAll(async () => {
11
+ if (env.runMySQL) ctxs.push(await _tu.createLegacyWalletMySQLCopy('getVersionTests'))
12
+ ctxs.push(await _tu.createLegacyWalletSQLiteCopy('getVersionTests'))
13
+ })
14
+
15
+ afterAll(async () => {
16
+ for (const ctx of ctxs) {
17
+ await ctx.storage.destroy()
18
+ }
19
+ })
20
+
21
+ test('should return the correct wallet version', async () => {
22
+ for (const { wallet } of ctxs) {
23
+ const result = await wallet.getVersion({})
24
+ expect(result).toEqual({ version: 'wallet-brc100-1.0.0' })
25
+ }
26
+ })
27
+ })
@@ -0,0 +1,279 @@
1
+ import { ListActionsArgs } from '@bsv/sdk'
2
+ import { sdk, StorageProvider } from '../../../src/index.client'
3
+ import { _tu, expectToThrowWERR, TestSetup1, TestWalletProviderNoSetup } from '../../utils/TestUtilsWalletStorage'
4
+ import path from 'path'
5
+
6
+ import 'fake-indexeddb/auto'
7
+
8
+ describe('listActions tests', () => {
9
+ jest.setTimeout(99999999)
10
+
11
+ const storages: StorageProvider[] = []
12
+ const chain: sdk.Chain = 'test'
13
+ const setups: { setup: TestSetup1; storage: StorageProvider }[] = []
14
+
15
+ const env = _tu.getEnv('test')
16
+ const ctxs: TestWalletProviderNoSetup[] = []
17
+ const testName = () => expect.getState().currentTestName || 'test'
18
+ const databaseName = path.parse(expect.getState().testPath!).name
19
+
20
+ beforeAll(async () => {
21
+ if (env.runMySQL) {
22
+ ctxs.push(await _tu.createLegacyWalletMySQLCopy(databaseName))
23
+ }
24
+ ctxs.push(await _tu.createIdbLegacyWalletCopy(databaseName))
25
+ ctxs.push(await _tu.createLegacyWalletSQLiteCopy(databaseName))
26
+ })
27
+
28
+ afterAll(async () => {
29
+ for (const ctx of ctxs) {
30
+ await ctx.storage.destroy()
31
+ }
32
+ })
33
+
34
+ test('0 invalid params', async () => {
35
+ for (const { wallet } of ctxs) {
36
+ const invalidArgs: ListActionsArgs[] = [
37
+ { labels: ['toolong890'.repeat(31)] }
38
+ // Oh so many things to test...
39
+ ]
40
+
41
+ for (const args of invalidArgs) {
42
+ await expectToThrowWERR(sdk.WERR_INVALID_PARAMETER, () => wallet.listActions(args))
43
+ }
44
+ }
45
+ })
46
+
47
+ test('1 all actions', async () => {
48
+ for (const { wallet } of ctxs) {
49
+ {
50
+ const args: ListActionsArgs = {
51
+ includeLabels: true,
52
+ labels: []
53
+ }
54
+ const r = await wallet.listActions(args)
55
+ expect(r.totalActions).toBe(191)
56
+ expect(r.actions.length).toBe(10)
57
+ let i = 0
58
+ for (const a of r.actions) {
59
+ expect(a.inputs).toBeUndefined()
60
+ expect(a.outputs).toBeUndefined()
61
+ expect(Array.isArray(a.labels)).toBe(true)
62
+ }
63
+ }
64
+ }
65
+ })
66
+
67
+ test('2 non-existing label with any', async () => {
68
+ for (const { wallet } of ctxs) {
69
+ {
70
+ const args: ListActionsArgs = {
71
+ includeLabels: true,
72
+ labels: ['xyzzy'],
73
+ labelQueryMode: 'any'
74
+ }
75
+ const r = await wallet.listActions(args)
76
+ expect(r.totalActions).toBe(0)
77
+ expect(r.actions.length).toBe(0)
78
+ }
79
+ }
80
+ })
81
+
82
+ test('3_label babbage_protocol_perm', async () => {
83
+ for (const { wallet } of ctxs) {
84
+ {
85
+ const args: ListActionsArgs = {
86
+ includeLabels: true,
87
+ labels: ['babbage_protocol_perm']
88
+ }
89
+ const r = await wallet.listActions(args)
90
+ expect(r.totalActions).toBeGreaterThanOrEqual(r.actions.length)
91
+ expect(r.actions.length).toBe(args.limit || 10)
92
+ let i = 0
93
+ for (const a of r.actions) {
94
+ expect(a.inputs).toBeUndefined()
95
+ expect(a.outputs).toBeUndefined()
96
+ expect(Array.isArray(a.labels)).toBe(true)
97
+ expect(a.labels?.indexOf('babbage_protocol_perm')).toBeGreaterThan(-1)
98
+ }
99
+ }
100
+ }
101
+ })
102
+
103
+ test('4_label babbage_protocol_perm', async () => {
104
+ for (const { wallet } of ctxs) {
105
+ {
106
+ const args: ListActionsArgs = {
107
+ includeLabels: true,
108
+ labels: ['babbage_protocol_perm']
109
+ }
110
+ const r = await wallet.listActions(args)
111
+ expect(r.totalActions).toBeGreaterThanOrEqual(r.actions.length)
112
+ expect(r.actions.length).toBe(args.limit || 10)
113
+ let i = 0
114
+ for (const a of r.actions) {
115
+ expect(a.inputs).toBeUndefined()
116
+ expect(a.outputs).toBeUndefined()
117
+ expect(Array.isArray(a.labels)).toBe(true)
118
+ for (const label of args.labels) {
119
+ expect(a.labels?.indexOf(label)).toBeGreaterThan(-1)
120
+ }
121
+ }
122
+ }
123
+ }
124
+ })
125
+
126
+ test('5_label babbage_protocol_perm or babbage_basket_access', async () => {
127
+ for (const { wallet } of ctxs) {
128
+ {
129
+ const args: ListActionsArgs = {
130
+ includeLabels: true,
131
+ labels: ['babbage_protocol_perm', 'babbage_basket_access']
132
+ }
133
+ const r = await wallet.listActions(args)
134
+ expect(r.totalActions).toBeGreaterThanOrEqual(r.actions.length)
135
+ expect(r.actions.length).toBe(args.limit || 10)
136
+ let i = 0
137
+ for (const a of r.actions) {
138
+ expect(a.inputs).toBeUndefined()
139
+ expect(a.outputs).toBeUndefined()
140
+ expect(Array.isArray(a.labels)).toBe(true)
141
+ let count = 0
142
+ for (const label of args.labels) {
143
+ if (a.labels!.indexOf(label) > -1) count++
144
+ }
145
+ expect(count).toBeGreaterThan(0)
146
+ }
147
+ }
148
+ }
149
+ })
150
+
151
+ test('6_label babbage_protocol_perm and babbage_basket_access', async () => {
152
+ for (const { wallet } of ctxs) {
153
+ {
154
+ const args: ListActionsArgs = {
155
+ includeLabels: true,
156
+ labels: ['babbage_protocol_perm', 'babbage_basket_access'],
157
+ labelQueryMode: 'all'
158
+ }
159
+ const r = await wallet.listActions(args)
160
+ expect(r.totalActions).toBe(0)
161
+ }
162
+ }
163
+ })
164
+
165
+ test('7_includeOutputs', async () => {
166
+ for (const { wallet } of ctxs) {
167
+ {
168
+ const args: ListActionsArgs = {
169
+ includeOutputs: true,
170
+ labels: ['babbage_protocol_perm']
171
+ }
172
+ const r = await wallet.listActions(args)
173
+ expect(r.totalActions).toBeGreaterThanOrEqual(r.actions.length)
174
+ expect(r.actions.length).toBe(args.limit || 10)
175
+ let i = 0
176
+ for (const a of r.actions) {
177
+ expect(a.isOutgoing === true || a.isOutgoing === false).toBe(true)
178
+ expect(a.inputs).toBeUndefined()
179
+ expect(Array.isArray(a.outputs)).toBe(true)
180
+ expect(a.labels).toBeUndefined()
181
+ for (const o of a.outputs!) {
182
+ expect(o.outputIndex).toBeGreaterThanOrEqual(0)
183
+ expect(o.lockingScript).toBeUndefined()
184
+ }
185
+ }
186
+ }
187
+ }
188
+ })
189
+
190
+ test('8_includeOutputs and script', async () => {
191
+ for (const { wallet } of ctxs) {
192
+ {
193
+ const args: ListActionsArgs = {
194
+ includeOutputs: true,
195
+ includeOutputLockingScripts: true,
196
+ labels: ['babbage_protocol_perm']
197
+ }
198
+ const r = await wallet.listActions(args)
199
+ let i = 0
200
+ for (const a of r.actions) {
201
+ for (const o of a.outputs!) {
202
+ expect(o.lockingScript?.length).toBeGreaterThan(0)
203
+ }
204
+ }
205
+ }
206
+ }
207
+ })
208
+
209
+ test('9_includeInputs', async () => {
210
+ for (const { wallet } of ctxs) {
211
+ {
212
+ const args: ListActionsArgs = {
213
+ includeInputs: true,
214
+ labels: ['babbage_protocol_perm']
215
+ }
216
+ const r = await wallet.listActions(args)
217
+ let i = 0
218
+ for (const a of r.actions) {
219
+ expect(a.isOutgoing === true || a.isOutgoing === false).toBe(true)
220
+ expect(a.outputs).toBeUndefined()
221
+ expect(Array.isArray(a.inputs)).toBe(true)
222
+ expect(a.labels).toBeUndefined()
223
+ for (const i of a.inputs!) {
224
+ expect(i.sourceLockingScript).toBeUndefined()
225
+ expect(i.unlockingScript).toBeUndefined()
226
+ }
227
+ }
228
+ }
229
+ }
230
+ })
231
+
232
+ test('10_includeInputs and unlock', async () => {
233
+ for (const { wallet } of ctxs) {
234
+ {
235
+ const args: ListActionsArgs = {
236
+ includeInputs: true,
237
+ includeInputUnlockingScripts: true,
238
+ labels: ['babbage_protocol_perm']
239
+ }
240
+ const r = await wallet.listActions(args)
241
+ let i = 0
242
+ for (const a of r.actions) {
243
+ expect(a.isOutgoing === true || a.isOutgoing === false).toBe(true)
244
+ expect(a.outputs).toBeUndefined()
245
+ expect(Array.isArray(a.inputs)).toBe(true)
246
+ expect(a.labels).toBeUndefined()
247
+ for (const i of a.inputs!) {
248
+ expect(i.sourceLockingScript).toBeUndefined()
249
+ expect(i.unlockingScript?.length).toBeGreaterThan(0)
250
+ }
251
+ }
252
+ }
253
+ }
254
+ })
255
+
256
+ test('11_includeInputs and lock', async () => {
257
+ for (const { wallet } of ctxs) {
258
+ {
259
+ const args: ListActionsArgs = {
260
+ includeInputs: true,
261
+ includeInputSourceLockingScripts: true,
262
+ labels: ['babbage_protocol_perm']
263
+ }
264
+ const r = await wallet.listActions(args)
265
+ let i = 0
266
+ for (const a of r.actions) {
267
+ expect(a.isOutgoing === true || a.isOutgoing === false).toBe(true)
268
+ expect(a.outputs).toBeUndefined()
269
+ expect(Array.isArray(a.inputs)).toBe(true)
270
+ expect(a.labels).toBeUndefined()
271
+ for (const i of a.inputs!) {
272
+ expect(i.sourceLockingScript?.length).toBeGreaterThan(0)
273
+ expect(i.unlockingScript).toBeUndefined()
274
+ }
275
+ }
276
+ }
277
+ }
278
+ })
279
+ })