@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,312 @@
1
+ import { expect, describe, test, beforeEach, afterEach } from 'bun:test';
2
+ import { LifecycleManager } from '../../../src/lifecycle/LifecycleManager';
3
+ import { DIDManager } from '../../../src/did/DIDManager';
4
+ import { CredentialManager } from '../../../src/vc/CredentialManager';
5
+ import { KeyManager } from '../../../src/did/KeyManager';
6
+ import { MockKeyStore } from '../../mocks/MockKeyStore';
7
+ import { OriginalsConfig } from '../../../src/types';
8
+ import * as fs from 'fs';
9
+ import * as path from 'path';
10
+ import { tmpdir } from 'os';
11
+
12
+ const resources = [
13
+ {
14
+ id: 'res1',
15
+ type: 'text',
16
+ content: 'hello world',
17
+ contentType: 'text/plain',
18
+ hash: 'deadbeef'
19
+ }
20
+ ];
21
+
22
+ const config: OriginalsConfig = {
23
+ network: 'regtest',
24
+ defaultKeyType: 'Ed25519', // Use Ed25519 for did:webvh compatibility
25
+ enableLogging: true
26
+ };
27
+
28
+ describe('LifecycleManager Key Management', () => {
29
+ let lifecycleManager: LifecycleManager;
30
+ let didManager: DIDManager;
31
+ let credentialManager: CredentialManager;
32
+ let keyStore: MockKeyStore;
33
+ let publisherDid: string;
34
+ let tempDir: string;
35
+ let publisherKeyPair: any;
36
+
37
+ beforeEach(async () => {
38
+ didManager = new DIDManager(config);
39
+ credentialManager = new CredentialManager(config, didManager);
40
+ keyStore = new MockKeyStore();
41
+ lifecycleManager = new LifecycleManager(config, didManager, credentialManager, undefined, keyStore);
42
+
43
+ // Create a simple mock publisher DID instead of creating a full did:webvh
44
+ // This avoids the overhead of DID creation for every test
45
+ publisherDid = 'did:webvh:example.com:user';
46
+
47
+ // Create a key pair for the publisher
48
+ const keyManager = new KeyManager();
49
+ publisherKeyPair = await keyManager.generateKeyPair('Ed25519');
50
+
51
+ // Register the publisher's key in keyStore with common VM ID pattern
52
+ await keyStore.setPrivateKey(`${publisherDid}#key-0`, publisherKeyPair.privateKey);
53
+ });
54
+
55
+ afterEach(async () => {
56
+ // Clean up temp directory
57
+ if (tempDir) {
58
+ try {
59
+ await fs.promises.rm(tempDir, { recursive: true, force: true });
60
+ } catch (err) {
61
+ // Ignore cleanup errors
62
+ }
63
+ }
64
+ });
65
+
66
+ describe('registerKey', () => {
67
+ test('should register a valid private key', async () => {
68
+ const keyManager = new KeyManager();
69
+ const keyPair = await keyManager.generateKeyPair('ES256K');
70
+ const vmId = 'did:peer:test#keys-1';
71
+
72
+ await lifecycleManager.registerKey(vmId, keyPair.privateKey);
73
+
74
+ const retrievedKey = await keyStore.getPrivateKey(vmId);
75
+ expect(retrievedKey).toBe(keyPair.privateKey);
76
+ });
77
+
78
+ test('should throw error when keyStore not configured', async () => {
79
+ const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
80
+ const keyManager = new KeyManager();
81
+ const keyPair = await keyManager.generateKeyPair('ES256K');
82
+
83
+ await expect(
84
+ lifecycleWithoutKeyStore.registerKey('did:peer:test#keys-1', keyPair.privateKey)
85
+ ).rejects.toThrow('KeyStore not configured');
86
+ });
87
+
88
+ test('should throw error for invalid verification method ID', async () => {
89
+ const keyManager = new KeyManager();
90
+ const keyPair = await keyManager.generateKeyPair('ES256K');
91
+
92
+ await expect(
93
+ lifecycleManager.registerKey('', keyPair.privateKey)
94
+ ).rejects.toThrow('Invalid verificationMethodId');
95
+ });
96
+
97
+ test('should throw error for invalid private key format', async () => {
98
+ await expect(
99
+ lifecycleManager.registerKey('did:peer:test#keys-1', 'invalid-key')
100
+ ).rejects.toThrow('Invalid privateKey format');
101
+ });
102
+
103
+ test('should throw error for empty private key', async () => {
104
+ await expect(
105
+ lifecycleManager.registerKey('did:peer:test#keys-1', '')
106
+ ).rejects.toThrow('Invalid privateKey');
107
+ });
108
+ });
109
+
110
+ describe('createAsset with keyStore', () => {
111
+ test('should automatically register key when keyStore is provided', async () => {
112
+ const asset = await lifecycleManager.createAsset(resources);
113
+
114
+ expect(asset.currentLayer).toBe('did:peer');
115
+ expect(asset.did.verificationMethod).toBeDefined();
116
+ expect(asset.did.verificationMethod!.length).toBeGreaterThan(0);
117
+
118
+ let vmId = asset.did.verificationMethod![0].id;
119
+ // Ensure VM ID is absolute
120
+ if (vmId.startsWith('#')) {
121
+ vmId = `${asset.did.id}${vmId}`;
122
+ }
123
+
124
+ const privateKey = await keyStore.getPrivateKey(vmId);
125
+ expect(privateKey).not.toBeNull();
126
+ expect(typeof privateKey).toBe('string');
127
+ });
128
+
129
+ test('should create asset without keyStore gracefully', async () => {
130
+ const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
131
+ const asset = await lifecycleWithoutKeyStore.createAsset(resources);
132
+
133
+ expect(asset.currentLayer).toBe('did:peer');
134
+ expect(asset.did.verificationMethod).toBeDefined();
135
+ });
136
+ });
137
+
138
+ describe('publishToWeb with DID keys', () => {
139
+ test('should sign credential with DID document key from keyStore', async () => {
140
+ const asset = await lifecycleManager.createAsset(resources);
141
+
142
+ // Verify key was stored
143
+ let vmId = asset.did.verificationMethod![0].id;
144
+ if (vmId.startsWith('#')) {
145
+ vmId = `${asset.did.id}${vmId}`;
146
+ }
147
+ const storedKey = await keyStore.getPrivateKey(vmId);
148
+ expect(storedKey).not.toBeNull();
149
+
150
+ const published = await lifecycleManager.publishToWeb(asset, publisherDid);
151
+
152
+ expect(published.currentLayer).toBe('did:webvh');
153
+ expect(published.credentials.length).toBeGreaterThan(0);
154
+
155
+ const credential = published.credentials[0];
156
+ expect(credential.proof).toBeDefined();
157
+ expect(credential.type).toContain('ResourceMigrated');
158
+ expect(credential.issuer).toBe(publisherDid); // Publisher DID is the issuer
159
+
160
+ const proof = credential.proof as any;
161
+ // Verification method should be from the publisher DID, not the asset
162
+ expect(proof.verificationMethod).toContain(publisherDid);
163
+ });
164
+
165
+ test('should not add credential when keyStore not provided', async () => {
166
+ const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
167
+ const asset = await lifecycleWithoutKeyStore.createAsset(resources);
168
+
169
+ // Publishing should succeed but no credential should be added (best-effort)
170
+ const published = await lifecycleWithoutKeyStore.publishToWeb(asset, publisherDid);
171
+
172
+ expect(published.currentLayer).toBe('did:webvh');
173
+ // No credential should be added due to missing keyStore
174
+ expect(published.credentials.length).toBe(0);
175
+ });
176
+
177
+ test('should not add credential when private key not found in keyStore', async () => {
178
+ // Create asset without keyStore
179
+ const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
180
+ const asset = await lifecycleWithoutKeyStore.createAsset(resources);
181
+
182
+ // Try to publish with a different lifecycle manager that has keyStore but no keys
183
+ const emptyKeyStore = new MockKeyStore();
184
+ const lifecycleWithEmptyKeyStore = new LifecycleManager(
185
+ config,
186
+ didManager,
187
+ credentialManager,
188
+ undefined,
189
+ emptyKeyStore
190
+ );
191
+
192
+ // Publishing should succeed but no credential should be added (best-effort)
193
+ const published = await lifecycleWithEmptyKeyStore.publishToWeb(asset, publisherDid);
194
+
195
+ expect(published.currentLayer).toBe('did:webvh');
196
+ // No credential should be added due to missing private key
197
+ expect(published.credentials.length).toBe(0);
198
+ });
199
+
200
+ test('should use keys from keyStore not ephemeral keys', async () => {
201
+ const asset = await lifecycleManager.createAsset(resources);
202
+
203
+ // Get the stored key
204
+ let vmId = asset.did.verificationMethod![0].id;
205
+ if (vmId.startsWith('#')) {
206
+ vmId = `${asset.did.id}${vmId}`;
207
+ }
208
+ const storedKeyBefore = await keyStore.getPrivateKey(vmId);
209
+
210
+ const published = await lifecycleManager.publishToWeb(asset, publisherDid);
211
+
212
+ // Verify the same key is still there (not replaced)
213
+ const storedKeyAfter = await keyStore.getPrivateKey(vmId);
214
+ expect(storedKeyAfter).toBe(storedKeyBefore);
215
+
216
+ // Verify credential was created
217
+ expect(published.credentials.length).toBe(1);
218
+ const credential = published.credentials[0];
219
+ const proof = credential.proof as any;
220
+ // Verification method should be from the publisher DID
221
+ expect(proof.verificationMethod).toContain(publisherDid);
222
+ });
223
+
224
+ test('should use correct verification method from DID document', async () => {
225
+ const asset = await lifecycleManager.createAsset(resources);
226
+ let vmId = asset.did.verificationMethod![0].id;
227
+ const publicKey = asset.did.verificationMethod![0].publicKeyMultibase;
228
+
229
+ // Ensure VM ID is absolute
230
+ if (vmId.startsWith('#')) {
231
+ vmId = `${asset.did.id}${vmId}`;
232
+ }
233
+
234
+ const published = await lifecycleManager.publishToWeb(asset, publisherDid);
235
+ const credential = published.credentials[0];
236
+ const proof = credential.proof as any;
237
+
238
+ // Verify the VM ID references the publisher DID document
239
+ expect(proof.verificationMethod).toContain(publisherDid);
240
+ expect(vmId).toContain(asset.id); // Asset's VM ID contains asset ID
241
+ expect(credential.issuer).toBe(publisherDid); // Publisher is the issuer
242
+ });
243
+ });
244
+
245
+ describe('Key rotation scenario', () => {
246
+ test('should allow registering multiple keys for different verification methods', async () => {
247
+ const keyManager = new KeyManager();
248
+ const keyPair1 = await keyManager.generateKeyPair('ES256K');
249
+ const keyPair2 = await keyManager.generateKeyPair('ES256K');
250
+
251
+ await lifecycleManager.registerKey('did:peer:test#keys-1', keyPair1.privateKey);
252
+ await lifecycleManager.registerKey('did:peer:test#keys-2', keyPair2.privateKey);
253
+
254
+ const key1 = await keyStore.getPrivateKey('did:peer:test#keys-1');
255
+ const key2 = await keyStore.getPrivateKey('did:peer:test#keys-2');
256
+
257
+ expect(key1).toBe(keyPair1.privateKey);
258
+ expect(key2).toBe(keyPair2.privateKey);
259
+ expect(key1).not.toBe(key2);
260
+ });
261
+ });
262
+
263
+ describe('End-to-end credential management', () => {
264
+ test('should create signed credentials throughout asset lifecycle', async () => {
265
+ // Create asset with automatic key registration
266
+ const asset = await lifecycleManager.createAsset(resources);
267
+ expect(asset.did.verificationMethod).toBeDefined();
268
+
269
+ // Publish to web - should create signed credential
270
+ const published = await lifecycleManager.publishToWeb(asset, publisherDid);
271
+ expect(published.credentials.length).toBe(1);
272
+
273
+ // Check credential structure
274
+ const credential = published.credentials[0];
275
+ expect(credential.issuer).toBe(publisherDid); // Publisher is the issuer
276
+ expect(credential.type).toContain('ResourceMigrated');
277
+ expect((credential.credentialSubject as any).fromLayer).toBe('did:peer');
278
+ expect((credential.credentialSubject as any).toLayer).toBe('did:webvh');
279
+
280
+ // Verify proof is present with publisher's VM
281
+ expect(credential.proof).toBeDefined();
282
+ const proof = credential.proof as any;
283
+ // Verification method should be from publisher DID
284
+ expect(proof.verificationMethod).toContain(publisherDid);
285
+ });
286
+ });
287
+
288
+ describe('Error handling', () => {
289
+ test('should handle missing verification method in DID document gracefully', async () => {
290
+ const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
291
+ const asset = await lifecycleWithoutKeyStore.createAsset(resources);
292
+
293
+ // Manually remove verification methods to simulate error case
294
+ (asset.did as any).verificationMethod = [];
295
+
296
+ const lifecycleWithKeyStore = new LifecycleManager(
297
+ config,
298
+ didManager,
299
+ credentialManager,
300
+ undefined,
301
+ keyStore
302
+ );
303
+
304
+ // Should not throw - credentials can be issued using publisher's keys from keyStore
305
+ const published = await lifecycleWithKeyStore.publishToWeb(asset, publisherDid);
306
+
307
+ expect(published.currentLayer).toBe('did:webvh');
308
+ // Credential should be added using publisher's verification method from keyStore
309
+ expect(published.credentials.length).toBeGreaterThanOrEqual(0); // Best effort - may or may not issue
310
+ });
311
+ });
312
+ });
@@ -0,0 +1,18 @@
1
+ import { describe, test, expect } from 'bun:test';
2
+ import { OriginalsSDK } from '../../../src';
3
+ import { MockOrdinalsProvider } from '../../mocks/adapters';
4
+
5
+ describe('LifecycleManager provenance fallback', () => {
6
+ test('inscribeOnBitcoin initializes provenance when missing', async () => {
7
+ const provider = new MockOrdinalsProvider();
8
+ const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
9
+ const asset = await sdk.lifecycle.createAsset([{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }]);
10
+ // ensure provenance exists but is empty (migrations/transfers arrays present)
11
+ (asset as any).provenance = { createdAt: new Date().toISOString(), creator: asset.id, migrations: [], transfers: [] };
12
+ const updated = await sdk.lifecycle.inscribeOnBitcoin(asset);
13
+ const prov = (updated as any).getProvenance();
14
+ const latest = prov.migrations[prov.migrations.length - 1];
15
+ expect(latest.transactionId).toBeDefined();
16
+ expect(latest.feeRate as number).toBeGreaterThan(0);
17
+ });
18
+ });
@@ -0,0 +1,213 @@
1
+ import { describe, test, expect } from 'bun:test';
2
+ import { OriginalsSDK, OriginalsAsset } from '../../../src';
3
+ import { MockOrdinalsProvider } from '../../mocks/adapters';
4
+
5
+ const resources = [
6
+ {
7
+ id: 'res1',
8
+ type: 'text',
9
+ content: 'hello world',
10
+ contentType: 'text/plain',
11
+ hash: 'deadbeef'
12
+ }
13
+ ];
14
+
15
+ describe('LifecycleManager', () => {
16
+ test('createAsset creates a peer-layer asset', async () => {
17
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
18
+ const asset = await sdk.lifecycle.createAsset(resources);
19
+ expect(asset.currentLayer).toBe('did:peer');
20
+ expect(asset.id.startsWith('did:peer:')).toBe(true);
21
+ });
22
+
23
+ test('publishToWeb migrates and records binding', async () => {
24
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
25
+ const asset = await sdk.lifecycle.createAsset(resources);
26
+ const published = await sdk.lifecycle.publishToWeb(asset, 'example.com');
27
+ expect(published.currentLayer).toBe('did:webvh');
28
+ expect(published.bindings?.['did:webvh']).toContain('example.com');
29
+ });
30
+
31
+ test('inscribeOnBitcoin uses provider details for provenance', async () => {
32
+ const provider = new MockOrdinalsProvider();
33
+ const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
34
+ const asset = await sdk.lifecycle.createAsset(resources);
35
+ await sdk.lifecycle.publishToWeb(asset, 'example.com');
36
+ const btco = await sdk.lifecycle.inscribeOnBitcoin(asset, 9);
37
+ expect(btco.currentLayer).toBe('did:btco');
38
+ const provenance = btco.getProvenance();
39
+ const latest = provenance.migrations[provenance.migrations.length - 1];
40
+ expect(latest.inscriptionId).toBe('insc-mock');
41
+ expect(latest.satoshi).toBe('123');
42
+ expect(latest.transactionId).toBe('tx-reveal-mock');
43
+ expect(latest.feeRate).toBe(9);
44
+ expect(btco.bindings?.['did:btco']).toBe('did:btco:123');
45
+ });
46
+
47
+ test('inscribeOnBitcoin without provider throws error', async () => {
48
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
49
+ const asset = await sdk.lifecycle.createAsset(resources);
50
+ await expect(sdk.lifecycle.inscribeOnBitcoin(asset, 5)).rejects.toThrow('Ordinals provider must be configured');
51
+ });
52
+
53
+ test('inscribeOnBitcoin enforces migration guard', async () => {
54
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
55
+ const fakeAsset = { currentLayer: 'did:webvh', migrate: undefined } as unknown as OriginalsAsset;
56
+ await expect(sdk.lifecycle.inscribeOnBitcoin(fakeAsset, 5)).rejects.toThrow('Not implemented');
57
+ });
58
+
59
+ test('publishToWeb throws Not implemented (coverage for throw)', async () => {
60
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
61
+ const fakeAsset: any = { currentLayer: 'did:peer' };
62
+ await expect(
63
+ sdk.lifecycle.publishToWeb(fakeAsset, 'example.com')
64
+ ).rejects.toThrow();
65
+ });
66
+
67
+ test('inscribeOnBitcoin throws Not implemented (coverage for throw)', async () => {
68
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
69
+ const fakeAsset: any = { currentLayer: 'did:webvh' };
70
+ await expect(
71
+ sdk.lifecycle.inscribeOnBitcoin(fakeAsset, 10)
72
+ ).rejects.toThrow('Not implemented');
73
+ });
74
+
75
+ test('transferOwnership succeeds when on btco (returns tx)', async () => {
76
+ const provider = new MockOrdinalsProvider();
77
+ const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
78
+ const asset = await sdk.lifecycle.createAsset([
79
+ { id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }
80
+ ]);
81
+ await asset.migrate('did:btco');
82
+ const tx = await sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
83
+ expect(typeof tx.txid).toBe('string');
84
+ });
85
+
86
+ test('transferOwnership errors if not on btco layer', async () => {
87
+ const sdk = OriginalsSDK.create({ network: 'regtest' });
88
+ // This one should pass given current guard
89
+ const asset = await (async () => {
90
+ try {
91
+ return await sdk.lifecycle.createAsset(resources);
92
+ } catch (e) {
93
+ // Fallback mock minimal object to hit the guard branch
94
+ return { currentLayer: 'did:webvh' } as any;
95
+ }
96
+ })();
97
+ await expect(
98
+ sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx')
99
+ ).rejects.toThrow('Asset must be inscribed on Bitcoin before transfer');
100
+ });
101
+ });
102
+
103
+ /** Inlined from LifecycleManager.btco.psbt.part.ts */
104
+ import { BroadcastClient } from '../../../src/bitcoin/BroadcastClient';
105
+ import { PSBTBuilder } from '../../../src/bitcoin/PSBTBuilder';
106
+
107
+ describe('Bitcoin inscription MVP - dry run', () => {
108
+ test('dry-run using mocked provider and broadcaster', async () => {
109
+ const provider = new MockOrdinalsProvider();
110
+ const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
111
+
112
+ // Inject mocked dependencies
113
+ const mockBroadcast = new BroadcastClient(async (_hex) => 'tx-dryrun', async (_txid) => ({ confirmed: true, confirmations: 1 }));
114
+ const mockPsbt = new PSBTBuilder();
115
+
116
+ // @ts-ignore access internals for test injection
117
+ sdk.lifecycle = new (sdk.lifecycle.constructor as any)(
118
+ (sdk as any).lifecycle['config'],
119
+ (sdk as any).lifecycle['didManager'],
120
+ (sdk as any).lifecycle['credentialManager'],
121
+ { broadcastClient: mockBroadcast, psbtBuilder: mockPsbt }
122
+ );
123
+
124
+ const asset = await sdk.lifecycle.createAsset([
125
+ { id: 'r1', type: 'text', contentType: 'text/plain', hash: 'aa' }
126
+ ]);
127
+
128
+ const before = asset.currentLayer;
129
+ const feeRate = 7;
130
+ const result = await sdk.lifecycle.inscribeOnBitcoin(asset, feeRate);
131
+
132
+ expect(result.currentLayer).toBe('did:btco');
133
+ const prov = (result as any).getProvenance();
134
+ const latest = prov.migrations[prov.migrations.length - 1];
135
+ expect(latest.feeRate).toBe(feeRate);
136
+ expect(latest.transactionId).toEqual(expect.any(String));
137
+ expect(before).toBe('did:peer');
138
+ });
139
+ });
140
+
141
+
142
+
143
+
144
+ /** Inlined from LifecycleManager.coverage-branches.part.ts */
145
+ import { LifecycleManager } from '../../../src/lifecycle/LifecycleManager';
146
+ import { DIDManager } from '../../../src/did/DIDManager';
147
+ import { CredentialManager } from '../../../src/vc/CredentialManager';
148
+
149
+ describe('LifecycleManager additional branch coverage', () => {
150
+ const lm = new LifecycleManager({ network: 'mainnet' } as any, new DIDManager({} as any), new CredentialManager({} as any));
151
+
152
+ test('publishToWeb throws when migrate not a function', async () => {
153
+ const asset: any = {
154
+ currentLayer: 'did:peer',
155
+ id: 'did:peer:test',
156
+ resources: [{ id: 'r1', type: 'data', contentType: 'text/plain', hash: 'deadbeef', content: 'test' }],
157
+ migrate: undefined // This should cause an error when called
158
+ };
159
+ await expect(lm.publishToWeb(asset, 'example.com')).rejects.toThrow();
160
+ });
161
+ });
162
+
163
+
164
+
165
+
166
+ /** Inlined from LifecycleManager.more.part.ts */
167
+
168
+ const dummyConfig: any = {};
169
+ const didManager = new DIDManager(dummyConfig as any);
170
+ const credentialManager = new CredentialManager(dummyConfig as any);
171
+ const lm = new LifecycleManager(dummyConfig as any, didManager, credentialManager);
172
+
173
+ describe('LifecycleManager additional branches', () => {
174
+ test('publishToWeb throws when currentLayer is not did:peer', async () => {
175
+ const asset: any = { currentLayer: 'did:webvh', migrate: async () => { } };
176
+ await expect(lm.publishToWeb(asset, 'example.com')).rejects.toThrow();
177
+ });
178
+
179
+ test('inscribeOnBitcoin throws for invalid layer', async () => {
180
+ const asset: any = { currentLayer: 'did:wrong', migrate: async () => { } };
181
+ await expect(lm.inscribeOnBitcoin(asset)).rejects.toThrow('Not implemented');
182
+ });
183
+ });
184
+
185
+
186
+
187
+
188
+ /** Inlined from LifecycleManager.no-feeRate.part.ts */
189
+
190
+ describe('LifecycleManager.inscribeOnBitcoin without explicit feeRate', () => {
191
+ test('uses provider.estimateFee when feeRate not provided', async () => {
192
+ const provider = new MockOrdinalsProvider();
193
+ const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
194
+ const asset = await sdk.lifecycle.createAsset([{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }]);
195
+ const result = await sdk.lifecycle.inscribeOnBitcoin(asset);
196
+ expect(result.currentLayer).toBe('did:btco');
197
+ const prov = (result as any).getProvenance();
198
+ const latest = prov.migrations[prov.migrations.length - 1];
199
+ expect(latest.feeRate as number).toBeGreaterThan(0);
200
+ })
201
+
202
+ test('transferOwnership uses provenance inscription data', async () => {
203
+ const provider = new MockOrdinalsProvider();
204
+ const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
205
+ const asset = await sdk.lifecycle.createAsset(resources);
206
+ await sdk.lifecycle.publishToWeb(asset, 'example.com');
207
+ await sdk.lifecycle.inscribeOnBitcoin(asset, 8);
208
+ const tx = await sdk.lifecycle.transferOwnership(asset, 'tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7');
209
+ expect(tx.txid).toBe('tx-transfer-mock');
210
+ const provenance = asset.getProvenance();
211
+ expect(provenance.transfers[provenance.transfers.length - 1].transactionId).toBe('tx-transfer-mock');
212
+ });
213
+ });
@@ -0,0 +1,30 @@
1
+ /* istanbul ignore file */
2
+ import { describe, test, expect } from 'bun:test';
3
+ import { OriginalsSDK, OriginalsAsset } from '../../../src';
4
+ import { MockOrdinalsProvider } from '../../mocks/adapters';
5
+
6
+ describe('LifecycleManager.transferOwnership unit edge cases', () => {
7
+ const provider = new MockOrdinalsProvider();
8
+ const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
9
+
10
+ test('throws if not on btco layer', async () => {
11
+ const asset = new OriginalsAsset(
12
+ [{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'h' }],
13
+ { '@context': ['https://www.w3.org/ns/did/v1'], id: 'did:webvh:domain:1' } as any,
14
+ []
15
+ );
16
+ await expect(sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx')).rejects.toThrow('Asset must be inscribed on Bitcoin before transfer');
17
+ });
18
+
19
+ test('succeeds and updates provenance when on btco', async () => {
20
+ const asset = new OriginalsAsset(
21
+ [{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'h' }],
22
+ { '@context': ['https://www.w3.org/ns/did/v1'], id: 'did:btco:42' } as any,
23
+ []
24
+ );
25
+ const tx = await sdk.lifecycle.transferOwnership(asset, 'tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7');
26
+ expect(typeof tx.txid).toBe('string');
27
+ expect(asset.getProvenance().transfers.length).toBe(1);
28
+ });
29
+ });
30
+