@originals/sdk 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 (403) hide show
  1. package/.eslintrc.json +33 -0
  2. package/.turbo/turbo-build.log +1 -0
  3. package/.turbo/turbo-test.log +68353 -0
  4. package/dist/adapters/FeeOracleMock.d.ts +6 -0
  5. package/dist/adapters/FeeOracleMock.js +8 -0
  6. package/dist/adapters/index.d.ts +4 -0
  7. package/dist/adapters/index.js +4 -0
  8. package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
  9. package/dist/adapters/providers/OrdHttpProvider.js +110 -0
  10. package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
  11. package/dist/adapters/providers/OrdMockProvider.js +75 -0
  12. package/dist/adapters/types.d.ts +71 -0
  13. package/dist/adapters/types.js +1 -0
  14. package/dist/bitcoin/BitcoinManager.d.ts +15 -0
  15. package/dist/bitcoin/BitcoinManager.js +262 -0
  16. package/dist/bitcoin/BroadcastClient.d.ts +30 -0
  17. package/dist/bitcoin/BroadcastClient.js +35 -0
  18. package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
  19. package/dist/bitcoin/OrdinalsClient.js +105 -0
  20. package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
  21. package/dist/bitcoin/PSBTBuilder.js +80 -0
  22. package/dist/bitcoin/fee-calculation.d.ts +14 -0
  23. package/dist/bitcoin/fee-calculation.js +31 -0
  24. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
  25. package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
  26. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
  27. package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
  28. package/dist/bitcoin/providers/types.d.ts +63 -0
  29. package/dist/bitcoin/providers/types.js +1 -0
  30. package/dist/bitcoin/transactions/commit.d.ts +89 -0
  31. package/dist/bitcoin/transactions/commit.js +311 -0
  32. package/dist/bitcoin/transactions/index.d.ts +7 -0
  33. package/dist/bitcoin/transactions/index.js +8 -0
  34. package/dist/bitcoin/transfer.d.ts +9 -0
  35. package/dist/bitcoin/transfer.js +26 -0
  36. package/dist/bitcoin/utxo-selection.d.ts +78 -0
  37. package/dist/bitcoin/utxo-selection.js +237 -0
  38. package/dist/bitcoin/utxo.d.ts +26 -0
  39. package/dist/bitcoin/utxo.js +78 -0
  40. package/dist/contexts/credentials-v1.json +195 -0
  41. package/dist/contexts/credentials-v2-examples.json +5 -0
  42. package/dist/contexts/credentials-v2.json +301 -0
  43. package/dist/contexts/credentials.json +195 -0
  44. package/dist/contexts/data-integrity-v2.json +81 -0
  45. package/dist/contexts/dids.json +57 -0
  46. package/dist/contexts/ed255192020.json +93 -0
  47. package/dist/contexts/ordinals-plus.json +23 -0
  48. package/dist/contexts/originals.json +22 -0
  49. package/dist/core/OriginalsSDK.d.ts +158 -0
  50. package/dist/core/OriginalsSDK.js +274 -0
  51. package/dist/crypto/Multikey.d.ts +30 -0
  52. package/dist/crypto/Multikey.js +149 -0
  53. package/dist/crypto/Signer.d.ts +21 -0
  54. package/dist/crypto/Signer.js +196 -0
  55. package/dist/crypto/noble-init.d.ts +18 -0
  56. package/dist/crypto/noble-init.js +106 -0
  57. package/dist/did/BtcoDidResolver.d.ts +57 -0
  58. package/dist/did/BtcoDidResolver.js +166 -0
  59. package/dist/did/DIDManager.d.ts +101 -0
  60. package/dist/did/DIDManager.js +493 -0
  61. package/dist/did/Ed25519Verifier.d.ts +30 -0
  62. package/dist/did/Ed25519Verifier.js +59 -0
  63. package/dist/did/KeyManager.d.ts +17 -0
  64. package/dist/did/KeyManager.js +207 -0
  65. package/dist/did/WebVHManager.d.ts +100 -0
  66. package/dist/did/WebVHManager.js +304 -0
  67. package/dist/did/createBtcoDidDocument.d.ts +10 -0
  68. package/dist/did/createBtcoDidDocument.js +42 -0
  69. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
  70. package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
  71. package/dist/events/EventEmitter.d.ts +115 -0
  72. package/dist/events/EventEmitter.js +198 -0
  73. package/dist/events/index.d.ts +7 -0
  74. package/dist/events/index.js +6 -0
  75. package/dist/events/types.d.ts +286 -0
  76. package/dist/events/types.js +9 -0
  77. package/dist/examples/basic-usage.d.ts +3 -0
  78. package/dist/examples/basic-usage.js +62 -0
  79. package/dist/examples/run.d.ts +1 -0
  80. package/dist/examples/run.js +4 -0
  81. package/dist/index.d.ts +39 -0
  82. package/dist/index.js +47 -0
  83. package/dist/lifecycle/BatchOperations.d.ts +147 -0
  84. package/dist/lifecycle/BatchOperations.js +251 -0
  85. package/dist/lifecycle/LifecycleManager.d.ts +116 -0
  86. package/dist/lifecycle/LifecycleManager.js +971 -0
  87. package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
  88. package/dist/lifecycle/OriginalsAsset.js +380 -0
  89. package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
  90. package/dist/lifecycle/ProvenanceQuery.js +220 -0
  91. package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
  92. package/dist/lifecycle/ResourceVersioning.js +127 -0
  93. package/dist/migration/MigrationManager.d.ts +86 -0
  94. package/dist/migration/MigrationManager.js +412 -0
  95. package/dist/migration/audit/AuditLogger.d.ts +51 -0
  96. package/dist/migration/audit/AuditLogger.js +156 -0
  97. package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
  98. package/dist/migration/checkpoint/CheckpointManager.js +96 -0
  99. package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
  100. package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
  101. package/dist/migration/index.d.ts +22 -0
  102. package/dist/migration/index.js +27 -0
  103. package/dist/migration/operations/BaseMigration.d.ts +48 -0
  104. package/dist/migration/operations/BaseMigration.js +83 -0
  105. package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
  106. package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
  107. package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
  108. package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
  109. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
  110. package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
  111. package/dist/migration/rollback/RollbackManager.d.ts +29 -0
  112. package/dist/migration/rollback/RollbackManager.js +146 -0
  113. package/dist/migration/state/StateMachine.d.ts +25 -0
  114. package/dist/migration/state/StateMachine.js +76 -0
  115. package/dist/migration/state/StateTracker.d.ts +36 -0
  116. package/dist/migration/state/StateTracker.js +123 -0
  117. package/dist/migration/types.d.ts +306 -0
  118. package/dist/migration/types.js +33 -0
  119. package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
  120. package/dist/migration/validation/BitcoinValidator.js +83 -0
  121. package/dist/migration/validation/CredentialValidator.d.ts +13 -0
  122. package/dist/migration/validation/CredentialValidator.js +46 -0
  123. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
  124. package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
  125. package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
  126. package/dist/migration/validation/LifecycleValidator.js +52 -0
  127. package/dist/migration/validation/StorageValidator.d.ts +10 -0
  128. package/dist/migration/validation/StorageValidator.js +65 -0
  129. package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
  130. package/dist/migration/validation/ValidationPipeline.js +180 -0
  131. package/dist/storage/LocalStorageAdapter.d.ts +11 -0
  132. package/dist/storage/LocalStorageAdapter.js +53 -0
  133. package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
  134. package/dist/storage/MemoryStorageAdapter.js +21 -0
  135. package/dist/storage/StorageAdapter.d.ts +16 -0
  136. package/dist/storage/StorageAdapter.js +1 -0
  137. package/dist/storage/index.d.ts +2 -0
  138. package/dist/storage/index.js +2 -0
  139. package/dist/types/bitcoin.d.ts +84 -0
  140. package/dist/types/bitcoin.js +1 -0
  141. package/dist/types/common.d.ts +82 -0
  142. package/dist/types/common.js +1 -0
  143. package/dist/types/credentials.d.ts +75 -0
  144. package/dist/types/credentials.js +1 -0
  145. package/dist/types/did.d.ts +26 -0
  146. package/dist/types/did.js +1 -0
  147. package/dist/types/index.d.ts +5 -0
  148. package/dist/types/index.js +5 -0
  149. package/dist/types/network.d.ts +78 -0
  150. package/dist/types/network.js +145 -0
  151. package/dist/utils/EventLogger.d.ts +71 -0
  152. package/dist/utils/EventLogger.js +232 -0
  153. package/dist/utils/Logger.d.ts +106 -0
  154. package/dist/utils/Logger.js +257 -0
  155. package/dist/utils/MetricsCollector.d.ts +110 -0
  156. package/dist/utils/MetricsCollector.js +264 -0
  157. package/dist/utils/bitcoin-address.d.ts +38 -0
  158. package/dist/utils/bitcoin-address.js +113 -0
  159. package/dist/utils/cbor.d.ts +2 -0
  160. package/dist/utils/cbor.js +9 -0
  161. package/dist/utils/encoding.d.ts +37 -0
  162. package/dist/utils/encoding.js +120 -0
  163. package/dist/utils/hash.d.ts +1 -0
  164. package/dist/utils/hash.js +5 -0
  165. package/dist/utils/retry.d.ts +10 -0
  166. package/dist/utils/retry.js +35 -0
  167. package/dist/utils/satoshi-validation.d.ts +60 -0
  168. package/dist/utils/satoshi-validation.js +156 -0
  169. package/dist/utils/serialization.d.ts +14 -0
  170. package/dist/utils/serialization.js +76 -0
  171. package/dist/utils/telemetry.d.ts +17 -0
  172. package/dist/utils/telemetry.js +24 -0
  173. package/dist/utils/validation.d.ts +5 -0
  174. package/dist/utils/validation.js +98 -0
  175. package/dist/vc/CredentialManager.d.ts +22 -0
  176. package/dist/vc/CredentialManager.js +227 -0
  177. package/dist/vc/Issuer.d.ts +27 -0
  178. package/dist/vc/Issuer.js +70 -0
  179. package/dist/vc/Verifier.d.ts +16 -0
  180. package/dist/vc/Verifier.js +50 -0
  181. package/dist/vc/cryptosuites/bbs.d.ts +44 -0
  182. package/dist/vc/cryptosuites/bbs.js +213 -0
  183. package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
  184. package/dist/vc/cryptosuites/bbsSimple.js +12 -0
  185. package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
  186. package/dist/vc/cryptosuites/eddsa.js +81 -0
  187. package/dist/vc/documentLoader.d.ts +16 -0
  188. package/dist/vc/documentLoader.js +59 -0
  189. package/dist/vc/proofs/data-integrity.d.ts +21 -0
  190. package/dist/vc/proofs/data-integrity.js +15 -0
  191. package/dist/vc/utils/jsonld.d.ts +2 -0
  192. package/dist/vc/utils/jsonld.js +15 -0
  193. package/package.json +79 -0
  194. package/src/adapters/FeeOracleMock.ts +9 -0
  195. package/src/adapters/index.ts +5 -0
  196. package/src/adapters/providers/OrdHttpProvider.ts +126 -0
  197. package/src/adapters/providers/OrdMockProvider.ts +101 -0
  198. package/src/adapters/types.ts +66 -0
  199. package/src/bitcoin/BitcoinManager.ts +330 -0
  200. package/src/bitcoin/BroadcastClient.ts +54 -0
  201. package/src/bitcoin/OrdinalsClient.ts +119 -0
  202. package/src/bitcoin/PSBTBuilder.ts +106 -0
  203. package/src/bitcoin/fee-calculation.ts +38 -0
  204. package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
  205. package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
  206. package/src/bitcoin/providers/types.ts +59 -0
  207. package/src/bitcoin/transactions/commit.ts +465 -0
  208. package/src/bitcoin/transactions/index.ts +13 -0
  209. package/src/bitcoin/transfer.ts +43 -0
  210. package/src/bitcoin/utxo-selection.ts +322 -0
  211. package/src/bitcoin/utxo.ts +113 -0
  212. package/src/contexts/credentials-v1.json +237 -0
  213. package/src/contexts/credentials-v2-examples.json +5 -0
  214. package/src/contexts/credentials-v2.json +340 -0
  215. package/src/contexts/credentials.json +237 -0
  216. package/src/contexts/data-integrity-v2.json +81 -0
  217. package/src/contexts/dids.json +58 -0
  218. package/src/contexts/ed255192020.json +93 -0
  219. package/src/contexts/ordinals-plus.json +23 -0
  220. package/src/contexts/originals.json +22 -0
  221. package/src/core/OriginalsSDK.ts +416 -0
  222. package/src/crypto/Multikey.ts +194 -0
  223. package/src/crypto/Signer.ts +254 -0
  224. package/src/crypto/noble-init.ts +121 -0
  225. package/src/did/BtcoDidResolver.ts +227 -0
  226. package/src/did/DIDManager.ts +694 -0
  227. package/src/did/Ed25519Verifier.ts +68 -0
  228. package/src/did/KeyManager.ts +236 -0
  229. package/src/did/WebVHManager.ts +489 -0
  230. package/src/did/createBtcoDidDocument.ts +59 -0
  231. package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
  232. package/src/events/EventEmitter.ts +222 -0
  233. package/src/events/index.ts +19 -0
  234. package/src/events/types.ts +331 -0
  235. package/src/examples/basic-usage.ts +78 -0
  236. package/src/examples/run.ts +5 -0
  237. package/src/index.ts +84 -0
  238. package/src/lifecycle/BatchOperations.ts +373 -0
  239. package/src/lifecycle/LifecycleManager.ts +1218 -0
  240. package/src/lifecycle/OriginalsAsset.ts +524 -0
  241. package/src/lifecycle/ProvenanceQuery.ts +280 -0
  242. package/src/lifecycle/ResourceVersioning.ts +163 -0
  243. package/src/migration/MigrationManager.ts +527 -0
  244. package/src/migration/audit/AuditLogger.ts +176 -0
  245. package/src/migration/checkpoint/CheckpointManager.ts +112 -0
  246. package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
  247. package/src/migration/index.ts +33 -0
  248. package/src/migration/operations/BaseMigration.ts +126 -0
  249. package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
  250. package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
  251. package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
  252. package/src/migration/rollback/RollbackManager.ts +170 -0
  253. package/src/migration/state/StateMachine.ts +92 -0
  254. package/src/migration/state/StateTracker.ts +156 -0
  255. package/src/migration/types.ts +344 -0
  256. package/src/migration/validation/BitcoinValidator.ts +107 -0
  257. package/src/migration/validation/CredentialValidator.ts +62 -0
  258. package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
  259. package/src/migration/validation/LifecycleValidator.ts +64 -0
  260. package/src/migration/validation/StorageValidator.ts +79 -0
  261. package/src/migration/validation/ValidationPipeline.ts +213 -0
  262. package/src/storage/LocalStorageAdapter.ts +61 -0
  263. package/src/storage/MemoryStorageAdapter.ts +29 -0
  264. package/src/storage/StorageAdapter.ts +25 -0
  265. package/src/storage/index.ts +3 -0
  266. package/src/types/bitcoin.ts +98 -0
  267. package/src/types/common.ts +92 -0
  268. package/src/types/credentials.ts +88 -0
  269. package/src/types/did.ts +31 -0
  270. package/src/types/external-shims.d.ts +53 -0
  271. package/src/types/index.ts +7 -0
  272. package/src/types/network.ts +175 -0
  273. package/src/utils/EventLogger.ts +298 -0
  274. package/src/utils/Logger.ts +322 -0
  275. package/src/utils/MetricsCollector.ts +358 -0
  276. package/src/utils/bitcoin-address.ts +130 -0
  277. package/src/utils/cbor.ts +12 -0
  278. package/src/utils/encoding.ts +127 -0
  279. package/src/utils/hash.ts +6 -0
  280. package/src/utils/retry.ts +46 -0
  281. package/src/utils/satoshi-validation.ts +196 -0
  282. package/src/utils/serialization.ts +96 -0
  283. package/src/utils/telemetry.ts +40 -0
  284. package/src/utils/validation.ts +119 -0
  285. package/src/vc/CredentialManager.ts +273 -0
  286. package/src/vc/Issuer.ts +100 -0
  287. package/src/vc/Verifier.ts +47 -0
  288. package/src/vc/cryptosuites/bbs.ts +253 -0
  289. package/src/vc/cryptosuites/bbsSimple.ts +21 -0
  290. package/src/vc/cryptosuites/eddsa.ts +99 -0
  291. package/src/vc/documentLoader.ts +67 -0
  292. package/src/vc/proofs/data-integrity.ts +33 -0
  293. package/src/vc/utils/jsonld.ts +18 -0
  294. package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +1 -0
  295. package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +1 -0
  296. package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +1 -0
  297. package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +1 -0
  298. package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +1 -0
  299. package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +1 -0
  300. package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +1 -0
  301. package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +1 -0
  302. package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +1 -0
  303. package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +1 -0
  304. package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +1 -0
  305. package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +1 -0
  306. package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +1 -0
  307. package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +1 -0
  308. package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +1 -0
  309. package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +1 -0
  310. package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +1 -0
  311. package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +1 -0
  312. package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +1 -0
  313. package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +1 -0
  314. package/tests/__mocks__/bbs-signatures.js +17 -0
  315. package/tests/__mocks__/mf-base58.js +24 -0
  316. package/tests/e2e/README.md +97 -0
  317. package/tests/e2e/example.spec.ts +78 -0
  318. package/tests/fixtures/did-documents.ts +247 -0
  319. package/tests/index.test.ts +21 -0
  320. package/tests/integration/BatchOperations.test.ts +531 -0
  321. package/tests/integration/CompleteLifecycle.e2e.test.ts +735 -0
  322. package/tests/integration/CredentialManager.test.ts +42 -0
  323. package/tests/integration/DIDManager.test.ts +41 -0
  324. package/tests/integration/DidPeerToWebVhFlow.test.ts +351 -0
  325. package/tests/integration/Events.test.ts +435 -0
  326. package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +25 -0
  327. package/tests/integration/LifecycleManager.test.ts +21 -0
  328. package/tests/integration/MultikeyFlow.test.ts +52 -0
  329. package/tests/integration/TelemetryIntegration.test.ts +395 -0
  330. package/tests/integration/WebVhPublish.test.ts +48 -0
  331. package/tests/integration/migration/peer-to-webvh.test.ts +172 -0
  332. package/tests/manual/test-commit-creation.ts +323 -0
  333. package/tests/mocks/MockKeyStore.ts +38 -0
  334. package/tests/mocks/adapters/MemoryStorageAdapter.ts +24 -0
  335. package/tests/mocks/adapters/MockFeeOracle.ts +11 -0
  336. package/tests/mocks/adapters/MockOrdinalsProvider.ts +76 -0
  337. package/tests/mocks/adapters/OrdMockProvider.test.ts +176 -0
  338. package/tests/mocks/adapters/index.ts +6 -0
  339. package/tests/performance/BatchOperations.perf.test.ts +403 -0
  340. package/tests/performance/logging.perf.test.ts +336 -0
  341. package/tests/sdk.test.ts +43 -0
  342. package/tests/security/bitcoin-penetration-tests.test.ts +622 -0
  343. package/tests/setup.bun.ts +69 -0
  344. package/tests/setup.jest.ts +23 -0
  345. package/tests/stress/batch-operations-stress.test.ts +571 -0
  346. package/tests/unit/adapters/FeeOracleMock.test.ts +40 -0
  347. package/tests/unit/bitcoin/BitcoinManager.test.ts +293 -0
  348. package/tests/unit/bitcoin/BroadcastClient.test.ts +52 -0
  349. package/tests/unit/bitcoin/OrdNodeProvider.test.ts +53 -0
  350. package/tests/unit/bitcoin/OrdinalsClient.test.ts +381 -0
  351. package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +102 -0
  352. package/tests/unit/bitcoin/PSBTBuilder.test.ts +84 -0
  353. package/tests/unit/bitcoin/fee-calculation.test.ts +261 -0
  354. package/tests/unit/bitcoin/transactions/commit.test.ts +649 -0
  355. package/tests/unit/bitcoin/transfer.test.ts +31 -0
  356. package/tests/unit/bitcoin/utxo-selection-new.test.ts +502 -0
  357. package/tests/unit/bitcoin/utxo.more.test.ts +39 -0
  358. package/tests/unit/bitcoin/utxo.selection.test.ts +38 -0
  359. package/tests/unit/core/OriginalsSDK.test.ts +152 -0
  360. package/tests/unit/crypto/Multikey.test.ts +206 -0
  361. package/tests/unit/crypto/Signer.test.ts +408 -0
  362. package/tests/unit/did/BtcoDidResolver.test.ts +611 -0
  363. package/tests/unit/did/DIDManager.more.test.ts +43 -0
  364. package/tests/unit/did/DIDManager.test.ts +185 -0
  365. package/tests/unit/did/Ed25519Verifier.test.ts +160 -0
  366. package/tests/unit/did/KeyManager.test.ts +452 -0
  367. package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +45 -0
  368. package/tests/unit/did/WebVHManager.test.ts +435 -0
  369. package/tests/unit/did/createBtcoDidDocument.test.ts +67 -0
  370. package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +159 -0
  371. package/tests/unit/events/EventEmitter.test.ts +407 -0
  372. package/tests/unit/lifecycle/BatchOperations.test.ts +527 -0
  373. package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +312 -0
  374. package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +18 -0
  375. package/tests/unit/lifecycle/LifecycleManager.test.ts +213 -0
  376. package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +30 -0
  377. package/tests/unit/lifecycle/OriginalsAsset.test.ts +176 -0
  378. package/tests/unit/lifecycle/ProvenanceQuery.test.ts +577 -0
  379. package/tests/unit/lifecycle/ResourceVersioning.test.ts +651 -0
  380. package/tests/unit/storage/MemoryStorageAdapter.test.ts +93 -0
  381. package/tests/unit/types/network.test.ts +255 -0
  382. package/tests/unit/utils/EventIntegration.test.ts +384 -0
  383. package/tests/unit/utils/Logger.test.ts +473 -0
  384. package/tests/unit/utils/MetricsCollector.test.ts +358 -0
  385. package/tests/unit/utils/bitcoin-address.test.ts +250 -0
  386. package/tests/unit/utils/cbor.test.ts +35 -0
  387. package/tests/unit/utils/encoding.test.ts +318 -0
  388. package/tests/unit/utils/hash.test.ts +12 -0
  389. package/tests/unit/utils/retry.test.ts +100 -0
  390. package/tests/unit/utils/satoshi-validation.test.ts +354 -0
  391. package/tests/unit/utils/serialization.test.ts +124 -0
  392. package/tests/unit/utils/telemetry.test.ts +52 -0
  393. package/tests/unit/utils/validation.test.ts +141 -0
  394. package/tests/unit/vc/CredentialManager.test.ts +487 -0
  395. package/tests/unit/vc/Issuer.test.ts +107 -0
  396. package/tests/unit/vc/Verifier.test.ts +525 -0
  397. package/tests/unit/vc/bbs.test.ts +282 -0
  398. package/tests/unit/vc/cryptosuites/eddsa.test.ts +398 -0
  399. package/tests/unit/vc/documentLoader.test.ts +121 -0
  400. package/tests/unit/vc/proofs/data-integrity.test.ts +24 -0
  401. package/tsconfig.json +32 -0
  402. package/tsconfig.test.json +15 -0
  403. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,384 @@
1
+ import { describe, test, expect, beforeEach, mock } from 'bun:test';
2
+ import { EventLogger } from '../../../src/utils/EventLogger';
3
+ import { Logger, type LogOutput } from '../../../src/utils/Logger';
4
+ import { MetricsCollector } from '../../../src/utils/MetricsCollector';
5
+ import { EventEmitter } from '../../../src/events/EventEmitter';
6
+ import type { AssetCreatedEvent, AssetMigratedEvent, AssetTransferredEvent } from '../../../src/events/types';
7
+ import type { OriginalsConfig } from '../../../src/types';
8
+
9
+ describe('EventIntegration', () => {
10
+ let eventEmitter: EventEmitter;
11
+ let logger: Logger;
12
+ let metricsCollector: MetricsCollector;
13
+ let eventLogger: EventLogger;
14
+ let config: OriginalsConfig;
15
+ let logOutput: any;
16
+
17
+ beforeEach(() => {
18
+ eventEmitter = new EventEmitter();
19
+ metricsCollector = new MetricsCollector();
20
+
21
+ logOutput = mock(() => {});
22
+ const mockOutput: LogOutput = {
23
+ write: logOutput
24
+ };
25
+
26
+ config = {
27
+ network: 'mainnet',
28
+ defaultKeyType: 'ES256K',
29
+ logging: {
30
+ level: 'info',
31
+ outputs: [mockOutput]
32
+ }
33
+ };
34
+
35
+ logger = new Logger('Test', config);
36
+ eventLogger = new EventLogger(logger, metricsCollector);
37
+ });
38
+
39
+ describe('event subscription', () => {
40
+ test('should subscribe to all event types', () => {
41
+ eventLogger.subscribeToEvents(eventEmitter);
42
+
43
+ // Check that event emitter has listeners
44
+ expect(eventEmitter.hasListeners('asset:created')).toBe(true);
45
+ expect(eventEmitter.hasListeners('asset:migrated')).toBe(true);
46
+ expect(eventEmitter.hasListeners('asset:transferred')).toBe(true);
47
+ expect(eventEmitter.hasListeners('resource:published')).toBe(true);
48
+ expect(eventEmitter.hasListeners('credential:issued')).toBe(true);
49
+ expect(eventEmitter.hasListeners('verification:completed')).toBe(true);
50
+ });
51
+
52
+ test('should unsubscribe from all events', () => {
53
+ eventLogger.subscribeToEvents(eventEmitter);
54
+ eventLogger.unsubscribe();
55
+
56
+ expect(eventEmitter.hasListeners('asset:created')).toBe(false);
57
+ expect(eventEmitter.hasListeners('asset:migrated')).toBe(false);
58
+ expect(eventEmitter.hasListeners('asset:transferred')).toBe(false);
59
+ });
60
+ });
61
+
62
+ describe('event logging', () => {
63
+ beforeEach(() => {
64
+ eventLogger.subscribeToEvents(eventEmitter);
65
+ });
66
+
67
+ test('should log asset:created events', async () => {
68
+ const event: AssetCreatedEvent = {
69
+ type: 'asset:created',
70
+ timestamp: new Date().toISOString(),
71
+ asset: {
72
+ id: 'did:peer:123',
73
+ layer: 'did:peer',
74
+ resourceCount: 2,
75
+ createdAt: new Date().toISOString()
76
+ }
77
+ };
78
+
79
+ await eventEmitter.emit(event);
80
+
81
+ expect(logOutput).toHaveBeenCalled();
82
+ const logEntry = logOutput.mock.calls[0][0];
83
+ expect(logEntry.message).toBe('Asset created');
84
+ expect(logEntry.data.assetId).toBe('did:peer:123');
85
+ expect(logEntry.data.resourceCount).toBe(2);
86
+ });
87
+
88
+ test('should log asset:migrated events', async () => {
89
+ const event: AssetMigratedEvent = {
90
+ type: 'asset:migrated',
91
+ timestamp: new Date().toISOString(),
92
+ asset: {
93
+ id: 'did:peer:123',
94
+ fromLayer: 'did:peer',
95
+ toLayer: 'did:webvh'
96
+ },
97
+ details: {
98
+ transactionId: 'tx123'
99
+ }
100
+ };
101
+
102
+ await eventEmitter.emit(event);
103
+
104
+ expect(logOutput).toHaveBeenCalled();
105
+ const logEntry = logOutput.mock.calls[0][0];
106
+ expect(logEntry.message).toBe('Asset migrated');
107
+ expect(logEntry.data.fromLayer).toBe('did:peer');
108
+ expect(logEntry.data.toLayer).toBe('did:webvh');
109
+ });
110
+
111
+ test('should log asset:transferred events', async () => {
112
+ const event: AssetTransferredEvent = {
113
+ type: 'asset:transferred',
114
+ timestamp: new Date().toISOString(),
115
+ asset: {
116
+ id: 'did:btco:123',
117
+ layer: 'did:btco'
118
+ },
119
+ from: 'alice',
120
+ to: 'bc1q...',
121
+ transactionId: 'tx456'
122
+ };
123
+
124
+ await eventEmitter.emit(event);
125
+
126
+ expect(logOutput).toHaveBeenCalled();
127
+ const logEntry = logOutput.mock.calls[0][0];
128
+ expect(logEntry.message).toBe('Asset transferred');
129
+ expect(logEntry.data.from).toBe('alice');
130
+ expect(logEntry.data.to).toBe('bc1q...');
131
+ });
132
+ });
133
+
134
+ describe('metrics extraction', () => {
135
+ beforeEach(() => {
136
+ eventLogger.subscribeToEvents(eventEmitter);
137
+ });
138
+
139
+ test('should extract metrics from asset:created events', async () => {
140
+ const event: AssetCreatedEvent = {
141
+ type: 'asset:created',
142
+ timestamp: new Date().toISOString(),
143
+ asset: {
144
+ id: 'did:peer:123',
145
+ layer: 'did:peer',
146
+ resourceCount: 1,
147
+ createdAt: new Date().toISOString()
148
+ }
149
+ };
150
+
151
+ await eventEmitter.emit(event);
152
+
153
+ const metrics = metricsCollector.getMetrics();
154
+ expect(metrics.assetsCreated).toBe(1);
155
+ });
156
+
157
+ test('should extract metrics from asset:migrated events', async () => {
158
+ const event: AssetMigratedEvent = {
159
+ type: 'asset:migrated',
160
+ timestamp: new Date().toISOString(),
161
+ asset: {
162
+ id: 'did:peer:123',
163
+ fromLayer: 'did:peer',
164
+ toLayer: 'did:webvh'
165
+ }
166
+ };
167
+
168
+ await eventEmitter.emit(event);
169
+
170
+ const metrics = metricsCollector.getMetrics();
171
+ expect(metrics.assetsMigrated['peer→webvh']).toBe(1);
172
+ });
173
+
174
+ test('should extract metrics from asset:transferred events', async () => {
175
+ const event: AssetTransferredEvent = {
176
+ type: 'asset:transferred',
177
+ timestamp: new Date().toISOString(),
178
+ asset: {
179
+ id: 'did:btco:123',
180
+ layer: 'did:btco'
181
+ },
182
+ from: 'alice',
183
+ to: 'bc1q...',
184
+ transactionId: 'tx456'
185
+ };
186
+
187
+ await eventEmitter.emit(event);
188
+
189
+ const metrics = metricsCollector.getMetrics();
190
+ expect(metrics.assetsTransferred).toBe(1);
191
+ });
192
+
193
+ test('should track multiple events', async () => {
194
+ const events = [
195
+ {
196
+ type: 'asset:created' as const,
197
+ timestamp: new Date().toISOString(),
198
+ asset: {
199
+ id: 'did:peer:1',
200
+ layer: 'did:peer' as const,
201
+ resourceCount: 1,
202
+ createdAt: new Date().toISOString()
203
+ }
204
+ },
205
+ {
206
+ type: 'asset:created' as const,
207
+ timestamp: new Date().toISOString(),
208
+ asset: {
209
+ id: 'did:peer:2',
210
+ layer: 'did:peer' as const,
211
+ resourceCount: 1,
212
+ createdAt: new Date().toISOString()
213
+ }
214
+ },
215
+ {
216
+ type: 'asset:migrated' as const,
217
+ timestamp: new Date().toISOString(),
218
+ asset: {
219
+ id: 'did:peer:1',
220
+ fromLayer: 'did:peer' as const,
221
+ toLayer: 'did:webvh' as const
222
+ }
223
+ }
224
+ ];
225
+
226
+ for (const event of events) {
227
+ await eventEmitter.emit(event);
228
+ }
229
+
230
+ const metrics = metricsCollector.getMetrics();
231
+ expect(metrics.assetsCreated).toBe(2);
232
+ expect(metrics.assetsMigrated['peer→webvh']).toBe(1);
233
+ });
234
+ });
235
+
236
+ describe('event logging configuration', () => {
237
+ test('should respect custom log levels', async () => {
238
+ eventLogger.configureEventLogging({
239
+ 'asset:created': 'debug',
240
+ 'asset:migrated': 'warn'
241
+ });
242
+
243
+ eventLogger.subscribeToEvents(eventEmitter);
244
+
245
+ const event: AssetCreatedEvent = {
246
+ type: 'asset:created',
247
+ timestamp: new Date().toISOString(),
248
+ asset: {
249
+ id: 'did:peer:123',
250
+ layer: 'did:peer',
251
+ resourceCount: 1,
252
+ createdAt: new Date().toISOString()
253
+ }
254
+ };
255
+
256
+ // With default info level, debug logs won't appear
257
+ await eventEmitter.emit(event);
258
+
259
+ // Log should not appear because debug is below info threshold
260
+ // (Logger is configured with 'info' level)
261
+ // This is a smoke test to ensure configuration doesn't crash
262
+ expect(logOutput.mock.calls.length).toBeGreaterThanOrEqual(0);
263
+ });
264
+
265
+ test('should disable logging for specific events', async () => {
266
+ eventLogger.configureEventLogging({
267
+ 'asset:created': false
268
+ });
269
+
270
+ eventLogger.subscribeToEvents(eventEmitter);
271
+
272
+ const createdEvent: AssetCreatedEvent = {
273
+ type: 'asset:created',
274
+ timestamp: new Date().toISOString(),
275
+ asset: {
276
+ id: 'did:peer:123',
277
+ layer: 'did:peer',
278
+ resourceCount: 1,
279
+ createdAt: new Date().toISOString()
280
+ }
281
+ };
282
+
283
+ const migratedEvent: AssetMigratedEvent = {
284
+ type: 'asset:migrated',
285
+ timestamp: new Date().toISOString(),
286
+ asset: {
287
+ id: 'did:peer:123',
288
+ fromLayer: 'did:peer',
289
+ toLayer: 'did:webvh'
290
+ }
291
+ };
292
+
293
+ await eventEmitter.emit(createdEvent);
294
+ const callsAfterCreated = logOutput.mock.calls.length;
295
+
296
+ await eventEmitter.emit(migratedEvent);
297
+ const callsAfterMigrated = logOutput.mock.calls.length;
298
+
299
+ // asset:created should not log, asset:migrated should log
300
+ expect(callsAfterMigrated).toBeGreaterThan(callsAfterCreated);
301
+ });
302
+
303
+ test('should still extract metrics even when logging is disabled', async () => {
304
+ eventLogger.configureEventLogging({
305
+ 'asset:created': false
306
+ });
307
+
308
+ eventLogger.subscribeToEvents(eventEmitter);
309
+
310
+ const event: AssetCreatedEvent = {
311
+ type: 'asset:created',
312
+ timestamp: new Date().toISOString(),
313
+ asset: {
314
+ id: 'did:peer:123',
315
+ layer: 'did:peer',
316
+ resourceCount: 1,
317
+ createdAt: new Date().toISOString()
318
+ }
319
+ };
320
+
321
+ await eventEmitter.emit(event);
322
+
323
+ // Metrics should still be recorded
324
+ const metrics = metricsCollector.getMetrics();
325
+ expect(metrics.assetsCreated).toBe(1);
326
+ });
327
+ });
328
+
329
+ describe('performance', () => {
330
+ test('should have minimal overhead (<1ms per event)', async () => {
331
+ eventLogger.subscribeToEvents(eventEmitter);
332
+
333
+ const event: AssetCreatedEvent = {
334
+ type: 'asset:created',
335
+ timestamp: new Date().toISOString(),
336
+ asset: {
337
+ id: 'did:peer:123',
338
+ layer: 'did:peer',
339
+ resourceCount: 1,
340
+ createdAt: new Date().toISOString()
341
+ }
342
+ };
343
+
344
+ const start = performance.now();
345
+ for (let i = 0; i < 100; i++) {
346
+ await eventEmitter.emit(event);
347
+ }
348
+ const duration = performance.now() - start;
349
+
350
+ const avgDuration = duration / 100;
351
+
352
+ // Each event should add less than 1ms overhead
353
+ expect(avgDuration).toBeLessThan(1);
354
+ });
355
+ });
356
+
357
+ describe('error handling', () => {
358
+ test('should not throw if metrics recording fails', async () => {
359
+ // Create a spy that throws
360
+ const brokenMetrics = new MetricsCollector();
361
+ (brokenMetrics as any).recordAssetCreated = () => {
362
+ throw new Error('Metrics error');
363
+ };
364
+
365
+ const brokenEventLogger = new EventLogger(logger, brokenMetrics);
366
+ brokenEventLogger.subscribeToEvents(eventEmitter);
367
+
368
+ const event: AssetCreatedEvent = {
369
+ type: 'asset:created',
370
+ timestamp: new Date().toISOString(),
371
+ asset: {
372
+ id: 'did:peer:123',
373
+ layer: 'did:peer',
374
+ resourceCount: 1,
375
+ createdAt: new Date().toISOString()
376
+ }
377
+ };
378
+
379
+ // Should not throw even if metrics recording fails
380
+ await expect(eventEmitter.emit(event)).resolves.toBeUndefined();
381
+ });
382
+ });
383
+ });
384
+