@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,771 @@
1
+ import { Utils } from '@bsv/sdk'
2
+ import {
3
+ asArray,
4
+ asString,
5
+ convertProofToMerklePath,
6
+ randomBytesBase64,
7
+ sdk,
8
+ verifyHexString,
9
+ verifyId,
10
+ verifyInteger,
11
+ verifyOne,
12
+ verifyOptionalHexString,
13
+ verifyTruthy
14
+ } from '../../index.all'
15
+ import { table } from '../index.all'
16
+
17
+ import { Knex } from 'knex'
18
+ import { isHexString } from '../../sdk'
19
+ import { StorageReader, StorageReaderOptions } from '../StorageReader'
20
+
21
+ export interface StorageMySQLDojoReaderOptions extends StorageReaderOptions {
22
+ chain: sdk.Chain
23
+ /**
24
+ * Knex database interface initialized with valid connection configuration.
25
+ */
26
+ knex: Knex
27
+ }
28
+
29
+ export class StorageMySQLDojoReader extends StorageReader {
30
+ knex: Knex
31
+
32
+ constructor(options: StorageMySQLDojoReaderOptions) {
33
+ super(options)
34
+ if (!options.knex)
35
+ throw new sdk.WERR_INVALID_PARAMETER('options.knex', `valid`)
36
+ this.knex = options.knex
37
+ }
38
+
39
+ override async destroy(): Promise<void> {
40
+ await this.knex?.destroy()
41
+ }
42
+
43
+ override async transaction<T>(
44
+ scope: (trx: sdk.TrxToken) => Promise<T>,
45
+ trx?: sdk.TrxToken
46
+ ): Promise<T> {
47
+ if (trx) return await scope(trx)
48
+
49
+ return await this.knex.transaction<T>(async knextrx => {
50
+ const trx = knextrx as sdk.TrxToken
51
+ return await scope(trx)
52
+ })
53
+ }
54
+
55
+ toDb(trx?: sdk.TrxToken) {
56
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
57
+ const db = !trx ? this.knex : <Knex.Transaction<any, any[]>>trx
58
+ this.whenLastAccess = new Date()
59
+ return db
60
+ }
61
+
62
+ override async readSettings(trx?: sdk.TrxToken): Promise<table.Settings> {
63
+ const d = verifyOne(await this.toDb(trx)('settings'))
64
+ const r: table.Settings = {
65
+ created_at: verifyTruthy(d.created_at),
66
+ updated_at: verifyTruthy(d.updated_at),
67
+ storageIdentityKey: verifyHexString(d.dojoIdentityKey),
68
+ storageName: d.dojoName || `${this.chain} Legacy Import`,
69
+ chain: this.chain,
70
+ dbtype: 'MySQL',
71
+ maxOutputScript: 256
72
+ }
73
+ if (r.storageName.startsWith('staging') && this.chain !== 'test')
74
+ throw new sdk.WERR_INVALID_PARAMETER(
75
+ 'chain',
76
+ `in aggreement with storage chain ${r.storageName}`
77
+ )
78
+ this._settings = r
79
+ return r
80
+ }
81
+
82
+ setupQuery<T extends object>(
83
+ table: string,
84
+ args: sdk.FindPartialSincePagedArgs<T>
85
+ ): Knex.QueryBuilder {
86
+ let q = this.toDb(args.trx)<T>(table)
87
+ if (args.partial && Object.keys(args.partial).length > 0)
88
+ q.where(args.partial)
89
+ if (args.since)
90
+ q.where('updated_at', '>=', this.validateDateForWhere(args.since))
91
+ if (args.paged) {
92
+ q.limit(args.paged.limit)
93
+ q.offset(args.paged.offset || 0)
94
+ }
95
+ return q
96
+ }
97
+
98
+ findOutputBasketsQuery(args: sdk.FindOutputBasketsArgs): Knex.QueryBuilder {
99
+ return this.setupQuery('output_baskets', args)
100
+ }
101
+ async findOutputBaskets(
102
+ args: sdk.FindOutputBasketsArgs
103
+ ): Promise<table.OutputBasket[]> {
104
+ const q = this.findOutputBasketsQuery(args)
105
+ const ds = await q
106
+ const rs: table.OutputBasket[] = []
107
+ for (const d of ds) {
108
+ const r: table.OutputBasket = {
109
+ created_at: verifyTruthy(d.created_at),
110
+ updated_at: verifyTruthy(d.updated_at),
111
+ basketId: verifyInteger(d.basketId),
112
+ userId: verifyInteger(d.userId),
113
+ name: verifyTruthy(d.name).trim().toLowerCase(),
114
+ numberOfDesiredUTXOs: verifyInteger(d.numberOfDesiredUTXOs),
115
+ minimumDesiredUTXOValue: verifyInteger(d.minimumDesiredUTXOValue),
116
+ isDeleted: !!d.isDeleted
117
+ }
118
+ rs.push(r)
119
+ }
120
+ return this.validateEntities(rs, undefined, ['isDeleted'])
121
+ }
122
+ findTxLabelsQuery(args: sdk.FindTxLabelsArgs): Knex.QueryBuilder {
123
+ return this.setupQuery('tx_labels', args)
124
+ }
125
+ async findTxLabels(args: sdk.FindTxLabelsArgs): Promise<table.TxLabel[]> {
126
+ const q = this.findTxLabelsQuery(args)
127
+ const ds = await q
128
+ const rs: table.TxLabel[] = []
129
+ for (const d of ds) {
130
+ const r: table.TxLabel = {
131
+ created_at: verifyTruthy(d.created_at),
132
+ updated_at: verifyTruthy(d.updated_at),
133
+ txLabelId: verifyInteger(d.txLabelId),
134
+ userId: verifyInteger(d.userId),
135
+ label: verifyTruthy(d.label).trim().toLowerCase(),
136
+ isDeleted: !!d.isDeleted
137
+ }
138
+ rs.push(r)
139
+ }
140
+ return this.validateEntities(rs, undefined, ['isDeleted'])
141
+ }
142
+ findOutputTagsQuery(args: sdk.FindOutputTagsArgs): Knex.QueryBuilder {
143
+ return this.setupQuery('output_tags', args)
144
+ }
145
+ async findOutputTags(
146
+ args: sdk.FindOutputTagsArgs
147
+ ): Promise<table.OutputTag[]> {
148
+ const q = this.findOutputTagsQuery(args)
149
+ const ds = await q
150
+ const rs: table.OutputTag[] = []
151
+ for (const d of ds) {
152
+ const r: table.OutputTag = {
153
+ created_at: verifyTruthy(d.created_at),
154
+ updated_at: verifyTruthy(d.updated_at),
155
+ outputTagId: verifyInteger(d.outputTagId),
156
+ userId: verifyInteger(d.userId),
157
+ tag: verifyTruthy(d.tag).trim().toLowerCase(),
158
+ isDeleted: !!d.isDeleted
159
+ }
160
+ rs.push(r)
161
+ }
162
+ return this.validateEntities(rs, undefined, ['isDeleted'])
163
+ }
164
+ findTransactionsQuery(
165
+ args: sdk.FindTransactionsArgs,
166
+ count?: boolean
167
+ ): Knex.QueryBuilder {
168
+ if (args.partial.rawTx)
169
+ throw new sdk.WERR_INVALID_PARAMETER(
170
+ 'args.partial.rawTx',
171
+ `undefined. Transactions may not be found by rawTx value.`
172
+ )
173
+ if (args.partial.inputBEEF)
174
+ throw new sdk.WERR_INVALID_PARAMETER(
175
+ 'args.partial.inputBEEF',
176
+ `undefined. Transactions may not be found by inputBEEF value.`
177
+ )
178
+ const q = this.setupQuery('transactions', args)
179
+ if (args.status && args.status.length > 0) q.whereIn('status', args.status)
180
+ if (args.noRawTx && !count) {
181
+ const columns = table.transactionColumnsWithoutRawTx.map(
182
+ c => `transactions.${c}`
183
+ )
184
+ q.select(columns)
185
+ }
186
+ return q
187
+ }
188
+ async findTransactions(
189
+ args: sdk.FindTransactionsArgs
190
+ ): Promise<table.Transaction[]> {
191
+ const q = this.findTransactionsQuery(args)
192
+ const ds = await q
193
+ const rs: table.Transaction[] = []
194
+ for (const d of ds) {
195
+ const r: table.Transaction = {
196
+ created_at: verifyTruthy(d.created_at),
197
+ updated_at: verifyTruthy(d.updated_at),
198
+ transactionId: verifyInteger(d.transactionId),
199
+ userId: verifyInteger(d.userId),
200
+ status: verifyTruthy(convertTxStatus(d.status)),
201
+ reference: forceToBase64(d.referenceNumber),
202
+ isOutgoing: !!d.isOutgoing,
203
+ satoshis: verifyInteger(d.amount),
204
+ description: verifyTruthy(d.note || ''),
205
+ provenTxId: verifyOptionalInteger(d.provenTxId),
206
+ version: verifyOptionalInteger(d.version),
207
+ lockTime: verifyOptionalInteger(d.lockTime),
208
+ txid: nullToUndefined(d.txid),
209
+ inputBEEF: d.beef ? Array.from(d.beef) : undefined,
210
+ rawTx: d.rawTransaction ? Array.from(d.rawTransaction) : undefined
211
+ }
212
+ rs.push(r)
213
+ }
214
+ return this.validateEntities(rs, undefined, ['isOutgoing'])
215
+ }
216
+ findCommissionsQuery(args: sdk.FindCommissionsArgs): Knex.QueryBuilder {
217
+ if (args.partial.lockingScript)
218
+ throw new sdk.WERR_INVALID_PARAMETER(
219
+ 'args.partial.lockingScript',
220
+ `undefined. Commissions may not be found by lockingScript value.`
221
+ )
222
+ return this.setupQuery('commissions', args)
223
+ }
224
+ async findCommissions(
225
+ args: sdk.FindCommissionsArgs
226
+ ): Promise<table.Commission[]> {
227
+ const q = this.findCommissionsQuery(args)
228
+ const ds = await q
229
+ const rs: table.Commission[] = []
230
+ for (const d of ds) {
231
+ const r: table.Commission = {
232
+ created_at: verifyTruthy(d.created_at),
233
+ updated_at: verifyTruthy(d.updated_at),
234
+ commissionId: verifyInteger(d.commissionId),
235
+ userId: verifyInteger(d.userId),
236
+ transactionId: verifyInteger(d.transactionId),
237
+ satoshis: verifyInteger(d.satoshis),
238
+ keyOffset: verifyTruthy(d.keyOffset).trim(),
239
+ isRedeemed: !!d.isRedeemed,
240
+ lockingScript: Array.from(verifyTruthy(d.outputScript))
241
+ }
242
+ rs.push(r)
243
+ }
244
+ return this.validateEntities(rs, undefined, ['isRedeemed'])
245
+ }
246
+ limitString(s: string, maxLen: number): string {
247
+ if (s.length > maxLen) s = s.slice(0, maxLen)
248
+ return s
249
+ }
250
+ findOutputsQuery(
251
+ args: sdk.FindOutputsArgs,
252
+ count?: boolean
253
+ ): Knex.QueryBuilder {
254
+ if (args.partial.lockingScript)
255
+ throw new sdk.WERR_INVALID_PARAMETER(
256
+ 'args.partial.lockingScript',
257
+ `undefined. Outputs may not be found by lockingScript value.`
258
+ )
259
+ const q = this.setupQuery('outputs', args)
260
+ if (args.noScript && !count) {
261
+ const columns = table.outputColumnsWithoutLockingScript.map(
262
+ c => `outputs.${c}`
263
+ )
264
+ q.select(columns)
265
+ }
266
+ return q
267
+ }
268
+ async findOutputs(args: sdk.FindOutputsArgs): Promise<table.Output[]> {
269
+ const q = this.findOutputsQuery(args)
270
+ const ds = await q
271
+ const rs: table.Output[] = []
272
+ for (const d of ds) {
273
+ const r: table.Output = {
274
+ created_at: verifyTruthy(d.created_at),
275
+ updated_at: verifyTruthy(d.updated_at),
276
+ outputId: verifyInteger(d.outputId),
277
+ userId: verifyInteger(d.userId),
278
+ transactionId: verifyInteger(d.transactionId),
279
+ basketId: verifyOptionalInteger(d.basketId),
280
+ spendable: !!d.spendable,
281
+ change: d.providedBy !== 'you' && d.purpose === 'change',
282
+ outputDescription: (d.description || '').trim(),
283
+ vout: verifyInteger(d.vout),
284
+ satoshis: verifyInteger(d.amount),
285
+ providedBy: verifyTruthy(d.providedBy || '')
286
+ .trim()
287
+ .toLowerCase()
288
+ .replace('dojo', 'storage'),
289
+ purpose: verifyTruthy(d.purpose || '')
290
+ .trim()
291
+ .toLowerCase(),
292
+ type: verifyTruthy(d.type).trim(),
293
+ txid: nullToUndefined(d.txid),
294
+ senderIdentityKey: verifyOptionalHexString(d.senderIdentityKey),
295
+ derivationPrefix: nullToUndefined(d.derivationPrefix),
296
+ derivationSuffix: nullToUndefined(d.derivationSuffix),
297
+ customInstructions: nullToUndefined(d.customInstruction),
298
+ spentBy: verifyOptionalInteger(d.spentBy),
299
+ sequenceNumber: undefined,
300
+ spendingDescription: nullToUndefined(d.spendingDescription),
301
+ scriptLength: verifyOptionalInteger(d.scriptLength),
302
+ scriptOffset: verifyOptionalInteger(d.scriptOffset),
303
+ lockingScript: d.outputScript ? Array.from(d.outputScript) : undefined
304
+ }
305
+ rs.push(r)
306
+ }
307
+ return this.validateEntities(rs, undefined, ['spendable', 'change'])
308
+ }
309
+ findCertificatesQuery(args: sdk.FindCertificatesArgs): Knex.QueryBuilder {
310
+ const q = this.setupQuery('certificates', args)
311
+ if (args.certifiers && args.certifiers.length > 0)
312
+ q.whereIn('certifier', args.certifiers)
313
+ if (args.types && args.types.length > 0) q.whereIn('type', args.types)
314
+ return q
315
+ }
316
+ async findCertificates(
317
+ args: sdk.FindCertificatesArgs
318
+ ): Promise<table.Certificate[]> {
319
+ const q = this.findCertificatesQuery(args)
320
+ const ds = await q
321
+ const rs: table.Certificate[] = []
322
+ for (const d of ds) {
323
+ const r: table.Certificate = {
324
+ created_at: verifyTruthy(d.created_at),
325
+ updated_at: verifyTruthy(d.updated_at),
326
+ certificateId: verifyInteger(d.certificateId),
327
+ userId: verifyInteger(d.userId),
328
+ type: verifyTruthy(d.type).trim(), // base64
329
+ serialNumber: verifyTruthy(d.serialNumber).trim(), // base64
330
+ certifier: verifyHexString(d.certifier),
331
+ subject: verifyHexString(d.subject),
332
+ revocationOutpoint: verifyTruthy(d.revocationOutpoint)
333
+ .trim()
334
+ .toLowerCase(),
335
+ signature: verifyHexString(d.signature),
336
+ verifier: verifyOptionalHexString(d.validationKey),
337
+ isDeleted: !!d.isDeleted
338
+ }
339
+ rs.push(r)
340
+ }
341
+ return this.validateEntities(rs, undefined, ['isDeleted'])
342
+ }
343
+ findCertificateFieldsQuery(
344
+ args: sdk.FindCertificateFieldsArgs
345
+ ): Knex.QueryBuilder {
346
+ return this.setupQuery('certificate_fields', args)
347
+ }
348
+ async findCertificateFields(
349
+ args: sdk.FindCertificateFieldsArgs
350
+ ): Promise<table.CertificateField[]> {
351
+ const q = this.findCertificateFieldsQuery(args)
352
+ const ds = await q
353
+ const rs: table.CertificateField[] = []
354
+ for (const d of ds) {
355
+ const r: table.CertificateField = {
356
+ created_at: verifyTruthy(d.created_at),
357
+ updated_at: verifyTruthy(d.updated_at),
358
+ userId: verifyInteger(d.userId),
359
+ certificateId: verifyInteger(d.certificateId),
360
+ fieldName: verifyTruthy(d.fieldName).trim().toLowerCase(),
361
+ fieldValue: verifyTruthy(d.fieldValue).trim(), // base64
362
+ masterKey: verifyTruthy(d.masterKey).trim() // base64
363
+ }
364
+ rs.push(r)
365
+ }
366
+ return this.validateEntities(rs)
367
+ }
368
+ override async findSyncStates(
369
+ args: sdk.FindSyncStatesArgs
370
+ ): Promise<table.SyncState[]> {
371
+ const q = this.setupQuery('sync_state', args)
372
+ const ds = await q
373
+ const rs: table.SyncState[] = []
374
+ for (const d of ds) {
375
+ const r: table.SyncState = {
376
+ created_at: verifyTruthy(d.created_at),
377
+ updated_at: verifyTruthy(d.updated_at),
378
+ syncStateId: verifyInteger(d.syncStateId),
379
+ userId: verifyInteger(d.userId),
380
+ storageIdentityKey: verifyHexString(d.storageIdentityKey),
381
+ storageName: verifyTruthy(d.storageName || 'legacy importer')
382
+ .trim()
383
+ .toLowerCase(),
384
+ status: convertSyncStatus(d.status),
385
+ init: !!d.init,
386
+ refNum: verifyTruthy(d.refNum),
387
+ syncMap: verifyTruthy(d.syncMap),
388
+ when: d.when ? this.validateDate(d.when) : undefined,
389
+ satoshis: verifyOptionalInteger(d.total),
390
+ errorLocal: nullToUndefined(d.errorLocal),
391
+ errorOther: nullToUndefined(d.errorOther)
392
+ }
393
+ rs.push(r)
394
+ }
395
+ return this.validateEntities(rs, undefined, ['init'])
396
+ }
397
+ override async findUsers(args: sdk.FindUsersArgs): Promise<table.User[]> {
398
+ const q = this.setupQuery('users', args)
399
+ const ds = await q
400
+ const rs: table.User[] = []
401
+ for (const d of ds) {
402
+ const r: table.User = {
403
+ created_at: verifyTruthy(d.created_at),
404
+ updated_at: verifyTruthy(d.updated_at),
405
+ userId: verifyId(d.userId),
406
+ identityKey: verifyTruthy(d.identityKey)
407
+ }
408
+ rs.push(r)
409
+ }
410
+ return this.validateEntities(rs)
411
+ }
412
+
413
+ getProvenTxsForUserQuery(
414
+ args: sdk.FindForUserSincePagedArgs
415
+ ): Knex.QueryBuilder {
416
+ const k = this.toDb(args.trx)
417
+ let q = k('proven_txs').where(function () {
418
+ this.whereExists(
419
+ k
420
+ .select('*')
421
+ .from('transactions')
422
+ .whereRaw(
423
+ `proven_txs.provenTxId = transactions.provenTxId and transactions.userId = ${args.userId}`
424
+ )
425
+ )
426
+ })
427
+ if (args.paged) {
428
+ q = q.limit(args.paged.limit)
429
+ q = q.offset(args.paged.offset || 0)
430
+ }
431
+ if (args.since) q = q.where('updated_at', '>=', args.since)
432
+ return q
433
+ }
434
+ async getProvenTxsForUser(
435
+ args: sdk.FindForUserSincePagedArgs
436
+ ): Promise<table.ProvenTx[]> {
437
+ const q = this.getProvenTxsForUserQuery(args)
438
+ const ds = await q
439
+ const rs: table.ProvenTx[] = []
440
+ for (const d of ds) {
441
+ const mp = convertProofToMerklePath(d.txid, {
442
+ index: d.index,
443
+ nodes: deserializeTscMerkleProofNodes(d.nodes),
444
+ height: d.height
445
+ })
446
+
447
+ const r: table.ProvenTx = {
448
+ created_at: verifyTruthy(d.created_at),
449
+ updated_at: verifyTruthy(d.updated_at),
450
+ provenTxId: verifyInteger(d.provenTxId),
451
+ txid: verifyHexString(d.txid),
452
+ height: verifyInteger(d.height),
453
+ index: verifyInteger(d.index),
454
+ merklePath: mp.toBinary(),
455
+ rawTx: Array.from(verifyTruthy(d.rawTx)),
456
+ blockHash: verifyHexString(asString(verifyTruthy(d.blockHash))),
457
+ merkleRoot: verifyHexString(asString(verifyTruthy(d.merkleRoot)))
458
+ }
459
+
460
+ rs.push(r)
461
+ }
462
+ return this.validateEntities(rs)
463
+ }
464
+
465
+ getProvenTxReqsForUserQuery(
466
+ args: sdk.FindForUserSincePagedArgs
467
+ ): Knex.QueryBuilder {
468
+ const k = this.toDb(args.trx)
469
+ let q = k('proven_tx_reqs').where(function () {
470
+ this.whereExists(
471
+ k
472
+ .select('*')
473
+ .from('transactions')
474
+ .whereRaw(
475
+ `proven_tx_reqs.txid = transactions.txid and transactions.userId = ${args.userId}`
476
+ )
477
+ )
478
+ })
479
+ if (args.paged) {
480
+ q = q.limit(args.paged.limit)
481
+ q = q.offset(args.paged.offset || 0)
482
+ }
483
+ if (args.since) q = q.where('updated_at', '>=', args.since)
484
+ return q
485
+ }
486
+
487
+ async getProvenTxReqsForUser(
488
+ args: sdk.FindForUserSincePagedArgs
489
+ ): Promise<table.ProvenTxReq[]> {
490
+ const q = this.getProvenTxReqsForUserQuery(args)
491
+ const ds = await q
492
+ const rs: table.ProvenTxReq[] = []
493
+ for (const d of ds) {
494
+ const r: table.ProvenTxReq = {
495
+ created_at: verifyTruthy(d.created_at),
496
+ updated_at: verifyTruthy(d.updated_at),
497
+ provenTxReqId: verifyInteger(d.provenTxReqId),
498
+ provenTxId: verifyOptionalInteger(d.provenTxId),
499
+ txid: verifyTruthy(d.txid),
500
+ rawTx: Array.from(verifyTruthy(d.rawTx)),
501
+ status: verifyTruthy(convertReqStatus(d.status)),
502
+ attempts: verifyInteger(d.attempts),
503
+ notified: !!d.notified,
504
+ history: verifyTruthy(d.history),
505
+ notify: verifyTruthy(d.notify),
506
+ inputBEEF: d.beef ? Array.from(d.beef) : undefined
507
+ }
508
+
509
+ rs.push(r)
510
+ }
511
+ return this.validateEntities(rs, undefined, ['notified'])
512
+ }
513
+
514
+ getTxLabelMapsForUserQuery(
515
+ args: sdk.FindForUserSincePagedArgs
516
+ ): Knex.QueryBuilder {
517
+ const k = this.toDb(args.trx)
518
+ let q = k('tx_labels_map').whereExists(
519
+ k
520
+ .select('*')
521
+ .from('tx_labels')
522
+ .whereRaw(
523
+ `tx_labels.txLabelId = tx_labels_map.txLabelId and tx_labels.userId = ${args.userId}`
524
+ )
525
+ )
526
+ if (args.since)
527
+ q = q.where('updated_at', '>=', this.validateDateForWhere(args.since))
528
+ if (args.paged) {
529
+ q = q.limit(args.paged.limit)
530
+ q = q.offset(args.paged.offset || 0)
531
+ }
532
+ return q
533
+ }
534
+
535
+ async getTxLabelMapsForUser(
536
+ args: sdk.FindForUserSincePagedArgs
537
+ ): Promise<table.TxLabelMap[]> {
538
+ const q = this.getTxLabelMapsForUserQuery(args)
539
+ const ds = await q
540
+ const rs: table.TxLabelMap[] = []
541
+ for (const d of ds) {
542
+ const r: table.TxLabelMap = {
543
+ created_at: verifyTruthy(d.created_at),
544
+ updated_at: verifyTruthy(d.updated_at),
545
+ txLabelId: verifyInteger(d.txLabelId),
546
+ transactionId: verifyInteger(d.transactionId),
547
+ isDeleted: !!d.isDeleted
548
+ }
549
+ rs.push(r)
550
+ }
551
+ return this.validateEntities(rs, undefined, ['isDeleted'])
552
+ }
553
+
554
+ getOutputTagMapsForUserQuery(
555
+ args: sdk.FindForUserSincePagedArgs
556
+ ): Knex.QueryBuilder {
557
+ const k = this.toDb(args.trx)
558
+ let q = k('output_tags_map').whereExists(
559
+ k
560
+ .select('*')
561
+ .from('output_tags')
562
+ .whereRaw(
563
+ `output_tags.outputTagId = output_tags_map.outputTagId and output_tags.userId = ${args.userId}`
564
+ )
565
+ )
566
+ if (args.since)
567
+ q = q.where('updated_at', '>=', this.validateDateForWhere(args.since))
568
+ if (args.paged) {
569
+ q = q.limit(args.paged.limit)
570
+ q = q.offset(args.paged.offset || 0)
571
+ }
572
+ return q
573
+ }
574
+
575
+ async getOutputTagMapsForUser(
576
+ args: sdk.FindForUserSincePagedArgs
577
+ ): Promise<table.OutputTagMap[]> {
578
+ const q = this.getOutputTagMapsForUserQuery(args)
579
+ const ds = await q
580
+ const rs: table.OutputTagMap[] = []
581
+ for (const d of ds) {
582
+ const r: table.OutputTagMap = {
583
+ created_at: verifyTruthy(d.created_at),
584
+ updated_at: verifyTruthy(d.updated_at),
585
+ outputId: verifyInteger(d.outputId),
586
+ outputTagId: verifyInteger(d.outputTagId),
587
+ isDeleted: !!d.isDeleted
588
+ }
589
+ rs.push(r)
590
+ }
591
+ return this.validateEntities(rs, undefined, ['isDeleted'])
592
+ }
593
+
594
+ override countCertificateFields(
595
+ args: sdk.FindCertificateFieldsArgs
596
+ ): Promise<number> {
597
+ throw new Error('Method not implemented.')
598
+ }
599
+ override countCertificates(args: sdk.FindCertificatesArgs): Promise<number> {
600
+ throw new Error('Method not implemented.')
601
+ }
602
+ override countCommissions(args: sdk.FindCommissionsArgs): Promise<number> {
603
+ throw new Error('Method not implemented.')
604
+ }
605
+ override countOutputBaskets(
606
+ args: sdk.FindOutputBasketsArgs
607
+ ): Promise<number> {
608
+ throw new Error('Method not implemented.')
609
+ }
610
+ override countOutputs(args: sdk.FindOutputsArgs): Promise<number> {
611
+ throw new Error('Method not implemented.')
612
+ }
613
+ override countOutputTags(args: sdk.FindOutputTagsArgs): Promise<number> {
614
+ throw new Error('Method not implemented.')
615
+ }
616
+ override countSyncStates(args: sdk.FindSyncStatesArgs): Promise<number> {
617
+ throw new Error('Method not implemented.')
618
+ }
619
+ override countTransactions(args: sdk.FindTransactionsArgs): Promise<number> {
620
+ throw new Error('Method not implemented.')
621
+ }
622
+ override countTxLabels(args: sdk.FindTxLabelsArgs): Promise<number> {
623
+ throw new Error('Method not implemented.')
624
+ }
625
+ override countUsers(args: sdk.FindUsersArgs): Promise<number> {
626
+ throw new Error('Method not implemented.')
627
+ }
628
+ override findMonitorEvents(
629
+ args: sdk.FindMonitorEventsArgs
630
+ ): Promise<table.MonitorEvent[]> {
631
+ throw new Error('Method not implemented.')
632
+ }
633
+ override countMonitorEvents(
634
+ args: sdk.FindMonitorEventsArgs
635
+ ): Promise<number> {
636
+ throw new Error('Method not implemented.')
637
+ }
638
+
639
+ /**
640
+ * Helper to force uniform behavior across database engines.
641
+ * Use to process all individual records with time stamps retreived from database.
642
+ */
643
+ validateEntity<T extends sdk.EntityTimeStamp>(
644
+ entity: T,
645
+ dateFields?: string[],
646
+ booleanFields?: string[]
647
+ ): T {
648
+ entity.created_at = this.validateDate(entity.created_at)
649
+ entity.updated_at = this.validateDate(entity.updated_at)
650
+ if (dateFields) {
651
+ for (const df of dateFields) {
652
+ if (entity[df]) entity[df] = this.validateDate(entity[df])
653
+ }
654
+ }
655
+ if (booleanFields) {
656
+ for (const df of booleanFields) {
657
+ if (entity[df] !== undefined) entity[df] = !!entity[df]
658
+ }
659
+ }
660
+ for (const key of Object.keys(entity)) {
661
+ const val = entity[key]
662
+ if (val === null) {
663
+ entity[key] = undefined
664
+ } else if (Buffer.isBuffer(val)) {
665
+ entity[key] = Array.from(val)
666
+ }
667
+ }
668
+ return entity
669
+ }
670
+
671
+ /**
672
+ * Helper to force uniform behavior across database engines.
673
+ * Use to process all arrays of records with time stamps retreived from database.
674
+ * @returns input `entities` array with contained values validated.
675
+ */
676
+ validateEntities<T extends sdk.EntityTimeStamp>(
677
+ entities: T[],
678
+ dateFields?: string[],
679
+ booleanFields?: string[]
680
+ ): T[] {
681
+ for (let i = 0; i < entities.length; i++) {
682
+ entities[i] = this.validateEntity(entities[i], dateFields, booleanFields)
683
+ }
684
+ return entities
685
+ }
686
+ }
687
+
688
+ function deserializeTscMerkleProofNodes(nodes: Buffer): string[] {
689
+ if (!Buffer.isBuffer(nodes))
690
+ throw new sdk.WERR_INTERNAL('Buffer or string expected.')
691
+ const buffer = nodes
692
+ const ns: string[] = []
693
+ for (let offset = 0; offset < buffer.length; ) {
694
+ const flag = buffer[offset++]
695
+ if (flag === 1) ns.push('*')
696
+ else if (flag === 0) {
697
+ ns.push(asString(buffer.subarray(offset, offset + 32)))
698
+ offset += 32
699
+ } else {
700
+ throw new sdk.WERR_BAD_REQUEST(
701
+ `node type byte ${flag} is not supported here.`
702
+ )
703
+ }
704
+ }
705
+ return ns
706
+ }
707
+
708
+ type DojoProvenTxReqStatusApi =
709
+ | 'sending'
710
+ | 'unsent'
711
+ | 'nosend'
712
+ | 'unknown'
713
+ | 'nonfinal'
714
+ | 'unprocessed'
715
+ | 'unmined'
716
+ | 'callback'
717
+ | 'unconfirmed'
718
+ | 'completed'
719
+ | 'invalid'
720
+ | 'doubleSpend'
721
+
722
+ function convertReqStatus(
723
+ status: DojoProvenTxReqStatusApi
724
+ ): sdk.ProvenTxReqStatus {
725
+ return status
726
+ }
727
+
728
+ type DojoTransactionStatusApi =
729
+ | 'completed'
730
+ | 'failed'
731
+ | 'unprocessed'
732
+ | 'sending'
733
+ | 'unproven'
734
+ | 'unsigned'
735
+ | 'nosend'
736
+
737
+ //type TransactionStatus =
738
+ // 'completed' | 'failed' | 'unprocessed' | 'sending' | 'unproven' | 'unsigned' | 'nosend'
739
+
740
+ function convertTxStatus(
741
+ status: DojoTransactionStatusApi
742
+ ): sdk.TransactionStatus {
743
+ return status
744
+ }
745
+
746
+ function nullToUndefined<T>(v: T): T | undefined {
747
+ if (v === null) return undefined
748
+ if (typeof v === 'string') return v.trim() as T
749
+ return v
750
+ }
751
+
752
+ function verifyOptionalInteger(
753
+ v: number | null | undefined
754
+ ): number | undefined {
755
+ if (v === undefined || v === null) return undefined
756
+ if (typeof v !== 'number' || !Number.isInteger(v))
757
+ throw new sdk.WERR_INTERNAL('An integer is required.')
758
+ return v
759
+ }
760
+
761
+ type DojoSyncStatus = 'success' | 'error' | 'identified' | 'updated' | 'unknown'
762
+
763
+ function convertSyncStatus(status: DojoSyncStatus): sdk.SyncStatus {
764
+ return status
765
+ }
766
+
767
+ function forceToBase64(s?: string | null): string {
768
+ if (!s) return randomBytesBase64(12)
769
+ if (isHexString(s)) return Utils.toBase64(asArray(s.trim()))
770
+ return s.trim()
771
+ }