@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,775 @@
1
+ import { PrivilegedKeyManager } from '../PrivilegedKeyManager'
2
+ import { Utils, PrivateKey, Hash, Random } from '@bsv/sdk'
3
+
4
+ const sampleData = [3, 1, 4, 1, 5, 9]
5
+
6
+ // A helper function to get a 32-byte hex
7
+ function getRandom32ByteHex(): string {
8
+ const rawBytes = Random(32)
9
+ return Utils.toHex(rawBytes)
10
+ }
11
+
12
+ describe('PrivilegedKeyManager', () => {
13
+ it('Validates the BRC-3 compliance vector', async () => {
14
+ const wallet = new PrivilegedKeyManager(async () => new PrivateKey(1))
15
+ const { valid } = await wallet.verifySignature({
16
+ data: Utils.toArray('BRC-3 Compliance Validated!', 'utf8'),
17
+ signature: [
18
+ 48, 68, 2, 32, 43, 34, 58, 156, 219, 32, 50, 70, 29, 240, 155, 137, 88,
19
+ 60, 200, 95, 243, 198, 201, 21, 56, 82, 141, 112, 69, 196, 170, 73, 156,
20
+ 6, 44, 48, 2, 32, 118, 125, 254, 201, 44, 87, 177, 170, 93, 11, 193,
21
+ 134, 18, 70, 9, 31, 234, 27, 170, 177, 54, 96, 181, 140, 166, 196, 144,
22
+ 14, 230, 118, 106, 105
23
+ ],
24
+ protocolID: [2, 'BRC3 Test'],
25
+ keyID: '42',
26
+ counterparty:
27
+ '0294c479f762f6baa97fbcd4393564c1d7bd8336ebd15928135bbcf575cd1a71a1'
28
+ })
29
+ expect(valid).toBe(true)
30
+ await wallet.destroyKey()
31
+ })
32
+ it('Validates the BRC-2 HMAC compliance vector', async () => {
33
+ const wallet = new PrivilegedKeyManager(
34
+ async () =>
35
+ new PrivateKey(
36
+ '6a2991c9de20e38b31d7ea147bf55f5039e4bbc073160f5e0d541d1f17e321b8',
37
+ 'hex'
38
+ )
39
+ )
40
+ const { valid } = await wallet.verifyHmac({
41
+ data: Utils.toArray('BRC-2 HMAC Compliance Validated!', 'utf8'),
42
+ hmac: [
43
+ 81, 240, 18, 153, 163, 45, 174, 85, 9, 246, 142, 125, 209, 133, 82, 76,
44
+ 254, 103, 46, 182, 86, 59, 219, 61, 126, 30, 176, 232, 233, 100, 234, 14
45
+ ],
46
+ protocolID: [2, 'BRC2 Test'],
47
+ keyID: '42',
48
+ counterparty:
49
+ '0294c479f762f6baa97fbcd4393564c1d7bd8336ebd15928135bbcf575cd1a71a1'
50
+ })
51
+ expect(valid).toBe(true)
52
+ await wallet.destroyKey()
53
+ })
54
+ it('Validates the BRC-2 Encryption compliance vector', async () => {
55
+ const wallet = new PrivilegedKeyManager(
56
+ async () =>
57
+ new PrivateKey(
58
+ '6a2991c9de20e38b31d7ea147bf55f5039e4bbc073160f5e0d541d1f17e321b8',
59
+ 'hex'
60
+ )
61
+ )
62
+ const { plaintext } = await wallet.decrypt({
63
+ ciphertext: [
64
+ 252, 203, 216, 184, 29, 161, 223, 212, 16, 193, 94, 99, 31, 140, 99, 43,
65
+ 61, 236, 184, 67, 54, 105, 199, 47, 11, 19, 184, 127, 2, 165, 125, 9,
66
+ 188, 195, 196, 39, 120, 130, 213, 95, 186, 89, 64, 28, 1, 80, 20, 213,
67
+ 159, 133, 98, 253, 128, 105, 113, 247, 197, 152, 236, 64, 166, 207, 113,
68
+ 134, 65, 38, 58, 24, 127, 145, 140, 206, 47, 70, 146, 84, 186, 72, 95,
69
+ 35, 154, 112, 178, 55, 72, 124
70
+ ],
71
+ protocolID: [2, 'BRC2 Test'],
72
+ keyID: '42',
73
+ counterparty:
74
+ '0294c479f762f6baa97fbcd4393564c1d7bd8336ebd15928135bbcf575cd1a71a1'
75
+ })
76
+ expect(Utils.toUTF8(plaintext)).toEqual(
77
+ 'BRC-2 Encryption Compliance Validated!'
78
+ )
79
+ await wallet.destroyKey()
80
+ })
81
+ it('Encrypts messages decryptable by the counterparty', async () => {
82
+ const userKey = PrivateKey.fromRandom()
83
+ const counterpartyKey = PrivateKey.fromRandom()
84
+ const user = new PrivilegedKeyManager(async () => userKey)
85
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
86
+ const { ciphertext } = await user.encrypt({
87
+ plaintext: sampleData,
88
+ protocolID: [2, 'tests'],
89
+ keyID: '4',
90
+ counterparty: counterpartyKey.toPublicKey().toString()
91
+ })
92
+ const { plaintext } = await counterparty.decrypt({
93
+ ciphertext,
94
+ protocolID: [2, 'tests'],
95
+ keyID: '4',
96
+ counterparty: userKey.toPublicKey().toString()
97
+ })
98
+ expect(plaintext).toEqual(sampleData)
99
+ expect(ciphertext).not.toEqual(plaintext)
100
+ await user.destroyKey()
101
+ await counterparty.destroyKey()
102
+ })
103
+ it('Fails to decryupt messages for the wrong protocol, key, and counterparty', async () => {
104
+ const userKey = PrivateKey.fromRandom()
105
+ const counterpartyKey = PrivateKey.fromRandom()
106
+ const user = new PrivilegedKeyManager(async () => userKey)
107
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
108
+ const { ciphertext } = await user.encrypt({
109
+ plaintext: sampleData,
110
+ protocolID: [2, 'tests'],
111
+ keyID: '4',
112
+ counterparty: counterpartyKey.toPublicKey().toString()
113
+ })
114
+ await expect(
115
+ async () =>
116
+ await counterparty.decrypt({
117
+ ciphertext,
118
+ protocolID: [1, 'tests'],
119
+ keyID: '4',
120
+ counterparty: userKey.toPublicKey().toString()
121
+ })
122
+ ).rejects.toThrow()
123
+ await expect(
124
+ async () =>
125
+ await counterparty.decrypt({
126
+ ciphertext,
127
+ protocolID: [2, 'tests'],
128
+ keyID: '5',
129
+ counterparty: userKey.toPublicKey().toString()
130
+ })
131
+ ).rejects.toThrow()
132
+ await expect(
133
+ async () =>
134
+ await counterparty.decrypt({
135
+ ciphertext,
136
+ protocolID: [2, 'tests'],
137
+ keyID: '4',
138
+ counterparty: counterpartyKey.toPublicKey().toString()
139
+ })
140
+ ).rejects.toThrow()
141
+ await user.destroyKey()
142
+ await counterparty.destroyKey()
143
+ })
144
+ it('Correctly derives keys for a counterparty', async () => {
145
+ const userKey = PrivateKey.fromRandom()
146
+ const counterpartyKey = PrivateKey.fromRandom()
147
+ const user = new PrivilegedKeyManager(async () => userKey)
148
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
149
+ const { publicKey: identityKey } = await user.getPublicKey({
150
+ identityKey: true
151
+ })
152
+ expect(identityKey).toEqual(userKey.toPublicKey().toString())
153
+ const { publicKey: derivedForCounterparty } = await user.getPublicKey({
154
+ protocolID: [2, 'tests'],
155
+ keyID: '4',
156
+ counterparty: counterpartyKey.toPublicKey().toString()
157
+ })
158
+ const { publicKey: derivedByCounterparty } =
159
+ await counterparty.getPublicKey({
160
+ protocolID: [2, 'tests'],
161
+ keyID: '4',
162
+ counterparty: userKey.toPublicKey().toString(),
163
+ forSelf: true
164
+ })
165
+ expect(derivedForCounterparty).toEqual(derivedByCounterparty)
166
+ await user.destroyKey()
167
+ await counterparty.destroyKey()
168
+ })
169
+ it('Signs messages verifiable by the counterparty', async () => {
170
+ const userKey = PrivateKey.fromRandom()
171
+ const counterpartyKey = PrivateKey.fromRandom()
172
+ const user = new PrivilegedKeyManager(async () => userKey)
173
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
174
+ const { signature } = await user.createSignature({
175
+ data: sampleData,
176
+ protocolID: [2, 'tests'],
177
+ keyID: '4',
178
+ counterparty: counterpartyKey.toPublicKey().toString()
179
+ })
180
+ const { valid } = await counterparty.verifySignature({
181
+ signature,
182
+ data: sampleData,
183
+ protocolID: [2, 'tests'],
184
+ keyID: '4',
185
+ counterparty: userKey.toPublicKey().toString()
186
+ })
187
+ expect(valid).toEqual(true)
188
+ expect(signature.length).not.toEqual(0)
189
+ await user.destroyKey()
190
+ await counterparty.destroyKey()
191
+ })
192
+ it('Directly signs hash of message verifiable by the counterparty', async () => {
193
+ const userKey = PrivateKey.fromRandom()
194
+ const counterpartyKey = PrivateKey.fromRandom()
195
+ const user = new PrivilegedKeyManager(async () => userKey)
196
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
197
+ const { signature } = await user.createSignature({
198
+ hashToDirectlySign: Hash.sha256(sampleData),
199
+ protocolID: [2, 'tests'],
200
+ keyID: '4',
201
+ counterparty: counterpartyKey.toPublicKey().toString()
202
+ })
203
+ const { valid } = await counterparty.verifySignature({
204
+ signature,
205
+ data: sampleData,
206
+ protocolID: [2, 'tests'],
207
+ keyID: '4',
208
+ counterparty: userKey.toPublicKey().toString()
209
+ })
210
+ expect(valid).toEqual(true)
211
+ const { valid: hashValid } = await counterparty.verifySignature({
212
+ signature,
213
+ hashToDirectlyVerify: Hash.sha256(sampleData),
214
+ protocolID: [2, 'tests'],
215
+ keyID: '4',
216
+ counterparty: userKey.toPublicKey().toString()
217
+ })
218
+ expect(hashValid).toEqual(true)
219
+ expect(signature.length).not.toEqual(0)
220
+ await user.destroyKey()
221
+ await counterparty.destroyKey()
222
+ })
223
+ it('Fails to verify signature for the wrong data, protocol, key, and counterparty', async () => {
224
+ const userKey = PrivateKey.fromRandom()
225
+ const counterpartyKey = PrivateKey.fromRandom()
226
+ const user = new PrivilegedKeyManager(async () => userKey)
227
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
228
+ const { signature } = await user.createSignature({
229
+ data: sampleData,
230
+ protocolID: [2, 'tests'],
231
+ keyID: '4',
232
+ counterparty: counterpartyKey.toPublicKey().toString()
233
+ })
234
+ await expect(
235
+ async () =>
236
+ await counterparty.verifySignature({
237
+ signature,
238
+ data: [0, ...sampleData],
239
+ protocolID: [2, 'tests'],
240
+ keyID: '4',
241
+ counterparty: userKey.toPublicKey().toString()
242
+ })
243
+ ).rejects.toThrow()
244
+ await expect(
245
+ async () =>
246
+ await counterparty.verifySignature({
247
+ signature,
248
+ data: sampleData,
249
+ protocolID: [2, 'wrong'],
250
+ keyID: '4',
251
+ counterparty: userKey.toPublicKey().toString()
252
+ })
253
+ ).rejects.toThrow()
254
+ await expect(
255
+ async () =>
256
+ await counterparty.verifySignature({
257
+ signature,
258
+ data: sampleData,
259
+ protocolID: [2, 'tests'],
260
+ keyID: '2',
261
+ counterparty: userKey.toPublicKey().toString()
262
+ })
263
+ ).rejects.toThrow()
264
+ await expect(
265
+ async () =>
266
+ await counterparty.verifySignature({
267
+ signature,
268
+ data: sampleData,
269
+ protocolID: [2, 'tests'],
270
+ keyID: '4',
271
+ counterparty: counterpartyKey.toPublicKey().toString()
272
+ })
273
+ ).rejects.toThrow()
274
+ await user.destroyKey()
275
+ await counterparty.destroyKey()
276
+ })
277
+ it('Computes HMAC over messages verifiable by the counterparty', async () => {
278
+ const userKey = PrivateKey.fromRandom()
279
+ const counterpartyKey = PrivateKey.fromRandom()
280
+ const user = new PrivilegedKeyManager(async () => userKey)
281
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
282
+ const { hmac } = await user.createHmac({
283
+ data: sampleData,
284
+ protocolID: [2, 'tests'],
285
+ keyID: '4',
286
+ counterparty: counterpartyKey.toPublicKey().toString()
287
+ })
288
+ const { valid } = await counterparty.verifyHmac({
289
+ hmac,
290
+ data: sampleData,
291
+ protocolID: [2, 'tests'],
292
+ keyID: '4',
293
+ counterparty: userKey.toPublicKey().toString()
294
+ })
295
+ expect(valid).toEqual(true)
296
+ expect(hmac.length).toEqual(32)
297
+ await user.destroyKey()
298
+ await counterparty.destroyKey()
299
+ })
300
+ it('Fails to verify HMAC for the wrong data, protocol, key, and counterparty', async () => {
301
+ const userKey = PrivateKey.fromRandom()
302
+ const counterpartyKey = PrivateKey.fromRandom()
303
+ const user = new PrivilegedKeyManager(async () => userKey)
304
+ const counterparty = new PrivilegedKeyManager(async () => counterpartyKey)
305
+ const { hmac } = await user.createHmac({
306
+ data: sampleData,
307
+ protocolID: [2, 'tests'],
308
+ keyID: '4',
309
+ counterparty: counterpartyKey.toPublicKey().toString()
310
+ })
311
+ await expect(
312
+ async () =>
313
+ await counterparty.verifyHmac({
314
+ hmac,
315
+ data: [0, ...sampleData],
316
+ protocolID: [2, 'tests'],
317
+ keyID: '4',
318
+ counterparty: userKey.toPublicKey().toString()
319
+ })
320
+ ).rejects.toThrow()
321
+ await expect(
322
+ async () =>
323
+ await counterparty.verifyHmac({
324
+ hmac,
325
+ data: sampleData,
326
+ protocolID: [2, 'wrong'],
327
+ keyID: '4',
328
+ counterparty: userKey.toPublicKey().toString()
329
+ })
330
+ ).rejects.toThrow()
331
+ await expect(
332
+ async () =>
333
+ await counterparty.verifyHmac({
334
+ hmac,
335
+ data: sampleData,
336
+ protocolID: [2, 'tests'],
337
+ keyID: '2',
338
+ counterparty: userKey.toPublicKey().toString()
339
+ })
340
+ ).rejects.toThrow()
341
+ await expect(
342
+ async () =>
343
+ await counterparty.verifyHmac({
344
+ hmac,
345
+ data: sampleData,
346
+ protocolID: [2, 'tests'],
347
+ keyID: '4',
348
+ counterparty: counterpartyKey.toPublicKey().toString()
349
+ })
350
+ ).rejects.toThrow()
351
+ await user.destroyKey()
352
+ await counterparty.destroyKey()
353
+ })
354
+ it('Uses anyone for creating signatures and self for other operations if no counterparty is provided', async () => {
355
+ const userKey = PrivateKey.fromRandom()
356
+ const user = new PrivilegedKeyManager(async () => userKey)
357
+ const { hmac } = await user.createHmac({
358
+ data: sampleData,
359
+ protocolID: [2, 'tests'],
360
+ keyID: '4'
361
+ })
362
+ const { valid: hmacValid } = await user.verifyHmac({
363
+ hmac,
364
+ data: sampleData,
365
+ protocolID: [2, 'tests'],
366
+ keyID: '4'
367
+ })
368
+ expect(hmacValid).toEqual(true)
369
+ const { valid: explicitSelfHmacValid } = await user.verifyHmac({
370
+ hmac,
371
+ data: sampleData,
372
+ protocolID: [2, 'tests'],
373
+ keyID: '4',
374
+ counterparty: 'self'
375
+ })
376
+ expect(explicitSelfHmacValid).toEqual(true)
377
+ expect(hmac.length).toEqual(32)
378
+ const { signature: anyoneSig } = await user.createSignature({
379
+ data: sampleData,
380
+ protocolID: [2, 'tests'],
381
+ keyID: '4'
382
+ // counterparty=anyone is implicit for creating signatures
383
+ })
384
+ const anyone = new PrivilegedKeyManager(async () => new PrivateKey(1))
385
+ const { valid: anyoneSigValid } = await anyone.verifySignature({
386
+ signature: anyoneSig,
387
+ data: sampleData,
388
+ protocolID: [2, 'tests'],
389
+ keyID: '4',
390
+ counterparty: userKey.toPublicKey().toString()
391
+ })
392
+ expect(anyoneSigValid).toEqual(true)
393
+ const { signature: selfSig } = await user.createSignature({
394
+ data: sampleData,
395
+ protocolID: [2, 'tests'],
396
+ keyID: '4',
397
+ counterparty: 'self'
398
+ })
399
+ const { valid: selfSigValid } = await user.verifySignature({
400
+ signature: selfSig,
401
+ data: sampleData,
402
+ protocolID: [2, 'tests'],
403
+ keyID: '4'
404
+ // Self is implicit when verifying signatures
405
+ })
406
+ expect(selfSigValid).toEqual(true)
407
+ const { valid: explicitSelfSigValid } = await user.verifySignature({
408
+ signature: selfSig,
409
+ data: sampleData,
410
+ protocolID: [2, 'tests'],
411
+ keyID: '4',
412
+ counterparty: 'self'
413
+ })
414
+ expect(explicitSelfSigValid).toEqual(true)
415
+ const { publicKey } = await user.getPublicKey({
416
+ protocolID: [2, 'tests'],
417
+ keyID: '4'
418
+ })
419
+ const { publicKey: explicitSelfPublicKey } = await user.getPublicKey({
420
+ protocolID: [2, 'tests'],
421
+ keyID: '4',
422
+ counterparty: 'self'
423
+ })
424
+ expect(publicKey).toEqual(explicitSelfPublicKey)
425
+ const { ciphertext } = await user.encrypt({
426
+ plaintext: sampleData,
427
+ protocolID: [2, 'tests'],
428
+ keyID: '4'
429
+ })
430
+ const { plaintext } = await user.decrypt({
431
+ ciphertext,
432
+ protocolID: [2, 'tests'],
433
+ keyID: '4'
434
+ })
435
+ const { plaintext: explicitSelfPlaintext } = await user.decrypt({
436
+ ciphertext,
437
+ protocolID: [2, 'tests'],
438
+ keyID: '4',
439
+ counterparty: 'self'
440
+ })
441
+ expect(plaintext).toEqual(explicitSelfPlaintext)
442
+ expect(plaintext).toEqual(sampleData)
443
+ await user.destroyKey()
444
+ await anyone.destroyKey()
445
+ })
446
+ describe('PrivilegedKeyManager Key Linkage Revelation', () => {
447
+ it('Validates the revealCounterpartyKeyLinkage function', async () => {
448
+ // Initialize keys
449
+ const proverKey = PrivateKey.fromRandom()
450
+ const counterpartyKey = PrivateKey.fromRandom()
451
+ const verifierKey = PrivateKey.fromRandom()
452
+
453
+ // Initialize wallets
454
+ const proverWallet = new PrivilegedKeyManager(async () => proverKey)
455
+ const verifierWallet = new PrivilegedKeyManager(async () => verifierKey)
456
+
457
+ // Prover reveals counterparty key linkage
458
+ const revelation = await proverWallet.revealCounterpartyKeyLinkage({
459
+ counterparty: counterpartyKey.toPublicKey().toString(),
460
+ verifier: verifierKey.toPublicKey().toString()
461
+ })
462
+
463
+ // Verifier decrypts the encrypted linkage
464
+ const { plaintext: linkage } = await verifierWallet.decrypt({
465
+ ciphertext: revelation.encryptedLinkage,
466
+ protocolID: [2, 'counterparty linkage revelation'],
467
+ keyID: revelation.revelationTime,
468
+ counterparty: proverKey.toPublicKey().toString()
469
+ })
470
+
471
+ // Compute expected linkage
472
+ const expectedLinkage = proverKey
473
+ .deriveSharedSecret(counterpartyKey.toPublicKey())
474
+ .encode(true)
475
+
476
+ // Compare linkage and expectedLinkage
477
+ expect(linkage).toEqual(expectedLinkage)
478
+ await proverWallet.destroyKey()
479
+ await verifierWallet.destroyKey()
480
+ })
481
+
482
+ it('Validates the revealSpecificKeyLinkage function', async () => {
483
+ // Initialize keys
484
+ const proverKey = PrivateKey.fromRandom()
485
+ const counterpartyKey = PrivateKey.fromRandom()
486
+ const verifierKey = PrivateKey.fromRandom()
487
+
488
+ // Initialize wallets
489
+ const proverWallet = new PrivilegedKeyManager(async () => proverKey)
490
+ const verifierWallet = new PrivilegedKeyManager(async () => verifierKey)
491
+
492
+ const protocolID: [0 | 1 | 2, string] = [0, 'tests']
493
+ const keyID = 'test key id'
494
+
495
+ // Prover reveals specific key linkage
496
+ const revelation = await proverWallet.revealSpecificKeyLinkage({
497
+ counterparty: counterpartyKey.toPublicKey().toString(),
498
+ verifier: verifierKey.toPublicKey().toString(),
499
+ protocolID,
500
+ keyID
501
+ })
502
+
503
+ // Verifier decrypts the encrypted linkage
504
+ const { plaintext: linkage } = await verifierWallet.decrypt({
505
+ ciphertext: revelation.encryptedLinkage,
506
+ protocolID: [
507
+ 2,
508
+ `specific linkage revelation ${protocolID[0]} ${protocolID[1]}`
509
+ ],
510
+ keyID,
511
+ counterparty: proverKey.toPublicKey().toString()
512
+ })
513
+
514
+ // Compute expected linkage
515
+ const sharedSecret = proverKey
516
+ .deriveSharedSecret(counterpartyKey.toPublicKey())
517
+ .encode(true)
518
+
519
+ // Function to compute the invoice number
520
+ const computeInvoiceNumber = function (protocolID, keyID) {
521
+ const securityLevel = protocolID[0]
522
+ if (
523
+ !Number.isInteger(securityLevel) ||
524
+ securityLevel < 0 ||
525
+ securityLevel > 2
526
+ ) {
527
+ throw new Error('Protocol security level must be 0, 1, or 2')
528
+ }
529
+ const protocolName = protocolID[1].toLowerCase().trim()
530
+ if (keyID.length > 800) {
531
+ throw new Error('Key IDs must be 800 characters or less')
532
+ }
533
+ if (keyID.length < 1) {
534
+ throw new Error('Key IDs must be 1 character or more')
535
+ }
536
+ if (protocolName.length > 400) {
537
+ throw new Error('Protocol names must be 400 characters or less')
538
+ }
539
+ if (protocolName.length < 5) {
540
+ throw new Error('Protocol names must be 5 characters or more')
541
+ }
542
+ if (protocolName.includes(' ')) {
543
+ throw new Error(
544
+ 'Protocol names cannot contain multiple consecutive spaces (" ")'
545
+ )
546
+ }
547
+ if (!/^[a-z0-9 ]+$/g.test(protocolName)) {
548
+ throw new Error(
549
+ 'Protocol names can only contain letters, numbers and spaces'
550
+ )
551
+ }
552
+ if (protocolName.endsWith(' protocol')) {
553
+ throw new Error('No need to end your protocol name with " protocol"')
554
+ }
555
+ return `${securityLevel}-${protocolName}-${keyID}`
556
+ }
557
+ const invoiceNumber = computeInvoiceNumber(protocolID, keyID)
558
+ const invoiceNumberBin = Utils.toArray(invoiceNumber, 'utf8')
559
+
560
+ // Compute expected linkage
561
+ const expectedLinkage = Hash.sha256hmac(sharedSecret, invoiceNumberBin)
562
+
563
+ // Compare linkage and expectedLinkage
564
+ expect(linkage).toEqual(expectedLinkage)
565
+
566
+ await proverWallet.destroyKey()
567
+ await verifierWallet.destroyKey()
568
+ })
569
+ })
570
+ describe('PrivilegedKeyManager - Internal Logic Tests', () => {
571
+ beforeEach(() => {
572
+ jest.useFakeTimers()
573
+ })
574
+ afterEach(() => {
575
+ jest.clearAllTimers()
576
+ jest.useRealTimers()
577
+ })
578
+ it('Calls keyGetter only once if getPrivilegedKey is invoked multiple times within retention period', async () => {
579
+ // Create a mock keyGetter that returns a PrivateKey
580
+ const keyGetterMock = jest.fn(async (reason: string) => {
581
+ return new PrivateKey(getRandom32ByteHex(), 'hex')
582
+ })
583
+
584
+ // Retention period is 100 ms for testing
585
+ const km = new PrivilegedKeyManager(keyGetterMock, 100)
586
+
587
+ // 1) First call, should call keyGetter once
588
+ const key1 = await (km as any).getPrivilegedKey('first reason')
589
+ expect(keyGetterMock).toHaveBeenCalledTimes(1)
590
+
591
+ // 2) Second call, if within retention, should NOT call keyGetter again
592
+ const key2 = await (km as any).getPrivilegedKey('second reason')
593
+ expect(keyGetterMock).toHaveBeenCalledTimes(1)
594
+
595
+ // 3) Check that both keys match the same underlying private key
596
+ expect(key1.toHex()).toBe(key2.toHex())
597
+ await km.destroyKey()
598
+ })
599
+
600
+ it('Destroys key after retention period elapses', async () => {
601
+ const keyGetterMock = jest.fn(async (reason: string) => {
602
+ return new PrivateKey(getRandom32ByteHex(), 'hex')
603
+ })
604
+
605
+ const retentionMs = 200
606
+ const km = new PrivilegedKeyManager(keyGetterMock, retentionMs)
607
+
608
+ // Acquire the key
609
+ await (km as any).getPrivilegedKey('test reason')
610
+
611
+ // We have chunkPropNames set
612
+ expect((km as any).chunkPropNames.length).toBeGreaterThan(0)
613
+
614
+ // Fast-forward time beyond the retention period
615
+ jest.advanceTimersByTime(retentionMs + 1)
616
+
617
+ // The destroyKey logic should have run
618
+ expect((km as any).chunkPropNames.length).toBe(0)
619
+ expect((km as any).chunkPadPropNames.length).toBe(0)
620
+ expect((km as any).decoyPropNamesDestroy.length).toBe(0)
621
+ await km.destroyKey()
622
+ })
623
+
624
+ it('Explicitly calls destroyKey() and removes all chunk properties', async () => {
625
+ const keyGetterMock = jest.fn(async (reason: string) => {
626
+ return new PrivateKey(getRandom32ByteHex(), 'hex')
627
+ })
628
+ const km = new PrivilegedKeyManager(keyGetterMock, 5000)
629
+
630
+ // Acquire the key
631
+ await (km as any).getPrivilegedKey('destroy test')
632
+
633
+ // Verify chunk props exist
634
+ expect((km as any).chunkPropNames.length).toBeGreaterThan(0)
635
+ expect((km as any).chunkPadPropNames.length).toBeGreaterThan(0)
636
+
637
+ // Explicitly call destroyKey
638
+ ;(km as any).destroyKey()
639
+
640
+ // Now chunkPropNames and chunkPadPropNames should be cleared
641
+ expect((km as any).chunkPropNames.length).toBe(0)
642
+ expect((km as any).chunkPadPropNames.length).toBe(0)
643
+ await km.destroyKey()
644
+ })
645
+
646
+ it('Reuses in-memory obfuscated key if data is valid, otherwise fetches a new key', async () => {
647
+ const mockHex = getRandom32ByteHex()
648
+ const keyGetterMock = jest.fn(async () => new PrivateKey(mockHex, 'hex'))
649
+
650
+ const km = new PrivilegedKeyManager(keyGetterMock, 5000)
651
+
652
+ // 1) First retrieval => calls keyGetter
653
+ const key1 = await (km as any).getPrivilegedKey('reuse test')
654
+ expect(keyGetterMock).toHaveBeenCalledTimes(1)
655
+ expect(key1.toHex()).toBe(mockHex)
656
+
657
+ // 2) Tamper with chunk data so reassembleKeyFromChunks returns null
658
+ // We can zero out one chunk or remove it
659
+ ;(km as any)[(km as any).chunkPropNames[0]] = undefined
660
+
661
+ // 3) Second retrieval => chunk data is invalid => calls keyGetter again
662
+ const key2 = await (km as any).getPrivilegedKey('reuse test 2')
663
+ expect(keyGetterMock).toHaveBeenCalledTimes(2)
664
+ // The newly fetched key must still match mockHex,
665
+ // because the mock always returns the same key.
666
+ expect(key2.toHex()).toBe(mockHex)
667
+ await km.destroyKey()
668
+ })
669
+
670
+ it('Ensures chunk-splitting logic is correct for a 32-byte key', async () => {
671
+ const km = new PrivilegedKeyManager(async () => new PrivateKey(1), 5000)
672
+
673
+ const testBytes = new Uint8Array(32)
674
+ // Fill with some pattern, e.g. 0..31
675
+ testBytes.forEach((_, i) => {
676
+ testBytes[i] = i
677
+ })
678
+
679
+ const chunks = (km as any).splitKeyIntoChunks(testBytes)
680
+ expect(chunks.length).toBe((km as any).CHUNK_COUNT)
681
+
682
+ // By default CHUNK_COUNT = 4
683
+ // Typically each chunk would be 8 bytes (for a 32-byte key).
684
+ chunks.forEach((chunk: Uint8Array, i: number) => {
685
+ if (i < 3) {
686
+ expect(chunk.length).toBe(8)
687
+ } else {
688
+ // last chunk picks up leftover
689
+ expect(chunk.length).toBe(8)
690
+ }
691
+ })
692
+
693
+ // Reassemble logic typically is done by reassembleKeyFromChunks,
694
+ // but let's test it in isolation. We'll XOR with random pads,
695
+ // store them, reassemble, etc.
696
+
697
+ // For demonstration, we can do a quick test:
698
+ const pad = chunks.map((c: Uint8Array) =>
699
+ Uint8Array.from(Random(c.length))
700
+ )
701
+ const obfuscated = chunks.map((c: Uint8Array, i: number) =>
702
+ (km as any).xorBytes(c, pad[i])
703
+ )
704
+
705
+ // Then "store" and reassemble
706
+ ;(km as any).chunkPropNames = []
707
+ ;(km as any).chunkPadPropNames = []
708
+ obfuscated.forEach((obf: Uint8Array, i: number) => {
709
+ const chunkProp = `chunk${i}`
710
+ const padProp = `pad${i}`
711
+ ;(km as any).chunkPropNames.push(chunkProp)
712
+ ;(km as any).chunkPadPropNames.push(padProp)
713
+ ;(km as any)[chunkProp] = obf
714
+ ;(km as any)[padProp] = pad[i]
715
+ })
716
+ const reassembled = (km as any).reassembleKeyFromChunks()
717
+ expect(reassembled.length).toBe(32)
718
+ expect(Array.from(reassembled)).toEqual(Array.from(testBytes))
719
+ await km.destroyKey()
720
+ })
721
+
722
+ it('XOR function works as expected', async () => {
723
+ const km = new PrivilegedKeyManager(async () => new PrivateKey(1), 5000)
724
+ const a = Uint8Array.from([0, 1, 255])
725
+ const b = Uint8Array.from([255, 1, 0])
726
+
727
+ const result = (km as any).xorBytes(a, b)
728
+ // 0 ^ 255 = 255, 1 ^ 1 = 0, 255 ^ 0 = 255
729
+ expect(Array.from(result)).toEqual([255, 0, 255])
730
+
731
+ // XOR with zero array => same array
732
+ const zero = new Uint8Array(3)
733
+ const result2 = (km as any).xorBytes(a, zero)
734
+ expect(Array.from(result2)).toEqual([0, 1, 255])
735
+ await km.destroyKey()
736
+ })
737
+
738
+ it('Generates random property names', async () => {
739
+ const km = new PrivilegedKeyManager(async () => new PrivateKey(1), 5000)
740
+ const prop1 = (km as any).generateRandomPropName()
741
+ const prop2 = (km as any).generateRandomPropName()
742
+ expect(prop1).not.toBe(prop2)
743
+ // Just check format (roughly)
744
+ expect(prop1).toMatch(/^_[0-9a-f]{8}_[0-9]{1,6}$/)
745
+ expect(prop2).toMatch(/^_[0-9a-f]{8}_[0-9]{1,6}$/)
746
+ await km.destroyKey()
747
+ })
748
+
749
+ it('Sets up initial decoy properties in the constructor', async () => {
750
+ const km = new PrivilegedKeyManager(async () => new PrivateKey(1), 5000)
751
+ // decoyPropNamesRemain has length 2
752
+ expect((km as any).decoyPropNamesRemain.length).toBe(2)
753
+ // Validate those properties actually exist on the object
754
+ for (const propName of (km as any).decoyPropNamesRemain) {
755
+ expect((km as any)[propName]).toBeInstanceOf(Uint8Array)
756
+ expect((km as any)[propName].length).toBe(16)
757
+ }
758
+ await km.destroyKey()
759
+ })
760
+
761
+ it('New decoy properties are created on each key fetch and destroyed on destroy', async () => {
762
+ const km = new PrivilegedKeyManager(async () => new PrivateKey(1), 5000)
763
+ await (km as any).getPrivilegedKey('decoy test')
764
+
765
+ // We should have 2 decoy props that remain, plus 2 that are "destroyable"
766
+ expect((km as any).decoyPropNamesRemain.length).toBe(2)
767
+ expect((km as any).decoyPropNamesDestroy.length).toBe(2)
768
+
769
+ // Destroy them
770
+ ;(km as any).destroyKey()
771
+ expect((km as any).decoyPropNamesDestroy.length).toBe(0)
772
+ await km.destroyKey()
773
+ })
774
+ })
775
+ })