@bsv/wallet-toolbox 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (919) hide show
  1. package/.env.template +22 -0
  2. package/.github/ISSUE_TEMPLATE/bug_report.md +40 -0
  3. package/.github/ISSUE_TEMPLATE/discussion.md +24 -0
  4. package/.github/pull_request_template.md +24 -0
  5. package/.github/workflows/push.yaml +66 -0
  6. package/.prettierrc +10 -0
  7. package/CONTRIBUTING.md +89 -0
  8. package/LICENSE.txt +28 -0
  9. package/README.md +124 -0
  10. package/dev.sqlite3 +0 -0
  11. package/docs/README.md +15 -0
  12. package/docs/client.md +6812 -0
  13. package/docs/monitor.md +648 -0
  14. package/docs/services.md +496 -0
  15. package/docs/storage.md +1884 -0
  16. package/docs/wallet.md +6812 -0
  17. package/jest.config.ts +29 -0
  18. package/knexfile.js +9 -0
  19. package/license.md +1 -0
  20. package/out/src/Wallet.d.ts +83 -0
  21. package/out/src/Wallet.d.ts.map +1 -0
  22. package/out/src/Wallet.js +415 -0
  23. package/out/src/Wallet.js.map +1 -0
  24. package/out/src/index.all.d.ts +9 -0
  25. package/out/src/index.all.d.ts.map +1 -0
  26. package/out/src/index.all.js +48 -0
  27. package/out/src/index.all.js.map +1 -0
  28. package/out/src/index.client.d.ts +8 -0
  29. package/out/src/index.client.d.ts.map +1 -0
  30. package/out/src/index.client.js +47 -0
  31. package/out/src/index.client.js.map +1 -0
  32. package/out/src/index.d.ts +3 -0
  33. package/out/src/index.d.ts.map +1 -0
  34. package/out/src/index.js +42 -0
  35. package/out/src/index.js.map +1 -0
  36. package/out/src/monitor/Monitor.d.ts +89 -0
  37. package/out/src/monitor/Monitor.d.ts.map +1 -0
  38. package/out/src/monitor/Monitor.js +253 -0
  39. package/out/src/monitor/Monitor.js.map +1 -0
  40. package/out/src/monitor/MonitorDaemon.d.ts +30 -0
  41. package/out/src/monitor/MonitorDaemon.d.ts.map +1 -0
  42. package/out/src/monitor/MonitorDaemon.js +135 -0
  43. package/out/src/monitor/MonitorDaemon.js.map +1 -0
  44. package/out/src/monitor/__test/MonitorDaemon.man.test.d.ts +2 -0
  45. package/out/src/monitor/__test/MonitorDaemon.man.test.d.ts.map +1 -0
  46. package/out/src/monitor/__test/MonitorDaemon.man.test.js +50 -0
  47. package/out/src/monitor/__test/MonitorDaemon.man.test.js.map +1 -0
  48. package/out/src/monitor/tasks/TaskCheckForProofs.d.ts +53 -0
  49. package/out/src/monitor/tasks/TaskCheckForProofs.d.ts.map +1 -0
  50. package/out/src/monitor/tasks/TaskCheckForProofs.js +197 -0
  51. package/out/src/monitor/tasks/TaskCheckForProofs.js.map +1 -0
  52. package/out/src/monitor/tasks/TaskClock.d.ts +14 -0
  53. package/out/src/monitor/tasks/TaskClock.d.ts.map +1 -0
  54. package/out/src/monitor/tasks/TaskClock.js +27 -0
  55. package/out/src/monitor/tasks/TaskClock.js.map +1 -0
  56. package/out/src/monitor/tasks/TaskFailAbandoned.d.ts +20 -0
  57. package/out/src/monitor/tasks/TaskFailAbandoned.d.ts.map +1 -0
  58. package/out/src/monitor/tasks/TaskFailAbandoned.js +52 -0
  59. package/out/src/monitor/tasks/TaskFailAbandoned.js.map +1 -0
  60. package/out/src/monitor/tasks/TaskNewHeader.d.ts +15 -0
  61. package/out/src/monitor/tasks/TaskNewHeader.d.ts.map +1 -0
  62. package/out/src/monitor/tasks/TaskNewHeader.js +45 -0
  63. package/out/src/monitor/tasks/TaskNewHeader.js.map +1 -0
  64. package/out/src/monitor/tasks/TaskPurge.d.ts +45 -0
  65. package/out/src/monitor/tasks/TaskPurge.d.ts.map +1 -0
  66. package/out/src/monitor/tasks/TaskPurge.js +35 -0
  67. package/out/src/monitor/tasks/TaskPurge.js.map +1 -0
  68. package/out/src/monitor/tasks/TaskReviewStatus.d.ts +26 -0
  69. package/out/src/monitor/tasks/TaskReviewStatus.d.ts.map +1 -0
  70. package/out/src/monitor/tasks/TaskReviewStatus.js +44 -0
  71. package/out/src/monitor/tasks/TaskReviewStatus.js.map +1 -0
  72. package/out/src/monitor/tasks/TaskSendWaiting.d.ts +32 -0
  73. package/out/src/monitor/tasks/TaskSendWaiting.d.ts.map +1 -0
  74. package/out/src/monitor/tasks/TaskSendWaiting.js +99 -0
  75. package/out/src/monitor/tasks/TaskSendWaiting.js.map +1 -0
  76. package/out/src/monitor/tasks/TaskSyncWhenIdle.d.ts +12 -0
  77. package/out/src/monitor/tasks/TaskSyncWhenIdle.d.ts.map +1 -0
  78. package/out/src/monitor/tasks/TaskSyncWhenIdle.js +22 -0
  79. package/out/src/monitor/tasks/TaskSyncWhenIdle.js.map +1 -0
  80. package/out/src/monitor/tasks/WalletMonitorTask.d.ts +40 -0
  81. package/out/src/monitor/tasks/WalletMonitorTask.d.ts.map +1 -0
  82. package/out/src/monitor/tasks/WalletMonitorTask.js +37 -0
  83. package/out/src/monitor/tasks/WalletMonitorTask.js.map +1 -0
  84. package/out/src/sdk/CertOps.d.ts +66 -0
  85. package/out/src/sdk/CertOps.d.ts.map +1 -0
  86. package/out/src/sdk/CertOps.js +198 -0
  87. package/out/src/sdk/CertOps.js.map +1 -0
  88. package/out/src/sdk/PrivilegedKeyManager.d.ts +125 -0
  89. package/out/src/sdk/PrivilegedKeyManager.d.ts.map +1 -0
  90. package/out/src/sdk/PrivilegedKeyManager.js +293 -0
  91. package/out/src/sdk/PrivilegedKeyManager.js.map +1 -0
  92. package/out/src/sdk/StorageSyncReader.d.ts +121 -0
  93. package/out/src/sdk/StorageSyncReader.d.ts.map +1 -0
  94. package/out/src/sdk/StorageSyncReader.js +3 -0
  95. package/out/src/sdk/StorageSyncReader.js.map +1 -0
  96. package/out/src/sdk/StorageSyncReaderWriter.d.ts +89 -0
  97. package/out/src/sdk/StorageSyncReaderWriter.d.ts.map +1 -0
  98. package/out/src/sdk/StorageSyncReaderWriter.js +3 -0
  99. package/out/src/sdk/StorageSyncReaderWriter.js.map +1 -0
  100. package/out/src/sdk/WERR_errors.d.ts +90 -0
  101. package/out/src/sdk/WERR_errors.d.ts.map +1 -0
  102. package/out/src/sdk/WERR_errors.js +128 -0
  103. package/out/src/sdk/WERR_errors.js.map +1 -0
  104. package/out/src/sdk/WalletError.d.ts +45 -0
  105. package/out/src/sdk/WalletError.d.ts.map +1 -0
  106. package/out/src/sdk/WalletError.js +122 -0
  107. package/out/src/sdk/WalletError.js.map +1 -0
  108. package/out/src/sdk/WalletServices.interfaces.d.ts +325 -0
  109. package/out/src/sdk/WalletServices.interfaces.d.ts.map +1 -0
  110. package/out/src/sdk/WalletServices.interfaces.js +3 -0
  111. package/out/src/sdk/WalletServices.interfaces.js.map +1 -0
  112. package/out/src/sdk/WalletSigner.interfaces.d.ts +10 -0
  113. package/out/src/sdk/WalletSigner.interfaces.d.ts.map +1 -0
  114. package/out/src/sdk/WalletSigner.interfaces.js +3 -0
  115. package/out/src/sdk/WalletSigner.interfaces.js.map +1 -0
  116. package/out/src/sdk/WalletStorage.interfaces.d.ts +299 -0
  117. package/out/src/sdk/WalletStorage.interfaces.d.ts.map +1 -0
  118. package/out/src/sdk/WalletStorage.interfaces.js +3 -0
  119. package/out/src/sdk/WalletStorage.interfaces.js.map +1 -0
  120. package/out/src/sdk/__test/CertificateLifeCycle.test.d.ts +2 -0
  121. package/out/src/sdk/__test/CertificateLifeCycle.test.d.ts.map +1 -0
  122. package/out/src/sdk/__test/CertificateLifeCycle.test.js +125 -0
  123. package/out/src/sdk/__test/CertificateLifeCycle.test.js.map +1 -0
  124. package/out/src/sdk/__test/PrivilegedKeyManager.test.d.ts +2 -0
  125. package/out/src/sdk/__test/PrivilegedKeyManager.test.d.ts.map +1 -0
  126. package/out/src/sdk/__test/PrivilegedKeyManager.test.js +660 -0
  127. package/out/src/sdk/__test/PrivilegedKeyManager.test.js.map +1 -0
  128. package/out/src/sdk/index.d.ts +12 -0
  129. package/out/src/sdk/index.d.ts.map +1 -0
  130. package/out/src/sdk/index.js +28 -0
  131. package/out/src/sdk/index.js.map +1 -0
  132. package/out/src/sdk/types.d.ts +74 -0
  133. package/out/src/sdk/types.d.ts.map +1 -0
  134. package/out/src/sdk/types.js +20 -0
  135. package/out/src/sdk/types.js.map +1 -0
  136. package/out/src/sdk/validationHelpers.d.ts +288 -0
  137. package/out/src/sdk/validationHelpers.d.ts.map +1 -0
  138. package/out/src/sdk/validationHelpers.js +630 -0
  139. package/out/src/sdk/validationHelpers.js.map +1 -0
  140. package/out/src/services/ServiceCollection.d.ts +25 -0
  141. package/out/src/services/ServiceCollection.d.ts.map +1 -0
  142. package/out/src/services/ServiceCollection.js +43 -0
  143. package/out/src/services/ServiceCollection.js.map +1 -0
  144. package/out/src/services/Services.d.ts +60 -0
  145. package/out/src/services/Services.d.ts.map +1 -0
  146. package/out/src/services/Services.js +342 -0
  147. package/out/src/services/Services.js.map +1 -0
  148. package/out/src/services/__tests/getMerklePath.test.d.ts +2 -0
  149. package/out/src/services/__tests/getMerklePath.test.d.ts.map +1 -0
  150. package/out/src/services/__tests/getMerklePath.test.js +16 -0
  151. package/out/src/services/__tests/getMerklePath.test.js.map +1 -0
  152. package/out/src/services/__tests/getRawTx.test.d.ts +2 -0
  153. package/out/src/services/__tests/getRawTx.test.d.ts.map +1 -0
  154. package/out/src/services/__tests/getRawTx.test.js +13 -0
  155. package/out/src/services/__tests/getRawTx.test.js.map +1 -0
  156. package/out/src/services/__tests/postBeef.test.d.ts +2 -0
  157. package/out/src/services/__tests/postBeef.test.d.ts.map +1 -0
  158. package/out/src/services/__tests/postBeef.test.js +18 -0
  159. package/out/src/services/__tests/postBeef.test.js.map +1 -0
  160. package/out/src/services/__tests/postBeefToArcTaal.test.d.ts +2 -0
  161. package/out/src/services/__tests/postBeefToArcTaal.test.d.ts.map +1 -0
  162. package/out/src/services/__tests/postBeefToArcTaal.test.js +479 -0
  163. package/out/src/services/__tests/postBeefToArcTaal.test.js.map +1 -0
  164. package/out/src/services/__tests/postTxs.test.d.ts +2 -0
  165. package/out/src/services/__tests/postTxs.test.d.ts.map +1 -0
  166. package/out/src/services/__tests/postTxs.test.js +19 -0
  167. package/out/src/services/__tests/postTxs.test.js.map +1 -0
  168. package/out/src/services/chaintracker/ChaintracksChainTracker.d.ts +15 -0
  169. package/out/src/services/chaintracker/ChaintracksChainTracker.d.ts.map +1 -0
  170. package/out/src/services/chaintracker/ChaintracksChainTracker.js +51 -0
  171. package/out/src/services/chaintracker/ChaintracksChainTracker.js.map +1 -0
  172. package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.d.ts +2 -0
  173. package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.d.ts.map +1 -0
  174. package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.js +19 -0
  175. package/out/src/services/chaintracker/__tests/ChaintracksChainTracker.test.js.map +1 -0
  176. package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.d.ts +2 -0
  177. package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.d.ts.map +1 -0
  178. package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.js +29 -0
  179. package/out/src/services/chaintracker/__tests/ChaintracksServiceClient.test.js.map +1 -0
  180. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts +98 -0
  181. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts.map +1 -0
  182. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js +38 -0
  183. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js.map +1 -0
  184. package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts +36 -0
  185. package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.d.ts.map +1 -0
  186. package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js +130 -0
  187. package/out/src/services/chaintracker/chaintracks/ChaintracksServiceClient.js.map +1 -0
  188. package/out/src/services/chaintracker/chaintracks/index.d.ts +3 -0
  189. package/out/src/services/chaintracker/chaintracks/index.d.ts.map +1 -0
  190. package/out/src/services/chaintracker/chaintracks/index.js +19 -0
  191. package/out/src/services/chaintracker/chaintracks/index.js.map +1 -0
  192. package/out/src/services/chaintracker/index.d.ts +3 -0
  193. package/out/src/services/chaintracker/index.d.ts.map +1 -0
  194. package/out/src/services/chaintracker/index.js +19 -0
  195. package/out/src/services/chaintracker/index.js.map +1 -0
  196. package/out/src/services/createDefaultWalletServicesOptions.d.ts +3 -0
  197. package/out/src/services/createDefaultWalletServicesOptions.d.ts.map +1 -0
  198. package/out/src/services/createDefaultWalletServicesOptions.js +34 -0
  199. package/out/src/services/createDefaultWalletServicesOptions.js.map +1 -0
  200. package/out/src/services/index.d.ts +2 -0
  201. package/out/src/services/index.d.ts.map +1 -0
  202. package/out/src/services/index.js +18 -0
  203. package/out/src/services/index.js.map +1 -0
  204. package/out/src/services/providers/arcServices.d.ts +62 -0
  205. package/out/src/services/providers/arcServices.d.ts.map +1 -0
  206. package/out/src/services/providers/arcServices.js +368 -0
  207. package/out/src/services/providers/arcServices.js.map +1 -0
  208. package/out/src/services/providers/echangeRates.d.ts +12 -0
  209. package/out/src/services/providers/echangeRates.d.ts.map +1 -0
  210. package/out/src/services/providers/echangeRates.js +237 -0
  211. package/out/src/services/providers/echangeRates.js.map +1 -0
  212. package/out/src/services/providers/whatsonchain.d.ts +17 -0
  213. package/out/src/services/providers/whatsonchain.d.ts.map +1 -0
  214. package/out/src/services/providers/whatsonchain.js +130 -0
  215. package/out/src/services/providers/whatsonchain.js.map +1 -0
  216. package/out/src/signer/WalletSigner.d.ts +11 -0
  217. package/out/src/signer/WalletSigner.d.ts.map +1 -0
  218. package/out/src/signer/WalletSigner.js +13 -0
  219. package/out/src/signer/WalletSigner.js.map +1 -0
  220. package/out/src/signer/methods/acquireDirectCertificate.d.ts +4 -0
  221. package/out/src/signer/methods/acquireDirectCertificate.d.ts.map +1 -0
  222. package/out/src/signer/methods/acquireDirectCertificate.js +47 -0
  223. package/out/src/signer/methods/acquireDirectCertificate.js.map +1 -0
  224. package/out/src/signer/methods/createAction.d.ts +7 -0
  225. package/out/src/signer/methods/createAction.d.ts.map +1 -0
  226. package/out/src/signer/methods/createAction.js +250 -0
  227. package/out/src/signer/methods/createAction.js.map +1 -0
  228. package/out/src/signer/methods/internalizeAction.d.ts +31 -0
  229. package/out/src/signer/methods/internalizeAction.d.ts.map +1 -0
  230. package/out/src/signer/methods/internalizeAction.js +95 -0
  231. package/out/src/signer/methods/internalizeAction.js.map +1 -0
  232. package/out/src/signer/methods/proveCertificate.d.ts +4 -0
  233. package/out/src/signer/methods/proveCertificate.d.ts.map +1 -0
  234. package/out/src/signer/methods/proveCertificate.js +45 -0
  235. package/out/src/signer/methods/proveCertificate.js.map +1 -0
  236. package/out/src/signer/methods/signAction.d.ts +6 -0
  237. package/out/src/signer/methods/signAction.d.ts.map +1 -0
  238. package/out/src/signer/methods/signAction.js +79 -0
  239. package/out/src/signer/methods/signAction.js.map +1 -0
  240. package/out/src/storage/StorageKnex.d.ts +176 -0
  241. package/out/src/storage/StorageKnex.d.ts.map +1 -0
  242. package/out/src/storage/StorageKnex.js +1035 -0
  243. package/out/src/storage/StorageKnex.js.map +1 -0
  244. package/out/src/storage/StorageProvider.d.ts +140 -0
  245. package/out/src/storage/StorageProvider.d.ts.map +1 -0
  246. package/out/src/storage/StorageProvider.js +539 -0
  247. package/out/src/storage/StorageProvider.js.map +1 -0
  248. package/out/src/storage/StorageReader.d.ts +76 -0
  249. package/out/src/storage/StorageReader.d.ts.map +1 -0
  250. package/out/src/storage/StorageReader.js +124 -0
  251. package/out/src/storage/StorageReader.js.map +1 -0
  252. package/out/src/storage/StorageReaderWriter.d.ts +87 -0
  253. package/out/src/storage/StorageReaderWriter.d.ts.map +1 -0
  254. package/out/src/storage/StorageReaderWriter.js +337 -0
  255. package/out/src/storage/StorageReaderWriter.js.map +1 -0
  256. package/out/src/storage/StorageSyncReader.d.ts +33 -0
  257. package/out/src/storage/StorageSyncReader.d.ts.map +1 -0
  258. package/out/src/storage/StorageSyncReader.js +142 -0
  259. package/out/src/storage/StorageSyncReader.js.map +1 -0
  260. package/out/src/storage/WalletStorageManager.d.ts +103 -0
  261. package/out/src/storage/WalletStorageManager.d.ts.map +1 -0
  262. package/out/src/storage/WalletStorageManager.js +408 -0
  263. package/out/src/storage/WalletStorageManager.js.map +1 -0
  264. package/out/src/storage/__test/WalletStorageManager.test.d.ts +2 -0
  265. package/out/src/storage/__test/WalletStorageManager.test.d.ts.map +1 -0
  266. package/out/src/storage/__test/WalletStorageManager.test.js +260 -0
  267. package/out/src/storage/__test/WalletStorageManager.test.js.map +1 -0
  268. package/out/src/storage/index.all.d.ts +11 -0
  269. package/out/src/storage/index.all.d.ts.map +1 -0
  270. package/out/src/storage/index.all.js +50 -0
  271. package/out/src/storage/index.all.js.map +1 -0
  272. package/out/src/storage/index.client.d.ts +7 -0
  273. package/out/src/storage/index.client.d.ts.map +1 -0
  274. package/out/src/storage/index.client.js +46 -0
  275. package/out/src/storage/index.client.js.map +1 -0
  276. package/out/src/storage/index.db.d.ts +1 -0
  277. package/out/src/storage/index.db.d.ts.map +1 -0
  278. package/out/src/storage/index.db.js +2 -0
  279. package/out/src/storage/index.db.js.map +1 -0
  280. package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.d.ts +2 -0
  281. package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.d.ts.map +1 -0
  282. package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.js +948 -0
  283. package/out/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.js.map +1 -0
  284. package/out/src/storage/methods/__test/GenerateChange/randomValsUsed1.d.ts +2 -0
  285. package/out/src/storage/methods/__test/GenerateChange/randomValsUsed1.d.ts.map +1 -0
  286. package/out/src/storage/methods/__test/GenerateChange/randomValsUsed1.js +35 -0
  287. package/out/src/storage/methods/__test/GenerateChange/randomValsUsed1.js.map +1 -0
  288. package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts +27 -0
  289. package/out/src/storage/methods/attemptToPostReqsToNetwork.d.ts.map +1 -0
  290. package/out/src/storage/methods/attemptToPostReqsToNetwork.js +148 -0
  291. package/out/src/storage/methods/attemptToPostReqsToNetwork.js.map +1 -0
  292. package/out/src/storage/methods/createAction.d.ts +23 -0
  293. package/out/src/storage/methods/createAction.d.ts.map +1 -0
  294. package/out/src/storage/methods/createAction.js +663 -0
  295. package/out/src/storage/methods/createAction.js.map +1 -0
  296. package/out/src/storage/methods/generateChange.d.ts +108 -0
  297. package/out/src/storage/methods/generateChange.d.ts.map +1 -0
  298. package/out/src/storage/methods/generateChange.js +422 -0
  299. package/out/src/storage/methods/generateChange.js.map +1 -0
  300. package/out/src/storage/methods/getBeefForTransaction.d.ts +22 -0
  301. package/out/src/storage/methods/getBeefForTransaction.d.ts.map +1 -0
  302. package/out/src/storage/methods/getBeefForTransaction.js +94 -0
  303. package/out/src/storage/methods/getBeefForTransaction.js.map +1 -0
  304. package/out/src/storage/methods/getSyncChunk.d.ts +10 -0
  305. package/out/src/storage/methods/getSyncChunk.d.ts.map +1 -0
  306. package/out/src/storage/methods/getSyncChunk.js +271 -0
  307. package/out/src/storage/methods/getSyncChunk.js.map +1 -0
  308. package/out/src/storage/methods/internalizeAction.d.ts +38 -0
  309. package/out/src/storage/methods/internalizeAction.d.ts.map +1 -0
  310. package/out/src/storage/methods/internalizeAction.js +378 -0
  311. package/out/src/storage/methods/internalizeAction.js.map +1 -0
  312. package/out/src/storage/methods/listActions.d.ts +5 -0
  313. package/out/src/storage/methods/listActions.d.ts.map +1 -0
  314. package/out/src/storage/methods/listActions.js +174 -0
  315. package/out/src/storage/methods/listActions.js.map +1 -0
  316. package/out/src/storage/methods/listCertificates.d.ts +5 -0
  317. package/out/src/storage/methods/listCertificates.d.ts.map +1 -0
  318. package/out/src/storage/methods/listCertificates.js +68 -0
  319. package/out/src/storage/methods/listCertificates.js.map +1 -0
  320. package/out/src/storage/methods/listOutputs.d.ts +5 -0
  321. package/out/src/storage/methods/listOutputs.d.ts.map +1 -0
  322. package/out/src/storage/methods/listOutputs.js +189 -0
  323. package/out/src/storage/methods/listOutputs.js.map +1 -0
  324. package/out/src/storage/methods/processAction.d.ts +35 -0
  325. package/out/src/storage/methods/processAction.d.ts.map +1 -0
  326. package/out/src/storage/methods/processAction.js +271 -0
  327. package/out/src/storage/methods/processAction.js.map +1 -0
  328. package/out/src/storage/methods/purgeData.d.ts +4 -0
  329. package/out/src/storage/methods/purgeData.d.ts.map +1 -0
  330. package/out/src/storage/methods/purgeData.js +229 -0
  331. package/out/src/storage/methods/purgeData.js.map +1 -0
  332. package/out/src/storage/methods/reviewStatus.d.ts +9 -0
  333. package/out/src/storage/methods/reviewStatus.d.ts.map +1 -0
  334. package/out/src/storage/methods/reviewStatus.js +75 -0
  335. package/out/src/storage/methods/reviewStatus.js.map +1 -0
  336. package/out/src/storage/remoting/StorageClient.d.ts +56 -0
  337. package/out/src/storage/remoting/StorageClient.d.ts.map +1 -0
  338. package/out/src/storage/remoting/StorageClient.js +181 -0
  339. package/out/src/storage/remoting/StorageClient.js.map +1 -0
  340. package/out/src/storage/remoting/StorageServer.d.ts +26 -0
  341. package/out/src/storage/remoting/StorageServer.d.ts.map +1 -0
  342. package/out/src/storage/remoting/StorageServer.js +144 -0
  343. package/out/src/storage/remoting/StorageServer.js.map +1 -0
  344. package/out/src/storage/schema/KnexMigrations.d.ts +39 -0
  345. package/out/src/storage/schema/KnexMigrations.d.ts.map +1 -0
  346. package/out/src/storage/schema/KnexMigrations.js +442 -0
  347. package/out/src/storage/schema/KnexMigrations.js.map +1 -0
  348. package/out/src/storage/schema/entities/Certificate.d.ts +43 -0
  349. package/out/src/storage/schema/entities/Certificate.d.ts.map +1 -0
  350. package/out/src/storage/schema/entities/Certificate.js +162 -0
  351. package/out/src/storage/schema/entities/Certificate.js.map +1 -0
  352. package/out/src/storage/schema/entities/CertificateField.d.ts +32 -0
  353. package/out/src/storage/schema/entities/CertificateField.d.ts.map +1 -0
  354. package/out/src/storage/schema/entities/CertificateField.js +114 -0
  355. package/out/src/storage/schema/entities/CertificateField.js.map +1 -0
  356. package/out/src/storage/schema/entities/Commission.d.ts +37 -0
  357. package/out/src/storage/schema/entities/Commission.d.ts.map +1 -0
  358. package/out/src/storage/schema/entities/Commission.js +130 -0
  359. package/out/src/storage/schema/entities/Commission.js.map +1 -0
  360. package/out/src/storage/schema/entities/EntityBase.d.ts +105 -0
  361. package/out/src/storage/schema/entities/EntityBase.d.ts.map +1 -0
  362. package/out/src/storage/schema/entities/EntityBase.js +100 -0
  363. package/out/src/storage/schema/entities/EntityBase.js.map +1 -0
  364. package/out/src/storage/schema/entities/MergeEntity.d.ts +34 -0
  365. package/out/src/storage/schema/entities/MergeEntity.d.ts.map +1 -0
  366. package/out/src/storage/schema/entities/MergeEntity.js +57 -0
  367. package/out/src/storage/schema/entities/MergeEntity.js.map +1 -0
  368. package/out/src/storage/schema/entities/Output.d.ts +67 -0
  369. package/out/src/storage/schema/entities/Output.d.ts.map +1 -0
  370. package/out/src/storage/schema/entities/Output.js +281 -0
  371. package/out/src/storage/schema/entities/Output.js.map +1 -0
  372. package/out/src/storage/schema/entities/OutputBasket.d.ts +35 -0
  373. package/out/src/storage/schema/entities/OutputBasket.d.ts.map +1 -0
  374. package/out/src/storage/schema/entities/OutputBasket.js +133 -0
  375. package/out/src/storage/schema/entities/OutputBasket.js.map +1 -0
  376. package/out/src/storage/schema/entities/OutputTag.d.ts +31 -0
  377. package/out/src/storage/schema/entities/OutputTag.d.ts.map +1 -0
  378. package/out/src/storage/schema/entities/OutputTag.js +104 -0
  379. package/out/src/storage/schema/entities/OutputTag.js.map +1 -0
  380. package/out/src/storage/schema/entities/OutputTagMap.d.ts +28 -0
  381. package/out/src/storage/schema/entities/OutputTagMap.d.ts.map +1 -0
  382. package/out/src/storage/schema/entities/OutputTagMap.js +101 -0
  383. package/out/src/storage/schema/entities/OutputTagMap.js.map +1 -0
  384. package/out/src/storage/schema/entities/ProvenTx.d.ts +84 -0
  385. package/out/src/storage/schema/entities/ProvenTx.d.ts.map +1 -0
  386. package/out/src/storage/schema/entities/ProvenTx.js +283 -0
  387. package/out/src/storage/schema/entities/ProvenTx.js.map +1 -0
  388. package/out/src/storage/schema/entities/ProvenTxReq.d.ts +130 -0
  389. package/out/src/storage/schema/entities/ProvenTxReq.d.ts.map +1 -0
  390. package/out/src/storage/schema/entities/ProvenTxReq.js +521 -0
  391. package/out/src/storage/schema/entities/ProvenTxReq.js.map +1 -0
  392. package/out/src/storage/schema/entities/SyncState.d.ts +66 -0
  393. package/out/src/storage/schema/entities/SyncState.d.ts.map +1 -0
  394. package/out/src/storage/schema/entities/SyncState.js +284 -0
  395. package/out/src/storage/schema/entities/SyncState.js.map +1 -0
  396. package/out/src/storage/schema/entities/Transaction.d.ts +67 -0
  397. package/out/src/storage/schema/entities/Transaction.d.ts.map +1 -0
  398. package/out/src/storage/schema/entities/Transaction.js +264 -0
  399. package/out/src/storage/schema/entities/Transaction.js.map +1 -0
  400. package/out/src/storage/schema/entities/TxLabel.d.ts +31 -0
  401. package/out/src/storage/schema/entities/TxLabel.d.ts.map +1 -0
  402. package/out/src/storage/schema/entities/TxLabel.js +104 -0
  403. package/out/src/storage/schema/entities/TxLabel.js.map +1 -0
  404. package/out/src/storage/schema/entities/TxLabelMap.d.ts +28 -0
  405. package/out/src/storage/schema/entities/TxLabelMap.d.ts.map +1 -0
  406. package/out/src/storage/schema/entities/TxLabelMap.js +103 -0
  407. package/out/src/storage/schema/entities/TxLabelMap.js.map +1 -0
  408. package/out/src/storage/schema/entities/User.d.ts +29 -0
  409. package/out/src/storage/schema/entities/User.d.ts.map +1 -0
  410. package/out/src/storage/schema/entities/User.js +100 -0
  411. package/out/src/storage/schema/entities/User.js.map +1 -0
  412. package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.d.ts +2 -0
  413. package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.d.ts.map +1 -0
  414. package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.js +588 -0
  415. package/out/src/storage/schema/entities/__tests/CertificateFieldTests.test.js.map +1 -0
  416. package/out/src/storage/schema/entities/__tests/CertificateTests.test.d.ts +2 -0
  417. package/out/src/storage/schema/entities/__tests/CertificateTests.test.d.ts.map +1 -0
  418. package/out/src/storage/schema/entities/__tests/CertificateTests.test.js +449 -0
  419. package/out/src/storage/schema/entities/__tests/CertificateTests.test.js.map +1 -0
  420. package/out/src/storage/schema/entities/__tests/CommissionTests.test.d.ts +2 -0
  421. package/out/src/storage/schema/entities/__tests/CommissionTests.test.d.ts.map +1 -0
  422. package/out/src/storage/schema/entities/__tests/CommissionTests.test.js +602 -0
  423. package/out/src/storage/schema/entities/__tests/CommissionTests.test.js.map +1 -0
  424. package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.d.ts +2 -0
  425. package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.d.ts.map +1 -0
  426. package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.js +515 -0
  427. package/out/src/storage/schema/entities/__tests/OutputBasketTests.test.js.map +1 -0
  428. package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.d.ts +2 -0
  429. package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.d.ts.map +1 -0
  430. package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.js +478 -0
  431. package/out/src/storage/schema/entities/__tests/OutputTagMapTests.test.js.map +1 -0
  432. package/out/src/storage/schema/entities/__tests/OutputTagTests.test.d.ts +2 -0
  433. package/out/src/storage/schema/entities/__tests/OutputTagTests.test.d.ts.map +1 -0
  434. package/out/src/storage/schema/entities/__tests/OutputTagTests.test.js +440 -0
  435. package/out/src/storage/schema/entities/__tests/OutputTagTests.test.js.map +1 -0
  436. package/out/src/storage/schema/entities/__tests/OutputTests.test.d.ts +2 -0
  437. package/out/src/storage/schema/entities/__tests/OutputTests.test.d.ts.map +1 -0
  438. package/out/src/storage/schema/entities/__tests/OutputTests.test.js +626 -0
  439. package/out/src/storage/schema/entities/__tests/OutputTests.test.js.map +1 -0
  440. package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.d.ts +2 -0
  441. package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.d.ts.map +1 -0
  442. package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.js +585 -0
  443. package/out/src/storage/schema/entities/__tests/ProvenTxReqTests.test.js.map +1 -0
  444. package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.d.ts +2 -0
  445. package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.d.ts.map +1 -0
  446. package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.js +628 -0
  447. package/out/src/storage/schema/entities/__tests/ProvenTxTests.test.js.map +1 -0
  448. package/out/src/storage/schema/entities/__tests/SyncStateTests.test.d.ts +2 -0
  449. package/out/src/storage/schema/entities/__tests/SyncStateTests.test.d.ts.map +1 -0
  450. package/out/src/storage/schema/entities/__tests/SyncStateTests.test.js +307 -0
  451. package/out/src/storage/schema/entities/__tests/SyncStateTests.test.js.map +1 -0
  452. package/out/src/storage/schema/entities/__tests/TransactionTests.test.d.ts +2 -0
  453. package/out/src/storage/schema/entities/__tests/TransactionTests.test.d.ts.map +1 -0
  454. package/out/src/storage/schema/entities/__tests/TransactionTests.test.js +823 -0
  455. package/out/src/storage/schema/entities/__tests/TransactionTests.test.js.map +1 -0
  456. package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.d.ts +2 -0
  457. package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.d.ts.map +1 -0
  458. package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.js +442 -0
  459. package/out/src/storage/schema/entities/__tests/TxLabelMapTests.test.js.map +1 -0
  460. package/out/src/storage/schema/entities/__tests/TxLabelTests.test.d.ts +2 -0
  461. package/out/src/storage/schema/entities/__tests/TxLabelTests.test.d.ts.map +1 -0
  462. package/out/src/storage/schema/entities/__tests/TxLabelTests.test.js +313 -0
  463. package/out/src/storage/schema/entities/__tests/TxLabelTests.test.js.map +1 -0
  464. package/out/src/storage/schema/entities/__tests/stampLogTests.test.d.ts +2 -0
  465. package/out/src/storage/schema/entities/__tests/stampLogTests.test.d.ts.map +1 -0
  466. package/out/src/storage/schema/entities/__tests/stampLogTests.test.js +81 -0
  467. package/out/src/storage/schema/entities/__tests/stampLogTests.test.js.map +1 -0
  468. package/out/src/storage/schema/entities/__tests/usersTests.test.d.ts +2 -0
  469. package/out/src/storage/schema/entities/__tests/usersTests.test.d.ts.map +1 -0
  470. package/out/src/storage/schema/entities/__tests/usersTests.test.js +418 -0
  471. package/out/src/storage/schema/entities/__tests/usersTests.test.js.map +1 -0
  472. package/out/src/storage/schema/entities/index.d.ts +17 -0
  473. package/out/src/storage/schema/entities/index.d.ts.map +1 -0
  474. package/out/src/storage/schema/entities/index.js +33 -0
  475. package/out/src/storage/schema/entities/index.js.map +1 -0
  476. package/out/src/storage/schema/tables/Certificate.d.ts +20 -0
  477. package/out/src/storage/schema/tables/Certificate.d.ts.map +1 -0
  478. package/out/src/storage/schema/tables/Certificate.js +3 -0
  479. package/out/src/storage/schema/tables/Certificate.js.map +1 -0
  480. package/out/src/storage/schema/tables/CertificateField.d.ts +12 -0
  481. package/out/src/storage/schema/tables/CertificateField.d.ts.map +1 -0
  482. package/out/src/storage/schema/tables/CertificateField.js +3 -0
  483. package/out/src/storage/schema/tables/CertificateField.js.map +1 -0
  484. package/out/src/storage/schema/tables/Commission.d.ts +13 -0
  485. package/out/src/storage/schema/tables/Commission.d.ts.map +1 -0
  486. package/out/src/storage/schema/tables/Commission.js +3 -0
  487. package/out/src/storage/schema/tables/Commission.js.map +1 -0
  488. package/out/src/storage/schema/tables/MonitorEvent.d.ts +9 -0
  489. package/out/src/storage/schema/tables/MonitorEvent.d.ts.map +1 -0
  490. package/out/src/storage/schema/tables/MonitorEvent.js +3 -0
  491. package/out/src/storage/schema/tables/MonitorEvent.js.map +1 -0
  492. package/out/src/storage/schema/tables/Output.d.ts +36 -0
  493. package/out/src/storage/schema/tables/Output.d.ts.map +1 -0
  494. package/out/src/storage/schema/tables/Output.js +31 -0
  495. package/out/src/storage/schema/tables/Output.js.map +1 -0
  496. package/out/src/storage/schema/tables/OutputBasket.d.ts +12 -0
  497. package/out/src/storage/schema/tables/OutputBasket.d.ts.map +1 -0
  498. package/out/src/storage/schema/tables/OutputBasket.js +3 -0
  499. package/out/src/storage/schema/tables/OutputBasket.js.map +1 -0
  500. package/out/src/storage/schema/tables/OutputTag.d.ts +10 -0
  501. package/out/src/storage/schema/tables/OutputTag.d.ts.map +1 -0
  502. package/out/src/storage/schema/tables/OutputTag.js +3 -0
  503. package/out/src/storage/schema/tables/OutputTag.js.map +1 -0
  504. package/out/src/storage/schema/tables/OutputTagMap.d.ts +9 -0
  505. package/out/src/storage/schema/tables/OutputTagMap.d.ts.map +1 -0
  506. package/out/src/storage/schema/tables/OutputTagMap.js +3 -0
  507. package/out/src/storage/schema/tables/OutputTagMap.js.map +1 -0
  508. package/out/src/storage/schema/tables/ProvenTx.d.ts +14 -0
  509. package/out/src/storage/schema/tables/ProvenTx.d.ts.map +1 -0
  510. package/out/src/storage/schema/tables/ProvenTx.js +3 -0
  511. package/out/src/storage/schema/tables/ProvenTx.js.map +1 -0
  512. package/out/src/storage/schema/tables/ProvenTxReq.d.ts +64 -0
  513. package/out/src/storage/schema/tables/ProvenTxReq.d.ts.map +1 -0
  514. package/out/src/storage/schema/tables/ProvenTxReq.js +3 -0
  515. package/out/src/storage/schema/tables/ProvenTxReq.js.map +1 -0
  516. package/out/src/storage/schema/tables/Settings.d.ts +17 -0
  517. package/out/src/storage/schema/tables/Settings.d.ts.map +1 -0
  518. package/out/src/storage/schema/tables/Settings.js +3 -0
  519. package/out/src/storage/schema/tables/Settings.js.map +1 -0
  520. package/out/src/storage/schema/tables/SyncState.d.ts +18 -0
  521. package/out/src/storage/schema/tables/SyncState.d.ts.map +1 -0
  522. package/out/src/storage/schema/tables/SyncState.js +3 -0
  523. package/out/src/storage/schema/tables/SyncState.js.map +1 -0
  524. package/out/src/storage/schema/tables/Transaction.d.ts +37 -0
  525. package/out/src/storage/schema/tables/Transaction.d.ts.map +1 -0
  526. package/out/src/storage/schema/tables/Transaction.js +21 -0
  527. package/out/src/storage/schema/tables/Transaction.js.map +1 -0
  528. package/out/src/storage/schema/tables/TxLabel.d.ts +10 -0
  529. package/out/src/storage/schema/tables/TxLabel.d.ts.map +1 -0
  530. package/out/src/storage/schema/tables/TxLabel.js +3 -0
  531. package/out/src/storage/schema/tables/TxLabel.js.map +1 -0
  532. package/out/src/storage/schema/tables/TxLabelMap.d.ts +9 -0
  533. package/out/src/storage/schema/tables/TxLabelMap.d.ts.map +1 -0
  534. package/out/src/storage/schema/tables/TxLabelMap.js +3 -0
  535. package/out/src/storage/schema/tables/TxLabelMap.js.map +1 -0
  536. package/out/src/storage/schema/tables/User.d.ts +16 -0
  537. package/out/src/storage/schema/tables/User.d.ts.map +1 -0
  538. package/out/src/storage/schema/tables/User.js +3 -0
  539. package/out/src/storage/schema/tables/User.js.map +1 -0
  540. package/out/src/storage/schema/tables/index.d.ts +17 -0
  541. package/out/src/storage/schema/tables/index.d.ts.map +1 -0
  542. package/out/src/storage/schema/tables/index.js +33 -0
  543. package/out/src/storage/schema/tables/index.js.map +1 -0
  544. package/out/src/storage/sync/StorageMySQLDojoReader.d.ts +71 -0
  545. package/out/src/storage/sync/StorageMySQLDojoReader.d.ts.map +1 -0
  546. package/out/src/storage/sync/StorageMySQLDojoReader.js +612 -0
  547. package/out/src/storage/sync/StorageMySQLDojoReader.js.map +1 -0
  548. package/out/src/storage/sync/index.d.ts +2 -0
  549. package/out/src/storage/sync/index.d.ts.map +1 -0
  550. package/out/src/storage/sync/index.js +18 -0
  551. package/out/src/storage/sync/index.js.map +1 -0
  552. package/out/src/utility/ScriptTemplateSABPPP.d.ts +25 -0
  553. package/out/src/utility/ScriptTemplateSABPPP.d.ts.map +1 -0
  554. package/out/src/utility/ScriptTemplateSABPPP.js +46 -0
  555. package/out/src/utility/ScriptTemplateSABPPP.js.map +1 -0
  556. package/out/src/utility/index.all.d.ts +7 -0
  557. package/out/src/utility/index.all.d.ts.map +1 -0
  558. package/out/src/utility/index.all.js +23 -0
  559. package/out/src/utility/index.all.js.map +1 -0
  560. package/out/src/utility/index.client.d.ts +7 -0
  561. package/out/src/utility/index.client.d.ts.map +1 -0
  562. package/out/src/utility/index.client.js +23 -0
  563. package/out/src/utility/index.client.js.map +1 -0
  564. package/out/src/utility/parseTxScriptOffsets.d.ts +14 -0
  565. package/out/src/utility/parseTxScriptOffsets.d.ts.map +1 -0
  566. package/out/src/utility/parseTxScriptOffsets.js +26 -0
  567. package/out/src/utility/parseTxScriptOffsets.js.map +1 -0
  568. package/out/src/utility/stampLog.d.ts +18 -0
  569. package/out/src/utility/stampLog.d.ts.map +1 -0
  570. package/out/src/utility/stampLog.js +72 -0
  571. package/out/src/utility/stampLog.js.map +1 -0
  572. package/out/src/utility/tscProofToMerklePath.d.ts +8 -0
  573. package/out/src/utility/tscProofToMerklePath.d.ts.map +1 -0
  574. package/out/src/utility/tscProofToMerklePath.js +41 -0
  575. package/out/src/utility/tscProofToMerklePath.js.map +1 -0
  576. package/out/src/utility/utilityHelpers.buffer.d.ts +18 -0
  577. package/out/src/utility/utilityHelpers.buffer.d.ts.map +1 -0
  578. package/out/src/utility/utilityHelpers.buffer.js +45 -0
  579. package/out/src/utility/utilityHelpers.buffer.js.map +1 -0
  580. package/out/src/utility/utilityHelpers.d.ts +129 -0
  581. package/out/src/utility/utilityHelpers.d.ts.map +1 -0
  582. package/out/src/utility/utilityHelpers.js +268 -0
  583. package/out/src/utility/utilityHelpers.js.map +1 -0
  584. package/out/src/utility/utilityHelpers.noBuffer.d.ts +9 -0
  585. package/out/src/utility/utilityHelpers.noBuffer.d.ts.map +1 -0
  586. package/out/src/utility/utilityHelpers.noBuffer.js +23 -0
  587. package/out/src/utility/utilityHelpers.noBuffer.js.map +1 -0
  588. package/out/test/Wallet/StorageClient/storageClient.man.test.d.ts +2 -0
  589. package/out/test/Wallet/StorageClient/storageClient.man.test.d.ts.map +1 -0
  590. package/out/test/Wallet/StorageClient/storageClient.man.test.js +45 -0
  591. package/out/test/Wallet/StorageClient/storageClient.man.test.js.map +1 -0
  592. package/out/test/Wallet/action/internalizeAction.a.test.d.ts +2 -0
  593. package/out/test/Wallet/action/internalizeAction.a.test.d.ts.map +1 -0
  594. package/out/test/Wallet/action/internalizeAction.a.test.js +243 -0
  595. package/out/test/Wallet/action/internalizeAction.a.test.js.map +1 -0
  596. package/out/test/Wallet/certificate/acquireCertificate.test.d.ts +2 -0
  597. package/out/test/Wallet/certificate/acquireCertificate.test.d.ts.map +1 -0
  598. package/out/test/Wallet/certificate/acquireCertificate.test.js +213 -0
  599. package/out/test/Wallet/certificate/acquireCertificate.test.js.map +1 -0
  600. package/out/test/Wallet/certificate/listCertificates.test.d.ts +2 -0
  601. package/out/test/Wallet/certificate/listCertificates.test.d.ts.map +1 -0
  602. package/out/test/Wallet/certificate/listCertificates.test.js +305 -0
  603. package/out/test/Wallet/certificate/listCertificates.test.js.map +1 -0
  604. package/out/test/Wallet/get/getHeaderForHeight.test.d.ts +2 -0
  605. package/out/test/Wallet/get/getHeaderForHeight.test.d.ts.map +1 -0
  606. package/out/test/Wallet/get/getHeaderForHeight.test.js +68 -0
  607. package/out/test/Wallet/get/getHeaderForHeight.test.js.map +1 -0
  608. package/out/test/Wallet/get/getHeight.test.d.ts +2 -0
  609. package/out/test/Wallet/get/getHeight.test.d.ts.map +1 -0
  610. package/out/test/Wallet/get/getHeight.test.js +45 -0
  611. package/out/test/Wallet/get/getHeight.test.js.map +1 -0
  612. package/out/test/Wallet/get/getKnownTxids.test.d.ts +2 -0
  613. package/out/test/Wallet/get/getKnownTxids.test.d.ts.map +1 -0
  614. package/out/test/Wallet/get/getKnownTxids.test.js +73 -0
  615. package/out/test/Wallet/get/getKnownTxids.test.js.map +1 -0
  616. package/out/test/Wallet/get/getNetwork.test.d.ts +2 -0
  617. package/out/test/Wallet/get/getNetwork.test.d.ts.map +1 -0
  618. package/out/test/Wallet/get/getNetwork.test.js +26 -0
  619. package/out/test/Wallet/get/getNetwork.test.js.map +1 -0
  620. package/out/test/Wallet/get/getVersion.test.d.ts +2 -0
  621. package/out/test/Wallet/get/getVersion.test.d.ts.map +1 -0
  622. package/out/test/Wallet/get/getVersion.test.js +25 -0
  623. package/out/test/Wallet/get/getVersion.test.js.map +1 -0
  624. package/out/test/Wallet/live/walletLive.man.test.d.ts +26 -0
  625. package/out/test/Wallet/live/walletLive.man.test.d.ts.map +1 -0
  626. package/out/test/Wallet/live/walletLive.man.test.js +389 -0
  627. package/out/test/Wallet/live/walletLive.man.test.js.map +1 -0
  628. package/out/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.d.ts +2 -0
  629. package/out/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.d.ts.map +1 -0
  630. package/out/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.js +153 -0
  631. package/out/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.js.map +1 -0
  632. package/out/test/checkDB.d.ts +4 -0
  633. package/out/test/checkDB.d.ts.map +1 -0
  634. package/out/test/checkDB.js +55 -0
  635. package/out/test/checkDB.js.map +1 -0
  636. package/out/test/examples/README.man.test.d.ts +2 -0
  637. package/out/test/examples/README.man.test.d.ts.map +1 -0
  638. package/out/test/examples/README.man.test.js +46 -0
  639. package/out/test/examples/README.man.test.js.map +1 -0
  640. package/out/test/monitor/Monitor.test.d.ts +2 -0
  641. package/out/test/monitor/Monitor.test.d.ts.map +1 -0
  642. package/out/test/monitor/Monitor.test.js +446 -0
  643. package/out/test/monitor/Monitor.test.js.map +1 -0
  644. package/out/test/services/Services.test.d.ts +2 -0
  645. package/out/test/services/Services.test.d.ts.map +1 -0
  646. package/out/test/services/Services.test.js +128 -0
  647. package/out/test/services/Services.test.js.map +1 -0
  648. package/out/test/storage/KnexMigrations.test.d.ts +2 -0
  649. package/out/test/storage/KnexMigrations.test.d.ts.map +1 -0
  650. package/out/test/storage/KnexMigrations.test.js +81 -0
  651. package/out/test/storage/KnexMigrations.test.js.map +1 -0
  652. package/out/test/storage/StorageMySQLDojoReader.man.test.d.ts +2 -0
  653. package/out/test/storage/StorageMySQLDojoReader.man.test.d.ts.map +1 -0
  654. package/out/test/storage/StorageMySQLDojoReader.man.test.js +88 -0
  655. package/out/test/storage/StorageMySQLDojoReader.man.test.js.map +1 -0
  656. package/out/test/storage/count.test.d.ts +2 -0
  657. package/out/test/storage/count.test.d.ts.map +1 -0
  658. package/out/test/storage/count.test.js +141 -0
  659. package/out/test/storage/count.test.js.map +1 -0
  660. package/out/test/storage/find.test.d.ts +2 -0
  661. package/out/test/storage/find.test.d.ts.map +1 -0
  662. package/out/test/storage/find.test.js +148 -0
  663. package/out/test/storage/find.test.js.map +1 -0
  664. package/out/test/storage/findLegacy.test.d.ts +2 -0
  665. package/out/test/storage/findLegacy.test.d.ts.map +1 -0
  666. package/out/test/storage/findLegacy.test.js +52 -0
  667. package/out/test/storage/findLegacy.test.js.map +1 -0
  668. package/out/test/storage/insert.test.d.ts +2 -0
  669. package/out/test/storage/insert.test.d.ts.map +1 -0
  670. package/out/test/storage/insert.test.js +256 -0
  671. package/out/test/storage/insert.test.js.map +1 -0
  672. package/out/test/storage/update.test.d.ts +2 -0
  673. package/out/test/storage/update.test.d.ts.map +1 -0
  674. package/out/test/storage/update.test.js +926 -0
  675. package/out/test/storage/update.test.js.map +1 -0
  676. package/out/test/storage/update2.test.d.ts +2 -0
  677. package/out/test/storage/update2.test.d.ts.map +1 -0
  678. package/out/test/storage/update2.test.js +766 -0
  679. package/out/test/storage/update2.test.js.map +1 -0
  680. package/out/test/utils/TestUtilsWalletStorage.d.ts +399 -0
  681. package/out/test/utils/TestUtilsWalletStorage.d.ts.map +1 -0
  682. package/out/test/utils/TestUtilsWalletStorage.js +1337 -0
  683. package/out/test/utils/TestUtilsWalletStorage.js.map +1 -0
  684. package/out/test/wallet/action/abortAction.test.d.ts +2 -0
  685. package/out/test/wallet/action/abortAction.test.d.ts.map +1 -0
  686. package/out/test/wallet/action/abortAction.test.js +44 -0
  687. package/out/test/wallet/action/abortAction.test.js.map +1 -0
  688. package/out/test/wallet/action/createAction.test.d.ts +2 -0
  689. package/out/test/wallet/action/createAction.test.d.ts.map +1 -0
  690. package/out/test/wallet/action/createAction.test.js +230 -0
  691. package/out/test/wallet/action/createAction.test.js.map +1 -0
  692. package/out/test/wallet/action/createActionToGenerateBeefs.man.test.d.ts +2 -0
  693. package/out/test/wallet/action/createActionToGenerateBeefs.man.test.d.ts.map +1 -0
  694. package/out/test/wallet/action/createActionToGenerateBeefs.man.test.js +273 -0
  695. package/out/test/wallet/action/createActionToGenerateBeefs.man.test.js.map +1 -0
  696. package/out/test/wallet/action/internalizeAction.test.d.ts +2 -0
  697. package/out/test/wallet/action/internalizeAction.test.d.ts.map +1 -0
  698. package/out/test/wallet/action/internalizeAction.test.js +603 -0
  699. package/out/test/wallet/action/internalizeAction.test.js.map +1 -0
  700. package/out/test/wallet/action/relinquishOutput.test.d.ts +2 -0
  701. package/out/test/wallet/action/relinquishOutput.test.d.ts.map +1 -0
  702. package/out/test/wallet/action/relinquishOutput.test.js +31 -0
  703. package/out/test/wallet/action/relinquishOutput.test.js.map +1 -0
  704. package/out/test/wallet/construct/Wallet.constructor.test.d.ts +2 -0
  705. package/out/test/wallet/construct/Wallet.constructor.test.d.ts.map +1 -0
  706. package/out/test/wallet/construct/Wallet.constructor.test.js +49 -0
  707. package/out/test/wallet/construct/Wallet.constructor.test.js.map +1 -0
  708. package/out/test/wallet/list/listActions.test.d.ts +2 -0
  709. package/out/test/wallet/list/listActions.test.d.ts.map +1 -0
  710. package/out/test/wallet/list/listActions.test.js +265 -0
  711. package/out/test/wallet/list/listActions.test.js.map +1 -0
  712. package/out/test/wallet/list/listActions2.test.d.ts +2 -0
  713. package/out/test/wallet/list/listActions2.test.d.ts.map +1 -0
  714. package/out/test/wallet/list/listActions2.test.js +423 -0
  715. package/out/test/wallet/list/listActions2.test.js.map +1 -0
  716. package/out/test/wallet/list/listCertificates.test.d.ts +2 -0
  717. package/out/test/wallet/list/listCertificates.test.d.ts.map +1 -0
  718. package/out/test/wallet/list/listCertificates.test.js +115 -0
  719. package/out/test/wallet/list/listCertificates.test.js.map +1 -0
  720. package/out/test/wallet/list/listOutputs.test.d.ts +2 -0
  721. package/out/test/wallet/list/listOutputs.test.d.ts.map +1 -0
  722. package/out/test/wallet/list/listOutputs.test.js +521 -0
  723. package/out/test/wallet/list/listOutputs.test.js.map +1 -0
  724. package/out/test/wallet/sync/Wallet.sync.test.d.ts +2 -0
  725. package/out/test/wallet/sync/Wallet.sync.test.d.ts.map +1 -0
  726. package/out/test/wallet/sync/Wallet.sync.test.js +142 -0
  727. package/out/test/wallet/sync/Wallet.sync.test.js.map +1 -0
  728. package/out/tsconfig.all.tsbuildinfo +1 -0
  729. package/package.json +63 -0
  730. package/src/Wallet.ts +771 -0
  731. package/src/index.all.ts +8 -0
  732. package/src/index.client.ts +7 -0
  733. package/src/index.ts +2 -0
  734. package/src/monitor/Monitor.ts +317 -0
  735. package/src/monitor/MonitorDaemon.ts +197 -0
  736. package/src/monitor/README.md +3 -0
  737. package/src/monitor/__test/MonitorDaemon.man.test.ts +17 -0
  738. package/src/monitor/tasks/TaskCheckForProofs.ts +235 -0
  739. package/src/monitor/tasks/TaskClock.ts +35 -0
  740. package/src/monitor/tasks/TaskFailAbandoned.ts +56 -0
  741. package/src/monitor/tasks/TaskNewHeader.ts +48 -0
  742. package/src/monitor/tasks/TaskPurge.ts +69 -0
  743. package/src/monitor/tasks/TaskReviewStatus.ts +51 -0
  744. package/src/monitor/tasks/TaskSendWaiting.ts +107 -0
  745. package/src/monitor/tasks/TaskSyncWhenIdle.ts +26 -0
  746. package/src/monitor/tasks/WalletMonitorTask.ts +47 -0
  747. package/src/sdk/CertOps.ts +346 -0
  748. package/src/sdk/PrivilegedKeyManager.ts +402 -0
  749. package/src/sdk/README.md +13 -0
  750. package/src/sdk/StorageSyncReader.ts +155 -0
  751. package/src/sdk/StorageSyncReaderWriter.ts +263 -0
  752. package/src/sdk/WERR_errors.ts +152 -0
  753. package/src/sdk/WalletError.ts +136 -0
  754. package/src/sdk/WalletServices.interfaces.ts +399 -0
  755. package/src/sdk/WalletSigner.interfaces.ts +38 -0
  756. package/src/sdk/WalletStorage.interfaces.ts +416 -0
  757. package/src/sdk/__test/CertificateLifeCycle.test.ts +194 -0
  758. package/src/sdk/__test/PrivilegedKeyManager.test.ts +775 -0
  759. package/src/sdk/index.ts +11 -0
  760. package/src/sdk/types.ts +115 -0
  761. package/src/sdk/validationHelpers.ts +1248 -0
  762. package/src/services/README.md +11 -0
  763. package/src/services/ServiceCollection.ts +50 -0
  764. package/src/services/Services.ts +461 -0
  765. package/src/services/__tests/getMerklePath.test.ts +16 -0
  766. package/src/services/__tests/getRawTx.test.ts +15 -0
  767. package/src/services/__tests/postBeef.test.ts +19 -0
  768. package/src/services/__tests/postBeefToArcTaal.test.ts +487 -0
  769. package/src/services/__tests/postTxs.test.ts +20 -0
  770. package/src/services/chaintracker/ChaintracksChainTracker.ts +78 -0
  771. package/src/services/chaintracker/__tests/ChaintracksChainTracker.test.ts +25 -0
  772. package/src/services/chaintracker/__tests/ChaintracksServiceClient.test.ts +32 -0
  773. package/src/services/chaintracker/chaintracks/BlockHeaderApi.ts +123 -0
  774. package/src/services/chaintracker/chaintracks/ChaintracksServiceClient.ts +160 -0
  775. package/src/services/chaintracker/chaintracks/index.ts +2 -0
  776. package/src/services/chaintracker/index.ts +2 -0
  777. package/src/services/createDefaultWalletServicesOptions.ts +38 -0
  778. package/src/services/index.ts +1 -0
  779. package/src/services/providers/arcServices.ts +570 -0
  780. package/src/services/providers/echangeRates.ts +276 -0
  781. package/src/services/providers/whatsonchain.ts +170 -0
  782. package/src/signer/README.md +5 -0
  783. package/src/signer/WalletSigner.ts +21 -0
  784. package/src/signer/methods/acquireDirectCertificate.ts +53 -0
  785. package/src/signer/methods/createAction.ts +364 -0
  786. package/src/signer/methods/internalizeAction.ts +142 -0
  787. package/src/signer/methods/proveCertificate.ts +51 -0
  788. package/src/signer/methods/signAction.ts +121 -0
  789. package/src/storage/README.md +14 -0
  790. package/src/storage/StorageKnex.ts +1449 -0
  791. package/src/storage/StorageProvider.ts +853 -0
  792. package/src/storage/StorageReader.ts +222 -0
  793. package/src/storage/StorageReaderWriter.ts +623 -0
  794. package/src/storage/StorageSyncReader.ts +143 -0
  795. package/src/storage/WalletStorageManager.ts +532 -0
  796. package/src/storage/__test/WalletStorageManager.test.ts +292 -0
  797. package/src/storage/index.all.ts +10 -0
  798. package/src/storage/index.client.ts +6 -0
  799. package/src/storage/index.db.ts +0 -0
  800. package/src/storage/methods/__test/GenerateChange/generateChangeSdk.test.ts +1143 -0
  801. package/src/storage/methods/__test/GenerateChange/randomValsUsed1.ts +31 -0
  802. package/src/storage/methods/attemptToPostReqsToNetwork.ts +185 -0
  803. package/src/storage/methods/createAction.ts +997 -0
  804. package/src/storage/methods/generateChange.ts +629 -0
  805. package/src/storage/methods/getBeefForTransaction.ts +143 -0
  806. package/src/storage/methods/getSyncChunk.ts +330 -0
  807. package/src/storage/methods/internalizeAction.ts +538 -0
  808. package/src/storage/methods/listActions.ts +203 -0
  809. package/src/storage/methods/listCertificates.ts +81 -0
  810. package/src/storage/methods/listOutputs.ts +219 -0
  811. package/src/storage/methods/processAction.ts +477 -0
  812. package/src/storage/methods/purgeData.ts +276 -0
  813. package/src/storage/methods/reviewStatus.ts +95 -0
  814. package/src/storage/remoting/StorageClient.ts +306 -0
  815. package/src/storage/remoting/StorageServer.ts +179 -0
  816. package/src/storage/schema/KnexMigrations.ts +488 -0
  817. package/src/storage/schema/entities/Certificate.ts +199 -0
  818. package/src/storage/schema/entities/CertificateField.ts +157 -0
  819. package/src/storage/schema/entities/Commission.ts +169 -0
  820. package/src/storage/schema/entities/EntityBase.ts +214 -0
  821. package/src/storage/schema/entities/MergeEntity.ts +79 -0
  822. package/src/storage/schema/entities/Output.ts +323 -0
  823. package/src/storage/schema/entities/OutputBasket.ts +165 -0
  824. package/src/storage/schema/entities/OutputTag.ts +138 -0
  825. package/src/storage/schema/entities/OutputTagMap.ts +146 -0
  826. package/src/storage/schema/entities/ProvenTx.ts +349 -0
  827. package/src/storage/schema/entities/ProvenTxReq.ts +646 -0
  828. package/src/storage/schema/entities/SyncState.ts +429 -0
  829. package/src/storage/schema/entities/Transaction.ts +334 -0
  830. package/src/storage/schema/entities/TxLabel.ts +135 -0
  831. package/src/storage/schema/entities/TxLabelMap.ts +148 -0
  832. package/src/storage/schema/entities/User.ts +138 -0
  833. package/src/storage/schema/entities/__tests/CertificateFieldTests.test.ts +663 -0
  834. package/src/storage/schema/entities/__tests/CertificateTests.test.ts +527 -0
  835. package/src/storage/schema/entities/__tests/CommissionTests.test.ts +658 -0
  836. package/src/storage/schema/entities/__tests/OutputBasketTests.test.ts +567 -0
  837. package/src/storage/schema/entities/__tests/OutputTagMapTests.test.ts +530 -0
  838. package/src/storage/schema/entities/__tests/OutputTagTests.test.ts +504 -0
  839. package/src/storage/schema/entities/__tests/OutputTests.test.ts +689 -0
  840. package/src/storage/schema/entities/__tests/ProvenTxReqTests.test.ts +669 -0
  841. package/src/storage/schema/entities/__tests/ProvenTxTests.test.ts +700 -0
  842. package/src/storage/schema/entities/__tests/SyncStateTests.test.ts +376 -0
  843. package/src/storage/schema/entities/__tests/TransactionTests.test.ts +920 -0
  844. package/src/storage/schema/entities/__tests/TxLabelMapTests.test.ts +512 -0
  845. package/src/storage/schema/entities/__tests/TxLabelTests.test.ts +350 -0
  846. package/src/storage/schema/entities/__tests/stampLogTests.test.ts +97 -0
  847. package/src/storage/schema/entities/__tests/usersTests.test.ts +485 -0
  848. package/src/storage/schema/entities/index.ts +16 -0
  849. package/src/storage/schema/tables/Certificate.ts +21 -0
  850. package/src/storage/schema/tables/CertificateField.ts +12 -0
  851. package/src/storage/schema/tables/Commission.ts +13 -0
  852. package/src/storage/schema/tables/MonitorEvent.ts +9 -0
  853. package/src/storage/schema/tables/Output.ts +64 -0
  854. package/src/storage/schema/tables/OutputBasket.ts +12 -0
  855. package/src/storage/schema/tables/OutputTag.ts +10 -0
  856. package/src/storage/schema/tables/OutputTagMap.ts +9 -0
  857. package/src/storage/schema/tables/ProvenTx.ts +14 -0
  858. package/src/storage/schema/tables/ProvenTxReq.ts +65 -0
  859. package/src/storage/schema/tables/Settings.ts +17 -0
  860. package/src/storage/schema/tables/SyncState.ts +18 -0
  861. package/src/storage/schema/tables/Transaction.ts +54 -0
  862. package/src/storage/schema/tables/TxLabel.ts +10 -0
  863. package/src/storage/schema/tables/TxLabelMap.ts +9 -0
  864. package/src/storage/schema/tables/User.ts +16 -0
  865. package/src/storage/schema/tables/index.ts +16 -0
  866. package/src/storage/sync/StorageMySQLDojoReader.ts +771 -0
  867. package/src/storage/sync/index.ts +1 -0
  868. package/src/utility/README.md +3 -0
  869. package/src/utility/ScriptTemplateSABPPP.ts +79 -0
  870. package/src/utility/index.all.ts +7 -0
  871. package/src/utility/index.client.ts +7 -0
  872. package/src/utility/parseTxScriptOffsets.ts +29 -0
  873. package/src/utility/stampLog.ts +73 -0
  874. package/src/utility/tscProofToMerklePath.ts +51 -0
  875. package/src/utility/utilityHelpers.buffer.ts +43 -0
  876. package/src/utility/utilityHelpers.noBuffer.ts +18 -0
  877. package/src/utility/utilityHelpers.ts +283 -0
  878. package/test/Wallet/StorageClient/storageClient.man.test.ts +55 -0
  879. package/test/Wallet/action/internalizeAction.a.test.ts +301 -0
  880. package/test/Wallet/certificate/acquireCertificate.test.ts +253 -0
  881. package/test/Wallet/certificate/listCertificates.test.ts +352 -0
  882. package/test/Wallet/get/getHeaderForHeight.test.ts +79 -0
  883. package/test/Wallet/get/getHeight.test.ts +52 -0
  884. package/test/Wallet/get/getKnownTxids.test.ts +90 -0
  885. package/test/Wallet/get/getNetwork.test.ts +28 -0
  886. package/test/Wallet/get/getVersion.test.ts +28 -0
  887. package/test/Wallet/live/walletLive.man.test.ts +510 -0
  888. package/test/Wallet/sync/Wallet.updateWalletLegacyTestData.man.test.ts +155 -0
  889. package/test/checkDB.ts +63 -0
  890. package/test/checkdb +0 -0
  891. package/test/examples/README.man.test.ts +53 -0
  892. package/test/monitor/Monitor.test.ts +536 -0
  893. package/test/services/Services.test.ts +149 -0
  894. package/test/storage/KnexMigrations.test.ts +100 -0
  895. package/test/storage/StorageMySQLDojoReader.man.test.ts +71 -0
  896. package/test/storage/count.test.ts +193 -0
  897. package/test/storage/find.test.ts +216 -0
  898. package/test/storage/findLegacy.test.ts +70 -0
  899. package/test/storage/insert.test.ts +294 -0
  900. package/test/storage/update.test.ts +1146 -0
  901. package/test/storage/update2.test.ts +1017 -0
  902. package/test/utils/TestUtilsWalletStorage.ts +1923 -0
  903. package/test/utils/removeFailedFromDatabase.sql +17 -0
  904. package/test/wallet/action/abortAction.test.ts +55 -0
  905. package/test/wallet/action/createAction.test.ts +266 -0
  906. package/test/wallet/action/createActionToGenerateBeefs.man.test.ts +297 -0
  907. package/test/wallet/action/internalizeAction.test.ts +729 -0
  908. package/test/wallet/action/relinquishOutput.test.ts +43 -0
  909. package/test/wallet/construct/Wallet.constructor.test.ts +57 -0
  910. package/test/wallet/list/listActions.test.ts +282 -0
  911. package/test/wallet/list/listActions2.test.ts +570 -0
  912. package/test/wallet/list/listCertificates.test.ts +129 -0
  913. package/test/wallet/list/listOutputs.test.ts +573 -0
  914. package/test/wallet/sync/Wallet.sync.test.ts +226 -0
  915. package/ts2md.json +32 -0
  916. package/tsconfig.all.json +29 -0
  917. package/tsconfig.client.json +22 -0
  918. package/tsconfig.json +14 -0
  919. package/unlock-migrations.sh +41 -0
@@ -0,0 +1,213 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const sdk_1 = require("@bsv/sdk");
4
+ const TestUtilsWalletStorage_1 = require("../../utils/TestUtilsWalletStorage");
5
+ const index_all_1 = require("../../../src/index.all");
6
+ describe('acquireCertificate tests', () => {
7
+ jest.setTimeout(99999999);
8
+ const env = TestUtilsWalletStorage_1._tu.getEnv('test');
9
+ beforeAll(async () => { });
10
+ afterAll(async () => { });
11
+ test('1 invalid params', async () => {
12
+ const { wallet, storage } = await TestUtilsWalletStorage_1._tu.createLegacyWalletSQLiteCopy('acquireCertificate1');
13
+ const invalidArgs = [
14
+ {
15
+ type: '',
16
+ certifier: '',
17
+ acquisitionProtocol: 'direct',
18
+ fields: {}
19
+ }
20
+ // Oh so many things to test...
21
+ ];
22
+ for (const args of invalidArgs) {
23
+ await (0, TestUtilsWalletStorage_1.expectToThrowWERR)(index_all_1.sdk.WERR_INVALID_PARAMETER, () => wallet.acquireCertificate(args));
24
+ }
25
+ await storage.destroy();
26
+ });
27
+ test('2 acquireCertificate listCertificate proveCertificate', async () => {
28
+ const { wallet, storage } = await TestUtilsWalletStorage_1._tu.createSQLiteTestWallet({
29
+ databaseName: 'acquireCertificate2',
30
+ dropAll: true
31
+ });
32
+ // Make a test certificate from a random certifier for the wallet's identityKey
33
+ const subject = wallet.keyDeriver.identityKey;
34
+ const { cert, certifier } = TestUtilsWalletStorage_1._tu.makeSampleCert(subject);
35
+ // Act as the certifier: create a wallet for them...
36
+ const certifierWallet = new sdk_1.CompletedProtoWallet(certifier);
37
+ // load the plaintext certificate into a CertOps object
38
+ const co = new index_all_1.sdk.CertOps(certifierWallet, cert);
39
+ // encrypt and sign the certificate
40
+ await co.encryptAndSignNewCertificate();
41
+ // export the signed certificate and a keyring for this wallet's identity as counterparty
42
+ const { certificate: c, keyring: kr } = co.exportForSubject();
43
+ // args object to create a new certificate via 'direct' protocol.
44
+ const args = {
45
+ serialNumber: c.serialNumber,
46
+ signature: c.signature,
47
+ privileged: false,
48
+ privilegedReason: undefined,
49
+ type: c.type,
50
+ certifier: c.certifier,
51
+ acquisitionProtocol: 'direct',
52
+ fields: c.fields,
53
+ keyringForSubject: kr,
54
+ keyringRevealer: 'certifier',
55
+ revocationOutpoint: c.revocationOutpoint
56
+ };
57
+ // store the new signed certificate in user's wallet
58
+ const r = await wallet.acquireCertificate(args);
59
+ expect(r.serialNumber).toBe(c.serialNumber);
60
+ // Attempt to retrieve it... since
61
+ // the certifier is random this should
62
+ // always be unique :-)
63
+ const lcs = await wallet.listCertificates({
64
+ certifiers: [cert.certifier],
65
+ types: []
66
+ });
67
+ expect(lcs.certificates.length).toBe(1);
68
+ const lc = lcs.certificates[0];
69
+ // the result should be encrypted.
70
+ expect(lc.fields['name']).not.toBe('Alice');
71
+ // Use proveCertificate to obtain a decryption keyring:
72
+ const pkrArgs = {
73
+ certificate: { serialNumber: lc.serialNumber },
74
+ fieldsToReveal: ['name'],
75
+ verifier: subject
76
+ };
77
+ const pkr = await wallet.proveCertificate(pkrArgs);
78
+ const co2 = await index_all_1.sdk.CertOps.fromCounterparty(wallet, {
79
+ certificate: lc,
80
+ keyring: pkr.keyringForVerifier,
81
+ counterparty: pkrArgs.verifier
82
+ });
83
+ expect(co2._decryptedFields['name']).toBe('Alice');
84
+ const certs = await wallet.listCertificates({ types: [], certifiers: [] });
85
+ for (const cert of certs.certificates) {
86
+ const rr = await wallet.relinquishCertificate({
87
+ type: cert.type,
88
+ serialNumber: cert.serialNumber,
89
+ certifier: cert.certifier
90
+ });
91
+ expect(rr.relinquished).toBe(true);
92
+ }
93
+ await storage.destroy();
94
+ });
95
+ test('3 privileged acquireCertificate listCertificate proveCertificate', async () => {
96
+ const { wallet, storage } = await TestUtilsWalletStorage_1._tu.createSQLiteTestWallet({
97
+ databaseName: 'acquireCertificate3',
98
+ privKeyHex: '42'.repeat(32),
99
+ dropAll: true
100
+ });
101
+ // Make a test certificate from a random certifier for the wallet's identityKey
102
+ // Certificate issued to the privileged key must use the privilegedKeyManager's identityKey
103
+ const subject = (await wallet.privilegedKeyManager.getPublicKey({ identityKey: true })).publicKey;
104
+ const { cert, certifier } = TestUtilsWalletStorage_1._tu.makeSampleCert(subject);
105
+ // Act as the certifier: create a wallet for them...
106
+ const certifierWallet = new sdk_1.CompletedProtoWallet(certifier);
107
+ // load the plaintext certificate into a CertOps object
108
+ const co = new index_all_1.sdk.CertOps(certifierWallet, cert);
109
+ // encrypt and sign the certificate
110
+ await co.encryptAndSignNewCertificate();
111
+ // export the signed certificate and a keyring for this wallet's identity as counterparty
112
+ const { certificate: c, keyring: kr } = co.exportForSubject();
113
+ // args object to create a new certificate via 'direct' protocol.
114
+ const args = {
115
+ serialNumber: c.serialNumber,
116
+ signature: c.signature,
117
+ privileged: true,
118
+ privilegedReason: 'access to my penthouse',
119
+ type: c.type,
120
+ certifier: c.certifier,
121
+ acquisitionProtocol: 'direct',
122
+ fields: c.fields,
123
+ keyringForSubject: kr,
124
+ keyringRevealer: 'certifier',
125
+ revocationOutpoint: c.revocationOutpoint
126
+ };
127
+ // store the new signed certificate in user's wallet
128
+ const r = await wallet.acquireCertificate(args);
129
+ expect(r.serialNumber).toBe(c.serialNumber);
130
+ // Attempt to retrieve it... since
131
+ // the certifier is random this should
132
+ // always be unique :-)
133
+ const lcs = await wallet.listCertificates({
134
+ certifiers: [cert.certifier],
135
+ types: []
136
+ });
137
+ expect(lcs.certificates.length).toBe(1);
138
+ const lc = lcs.certificates[0];
139
+ // the result should be encrypted.
140
+ expect(lc.fields['name']).not.toBe('Alice');
141
+ // Use proveCertificate to obtain a decryption keyring:
142
+ const pkrArgs = {
143
+ certificate: { serialNumber: lc.serialNumber },
144
+ fieldsToReveal: ['name'],
145
+ verifier: subject
146
+ };
147
+ const pkr = await wallet.proveCertificate(pkrArgs);
148
+ const co2 = await index_all_1.sdk.CertOps.fromCounterparty(wallet.privilegedKeyManager, {
149
+ certificate: lc,
150
+ keyring: pkr.keyringForVerifier,
151
+ counterparty: pkrArgs.verifier
152
+ });
153
+ expect(co2._decryptedFields['name']).toBe('Alice');
154
+ const certs = await wallet.listCertificates({ types: [], certifiers: [] });
155
+ for (const cert of certs.certificates) {
156
+ const rr = await wallet.relinquishCertificate({
157
+ type: cert.type,
158
+ serialNumber: cert.serialNumber,
159
+ certifier: cert.certifier
160
+ });
161
+ expect(rr.relinquished).toBe(true);
162
+ }
163
+ // Also cleans up the privilegedKeyManager
164
+ await wallet.destroy();
165
+ });
166
+ /**
167
+ * NOTE: This test requires a generic-certifier-backend to be running
168
+ * with the following configuration:
169
+ *
170
+ * type: 'h53Tvo8w3nqeF2cPyuRUc/B+gjPXJ3gPS2PKFBZfpDw=',
171
+ * certifierIdentityKey: '02be1093d98689b5a5bb49cefff5d98a390213cc5b0a5cd57459407f86a963325f',
172
+ */
173
+ test.skip('acquireCertificate via issuance', async () => {
174
+ const { wallet, storage } = await TestUtilsWalletStorage_1._tu.createSQLiteTestWallet({
175
+ databaseName: 'acquireCertificate2',
176
+ dropAll: true
177
+ });
178
+ // Attributes to get certified
179
+ const fields = {
180
+ name: 'Bob',
181
+ email: 'bob@projectbabbage.com'
182
+ };
183
+ // args object to create a new certificate via 'issuance' protocol.
184
+ const args = {
185
+ type: 'h53Tvo8w3nqeF2cPyuRUc/B+gjPXJ3gPS2PKFBZfpDw=',
186
+ certifier: '02be1093d98689b5a5bb49cefff5d98a390213cc5b0a5cd57459407f86a963325f',
187
+ certifierUrl: 'http://localhost:3998',
188
+ acquisitionProtocol: 'issuance',
189
+ fields: fields
190
+ };
191
+ // store the new signed certificate in user's wallet
192
+ const r = await wallet.acquireCertificate(args);
193
+ const certificatesFound = await wallet.listCertificates({
194
+ certifiers: [args.certifier],
195
+ types: []
196
+ });
197
+ expect(certificatesFound.certificates.length).toBe(1);
198
+ const lc = certificatesFound.certificates[0];
199
+ // the result should be encrypted.
200
+ expect(lc.fields['name']).not.toBe('Alice');
201
+ // const certs = await wallet.listCertificates({ types: [], certifiers: [] })
202
+ for (const cert of certificatesFound.certificates) {
203
+ const rr = await wallet.relinquishCertificate({
204
+ type: cert.type,
205
+ serialNumber: cert.serialNumber,
206
+ certifier: cert.certifier
207
+ });
208
+ expect(rr.relinquished).toBe(true);
209
+ }
210
+ await storage.destroy();
211
+ });
212
+ });
213
+ //# sourceMappingURL=acquireCertificate.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acquireCertificate.test.js","sourceRoot":"","sources":["../../../../test/Wallet/certificate/acquireCertificate.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=listCertificates.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listCertificates.test.d.ts","sourceRoot":"","sources":["../../../../test/Wallet/certificate/listCertificates.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,305 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const listCertificates_1 = require("../../../src/storage/methods/listCertificates");
4
+ jest.mock('../../../src/storage/StorageProvider');
5
+ describe('listCertificates', () => {
6
+ let mockStorage;
7
+ let auth;
8
+ // This is a valid, minimal set of arguments for listCertificates
9
+ let vargs;
10
+ let originator;
11
+ // Helper so we can easily mock the transaction call
12
+ const mockTransaction = async (callback) => {
13
+ // We simulate the transaction by simply calling back immediately
14
+ // with an empty object as trx token.
15
+ return callback({});
16
+ };
17
+ beforeEach(() => {
18
+ // Create a fresh mock of the storage
19
+ mockStorage = {
20
+ // We only need to mock the methods that are actually used by listCertificates
21
+ transaction: jest.fn().mockImplementation(mockTransaction),
22
+ findCertificates: jest.fn(),
23
+ findCertificateFields: jest.fn(),
24
+ countCertificates: jest.fn()
25
+ };
26
+ // Auth with a valid user ID
27
+ auth = {
28
+ identityKey: 'myIdentityKey',
29
+ userId: 123
30
+ };
31
+ // Minimal valid vargs with default limit=10, offset=0, no partial filter
32
+ vargs = {
33
+ partial: undefined,
34
+ certifiers: [],
35
+ types: [],
36
+ limit: 10,
37
+ offset: 0,
38
+ privileged: false
39
+ };
40
+ // By default we set it to undefined
41
+ originator = undefined;
42
+ });
43
+ afterEach(() => {
44
+ jest.clearAllMocks();
45
+ });
46
+ test('should return an empty result when no certificates are found', async () => {
47
+ // Setup mocks
48
+ mockStorage.findCertificates.mockResolvedValueOnce([]); // no certs returned
49
+ // Execute
50
+ const result = await (0, listCertificates_1.listCertificates)(mockStorage, auth, vargs, originator);
51
+ // Verify
52
+ expect(mockStorage.transaction).toHaveBeenCalledTimes(1);
53
+ expect(mockStorage.findCertificates).toHaveBeenCalledTimes(1);
54
+ expect(mockStorage.findCertificateFields).not.toHaveBeenCalled();
55
+ expect(mockStorage.countCertificates).not.toHaveBeenCalled(); // no need to call if 0 < limit
56
+ expect(result).toEqual({
57
+ totalCertificates: 0,
58
+ certificates: []
59
+ });
60
+ });
61
+ test('should return exactly the number of certificates if they are fewer than the limit', async () => {
62
+ // Suppose we have 2 certificates
63
+ const fakeCerts = [
64
+ {
65
+ certificateId: 1,
66
+ userId: 123,
67
+ type: 'base64Type1',
68
+ serialNumber: 'serial1',
69
+ certifier: 'abcdef01',
70
+ subject: '12345678',
71
+ verifier: undefined,
72
+ revocationOutpoint: 'abcd1234.0',
73
+ signature: 'deadbeef01',
74
+ isDeleted: false,
75
+ created_at: new Date(),
76
+ updated_at: new Date()
77
+ },
78
+ {
79
+ certificateId: 2,
80
+ userId: 123,
81
+ type: 'base64Type2',
82
+ serialNumber: 'serial2',
83
+ certifier: 'abcdef02',
84
+ subject: '23456789',
85
+ verifier: undefined,
86
+ revocationOutpoint: 'abcd5678.1',
87
+ signature: 'deadbeef02',
88
+ isDeleted: false,
89
+ created_at: new Date(),
90
+ updated_at: new Date()
91
+ }
92
+ ];
93
+ // Suppose each cert has some fields
94
+ const fakeFieldsForCert1 = [
95
+ {
96
+ certificateId: 1,
97
+ userId: 123,
98
+ fieldName: 'field1',
99
+ fieldValue: 'value1',
100
+ masterKey: 'mkey1',
101
+ created_at: new Date(),
102
+ updated_at: new Date()
103
+ }
104
+ ];
105
+ const fakeFieldsForCert2 = [
106
+ {
107
+ certificateId: 2,
108
+ userId: 123,
109
+ fieldName: 'fieldA',
110
+ fieldValue: 'valueA',
111
+ masterKey: 'mkeyA',
112
+ created_at: new Date(),
113
+ updated_at: new Date()
114
+ }
115
+ ];
116
+ mockStorage.findCertificates.mockResolvedValueOnce(fakeCerts);
117
+ // Make sure we return correct fields for each certificate
118
+ mockStorage.findCertificateFields.mockImplementation(async (args) => {
119
+ var _a, _b;
120
+ if (((_a = args.partial) === null || _a === void 0 ? void 0 : _a.certificateId) === 1)
121
+ return fakeFieldsForCert1;
122
+ if (((_b = args.partial) === null || _b === void 0 ? void 0 : _b.certificateId) === 2)
123
+ return fakeFieldsForCert2;
124
+ return [];
125
+ });
126
+ // The returned certs are length=2, which is < limit(10). So we do not call countCertificates
127
+ // Setup a spied or mocked value just in case
128
+ mockStorage.countCertificates.mockResolvedValueOnce(10);
129
+ // Execute
130
+ const result = await (0, listCertificates_1.listCertificates)(mockStorage, auth, vargs);
131
+ // Verify
132
+ expect(mockStorage.transaction).toHaveBeenCalledTimes(1);
133
+ expect(mockStorage.findCertificates).toHaveBeenCalledTimes(1);
134
+ expect(mockStorage.findCertificateFields).toHaveBeenCalledTimes(2);
135
+ expect(mockStorage.countCertificates).not.toHaveBeenCalled(); // Because 2 < 10
136
+ expect(result.certificates.length).toBe(2);
137
+ expect(result.totalCertificates).toBe(2);
138
+ // Ensure the fields are included
139
+ expect(result.certificates[0]).toEqual({
140
+ type: 'base64Type1',
141
+ subject: '12345678',
142
+ serialNumber: 'serial1',
143
+ certifier: 'abcdef01',
144
+ revocationOutpoint: 'abcd1234.0',
145
+ signature: 'deadbeef01',
146
+ verifier: undefined,
147
+ fields: { field1: 'value1' },
148
+ keyring: { field1: 'mkey1' }
149
+ });
150
+ expect(result.certificates[1]).toEqual({
151
+ type: 'base64Type2',
152
+ subject: '23456789',
153
+ serialNumber: 'serial2',
154
+ certifier: 'abcdef02',
155
+ revocationOutpoint: 'abcd5678.1',
156
+ signature: 'deadbeef02',
157
+ verifier: undefined,
158
+ fields: { fieldA: 'valueA' },
159
+ keyring: { fieldA: 'mkeyA' }
160
+ });
161
+ });
162
+ test('should call countCertificates when the returned certificates length is equal to limit', async () => {
163
+ // We want exactly 'limit' items returned, so the function calls countCertificates
164
+ vargs.limit = 2; // set limit to 2
165
+ const fakeCerts = [
166
+ {
167
+ certificateId: 11,
168
+ userId: 123,
169
+ type: 'base64Type',
170
+ serialNumber: 'sn',
171
+ certifier: 'abcdef01',
172
+ subject: 'deadbeef01',
173
+ verifier: undefined,
174
+ revocationOutpoint: '0000.0',
175
+ signature: 'abcdabcd',
176
+ isDeleted: false,
177
+ created_at: new Date(),
178
+ updated_at: new Date()
179
+ },
180
+ {
181
+ certificateId: 22,
182
+ userId: 123,
183
+ type: 'base64Type',
184
+ serialNumber: 'sn2',
185
+ certifier: 'abcdef02',
186
+ subject: 'deadbeef02',
187
+ verifier: undefined,
188
+ revocationOutpoint: '0001.0',
189
+ signature: 'ef01ef01',
190
+ isDeleted: false,
191
+ created_at: new Date(),
192
+ updated_at: new Date()
193
+ }
194
+ ];
195
+ // Suppose each cert has no fields
196
+ mockStorage.findCertificateFields.mockResolvedValue([]);
197
+ // We return exactly 2 certs, which is == limit
198
+ mockStorage.findCertificates.mockResolvedValueOnce(fakeCerts);
199
+ // So the code should call countCertificates
200
+ mockStorage.countCertificates.mockResolvedValueOnce(25);
201
+ // Execute
202
+ const result = await (0, listCertificates_1.listCertificates)(mockStorage, auth, vargs);
203
+ // Verify
204
+ expect(mockStorage.findCertificates).toHaveBeenCalledTimes(1);
205
+ expect(mockStorage.findCertificateFields).toHaveBeenCalledTimes(2);
206
+ expect(mockStorage.countCertificates).toHaveBeenCalledTimes(1);
207
+ // We expect totalCertificates = 25 from countCertificates
208
+ expect(result.totalCertificates).toBe(25);
209
+ expect(result.certificates.length).toBe(2);
210
+ });
211
+ test('should handle transaction failure by throwing an error', async () => {
212
+ // If the transaction or the underlying findCertificates call fails, we rethrow
213
+ const error = new Error('Database error');
214
+ mockStorage.transaction.mockRejectedValueOnce(error);
215
+ await expect((0, listCertificates_1.listCertificates)(mockStorage, auth, vargs)).rejects.toThrow('Database error');
216
+ // Verify mocks
217
+ expect(mockStorage.transaction).toHaveBeenCalledTimes(1);
218
+ expect(mockStorage.findCertificates).not.toHaveBeenCalled();
219
+ expect(mockStorage.findCertificateFields).not.toHaveBeenCalled();
220
+ expect(mockStorage.countCertificates).not.toHaveBeenCalled();
221
+ });
222
+ test('should handle scenario userId is undefined', async () => {
223
+ // Although typically userId is required, let's see what happens
224
+ // If userId is undefined, partial: { userId: undefined, isDeleted: false } is used
225
+ // The storage call might or might not blow up. We'll test that the code still calls the transaction
226
+ // We rely on the underlying findCertificates to throw or return an empty array.
227
+ auth.userId = undefined;
228
+ mockStorage.findCertificates.mockResolvedValueOnce([]);
229
+ const result = await (0, listCertificates_1.listCertificates)(mockStorage, auth, vargs);
230
+ expect(result).toEqual({
231
+ totalCertificates: 0,
232
+ certificates: []
233
+ });
234
+ // We see a normal call
235
+ expect(mockStorage.transaction).toHaveBeenCalledTimes(1);
236
+ expect(mockStorage.findCertificates).toHaveBeenCalledTimes(1);
237
+ // The partial would have userId: undefined
238
+ const arg0 = mockStorage.findCertificates.mock.calls[0][0];
239
+ expect(arg0.partial).toEqual({
240
+ userId: undefined,
241
+ isDeleted: false
242
+ });
243
+ });
244
+ test('if returned certificate count is bigger than limit, still only returns limit items but sets total using countCertificates', async () => {
245
+ // For completeness, if the storage findCertificates method returns exactly "limit" items,
246
+ // we do a count. But let's pretend it can return exactly limit or a bit more (some storages might do that incorrectly).
247
+ // We'll only test the scenario that triggers the "else" path. Already tested an =limit scenario above,
248
+ // but let's confirm the coverage if the function doesn't rely on partial storage returning partial results.
249
+ vargs.limit = 2;
250
+ const cA = {
251
+ certificateId: 100,
252
+ userId: 123,
253
+ type: 'zzz',
254
+ serialNumber: 'snA',
255
+ certifier: 'cA',
256
+ subject: 'sA',
257
+ verifier: undefined,
258
+ revocationOutpoint: 'nope.0',
259
+ signature: 'sigA',
260
+ isDeleted: false,
261
+ created_at: new Date(),
262
+ updated_at: new Date()
263
+ };
264
+ const cB = {
265
+ certificateId: 101,
266
+ userId: 123,
267
+ type: 'yyy',
268
+ serialNumber: 'snB',
269
+ certifier: 'cB',
270
+ subject: 'sB',
271
+ verifier: undefined,
272
+ revocationOutpoint: 'nope.1',
273
+ signature: 'sigB',
274
+ isDeleted: false,
275
+ created_at: new Date(),
276
+ updated_at: new Date()
277
+ };
278
+ const cC = {
279
+ certificateId: 102,
280
+ userId: 123,
281
+ type: 'xxx',
282
+ serialNumber: 'snC',
283
+ certifier: 'cC',
284
+ subject: 'sC',
285
+ verifier: undefined,
286
+ revocationOutpoint: 'nope.2',
287
+ signature: 'sigC',
288
+ isDeleted: false,
289
+ created_at: new Date(),
290
+ updated_at: new Date()
291
+ };
292
+ // Suppose the storage returned 3 items even though we only want 2.
293
+ // The code uses them all in memory, but sees length=3 which is > limit=2
294
+ // The line checks if (r.certificates.length < paged.limit). That is false, so it calls countCertificates.
295
+ mockStorage.findCertificates.mockResolvedValueOnce([cA, cB, cC]);
296
+ // Fields are none
297
+ mockStorage.findCertificateFields.mockResolvedValue([]);
298
+ // We want to see it call countCertificates
299
+ mockStorage.countCertificates.mockResolvedValueOnce(999);
300
+ const result = await (0, listCertificates_1.listCertificates)(mockStorage, auth, vargs);
301
+ expect(result.certificates.length).toBe(3);
302
+ expect(result.totalCertificates).toBe(999); // from countCertificates
303
+ });
304
+ });
305
+ //# sourceMappingURL=listCertificates.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listCertificates.test.js","sourceRoot":"","sources":["../../../../test/Wallet/certificate/listCertificates.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=getHeaderForHeight.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getHeaderForHeight.test.d.ts","sourceRoot":"","sources":["../../../../test/Wallet/get/getHeaderForHeight.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const TestUtilsWalletStorage_1 = require("../../utils/TestUtilsWalletStorage");
4
+ describe('getHeaderForHeight tests', () => {
5
+ jest.setTimeout(99999999);
6
+ const env = TestUtilsWalletStorage_1._tu.getEnv('test');
7
+ const ctxs = [];
8
+ beforeAll(async () => {
9
+ if (env.runMySQL)
10
+ ctxs.push(await TestUtilsWalletStorage_1._tu.createLegacyWalletMySQLCopy('getHeaderForHeightTests'));
11
+ ctxs.push(await TestUtilsWalletStorage_1._tu.createLegacyWalletSQLiteCopy('getHeaderForHeightTests'));
12
+ });
13
+ afterAll(async () => {
14
+ for (const ctx of ctxs) {
15
+ await ctx.storage.destroy();
16
+ }
17
+ });
18
+ test('0 invalid params', async () => {
19
+ for (const { wallet } of ctxs) {
20
+ try {
21
+ await wallet.getHeaderForHeight({ height: -1 });
22
+ throw new Error('Expected error was not thrown');
23
+ }
24
+ catch (e) {
25
+ const errorMessage = typeof e === 'object' && e !== null && 'message' in e
26
+ ? e.message
27
+ : String(e);
28
+ expect(errorMessage).toMatch(/Height -1 must be a non-negative integer/i);
29
+ }
30
+ }
31
+ });
32
+ test('1 valid block height', async () => {
33
+ for (const { wallet } of ctxs) {
34
+ // Query an existing valid block height
35
+ const height = 1; // Ensure this height exists in the test database
36
+ const result = await wallet.getHeaderForHeight({ height });
37
+ expect(result).toHaveProperty('header');
38
+ expect(typeof result.header).toBe('string');
39
+ expect(result.header).not.toBe('');
40
+ }
41
+ });
42
+ test('2 unexpected service errors', async () => {
43
+ for (const { wallet } of ctxs) {
44
+ try {
45
+ // Query a height that doesn't exist or triggers an unexpected error
46
+ const invalidHeight = 999999;
47
+ await wallet.getHeaderForHeight({ height: invalidHeight });
48
+ throw new Error('Expected error was not thrown');
49
+ }
50
+ catch (e) {
51
+ const errorMessage = typeof e === 'object' && e !== null && 'message' in e
52
+ ? e.message
53
+ : String(e);
54
+ expect(errorMessage).toMatch(/error|not found/i);
55
+ }
56
+ }
57
+ });
58
+ test('3 valid block height always returns a header', async () => {
59
+ for (const { wallet } of ctxs) {
60
+ const height = 9999;
61
+ const result = await wallet.getHeaderForHeight({ height });
62
+ expect(result).toHaveProperty('header');
63
+ expect(typeof result.header).toBe('string');
64
+ expect(result.header).not.toBe('');
65
+ }
66
+ });
67
+ });
68
+ //# sourceMappingURL=getHeaderForHeight.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getHeaderForHeight.test.js","sourceRoot":"","sources":["../../../../test/Wallet/get/getHeaderForHeight.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=getHeight.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getHeight.test.d.ts","sourceRoot":"","sources":["../../../../test/Wallet/get/getHeight.test.ts"],"names":[],"mappings":""}