@originals/sdk 1.2.0 → 1.4.3

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 (401) hide show
  1. package/package.json +4 -1
  2. package/.eslintrc.json +0 -33
  3. package/.turbo/turbo-build.log +0 -1
  4. package/dist/adapters/FeeOracleMock.d.ts +0 -6
  5. package/dist/adapters/FeeOracleMock.js +0 -8
  6. package/dist/adapters/index.d.ts +0 -4
  7. package/dist/adapters/index.js +0 -4
  8. package/dist/adapters/providers/OrdHttpProvider.d.ts +0 -56
  9. package/dist/adapters/providers/OrdHttpProvider.js +0 -110
  10. package/dist/adapters/providers/OrdMockProvider.d.ts +0 -70
  11. package/dist/adapters/providers/OrdMockProvider.js +0 -75
  12. package/dist/adapters/types.d.ts +0 -71
  13. package/dist/adapters/types.js +0 -1
  14. package/dist/bitcoin/BitcoinManager.d.ts +0 -15
  15. package/dist/bitcoin/BitcoinManager.js +0 -262
  16. package/dist/bitcoin/BroadcastClient.d.ts +0 -30
  17. package/dist/bitcoin/BroadcastClient.js +0 -35
  18. package/dist/bitcoin/OrdinalsClient.d.ts +0 -21
  19. package/dist/bitcoin/OrdinalsClient.js +0 -105
  20. package/dist/bitcoin/PSBTBuilder.d.ts +0 -24
  21. package/dist/bitcoin/PSBTBuilder.js +0 -80
  22. package/dist/bitcoin/fee-calculation.d.ts +0 -14
  23. package/dist/bitcoin/fee-calculation.js +0 -31
  24. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +0 -38
  25. package/dist/bitcoin/providers/OrdNodeProvider.js +0 -67
  26. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +0 -33
  27. package/dist/bitcoin/providers/OrdinalsProvider.js +0 -50
  28. package/dist/bitcoin/providers/types.d.ts +0 -63
  29. package/dist/bitcoin/providers/types.js +0 -1
  30. package/dist/bitcoin/transactions/commit.d.ts +0 -89
  31. package/dist/bitcoin/transactions/commit.js +0 -311
  32. package/dist/bitcoin/transactions/index.d.ts +0 -7
  33. package/dist/bitcoin/transactions/index.js +0 -8
  34. package/dist/bitcoin/transfer.d.ts +0 -9
  35. package/dist/bitcoin/transfer.js +0 -26
  36. package/dist/bitcoin/utxo-selection.d.ts +0 -78
  37. package/dist/bitcoin/utxo-selection.js +0 -237
  38. package/dist/bitcoin/utxo.d.ts +0 -26
  39. package/dist/bitcoin/utxo.js +0 -78
  40. package/dist/contexts/credentials-v1.json +0 -195
  41. package/dist/contexts/credentials-v2-examples.json +0 -5
  42. package/dist/contexts/credentials-v2.json +0 -301
  43. package/dist/contexts/credentials.json +0 -195
  44. package/dist/contexts/data-integrity-v2.json +0 -81
  45. package/dist/contexts/dids.json +0 -57
  46. package/dist/contexts/ed255192020.json +0 -93
  47. package/dist/contexts/ordinals-plus.json +0 -23
  48. package/dist/contexts/originals.json +0 -22
  49. package/dist/core/OriginalsSDK.d.ts +0 -158
  50. package/dist/core/OriginalsSDK.js +0 -274
  51. package/dist/crypto/Multikey.d.ts +0 -30
  52. package/dist/crypto/Multikey.js +0 -149
  53. package/dist/crypto/Signer.d.ts +0 -21
  54. package/dist/crypto/Signer.js +0 -196
  55. package/dist/crypto/noble-init.d.ts +0 -18
  56. package/dist/crypto/noble-init.js +0 -106
  57. package/dist/did/BtcoDidResolver.d.ts +0 -57
  58. package/dist/did/BtcoDidResolver.js +0 -166
  59. package/dist/did/DIDManager.d.ts +0 -101
  60. package/dist/did/DIDManager.js +0 -493
  61. package/dist/did/Ed25519Verifier.d.ts +0 -30
  62. package/dist/did/Ed25519Verifier.js +0 -59
  63. package/dist/did/KeyManager.d.ts +0 -17
  64. package/dist/did/KeyManager.js +0 -207
  65. package/dist/did/WebVHManager.d.ts +0 -100
  66. package/dist/did/WebVHManager.js +0 -304
  67. package/dist/did/createBtcoDidDocument.d.ts +0 -10
  68. package/dist/did/createBtcoDidDocument.js +0 -42
  69. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +0 -23
  70. package/dist/did/providers/OrdinalsClientProviderAdapter.js +0 -51
  71. package/dist/events/EventEmitter.d.ts +0 -115
  72. package/dist/events/EventEmitter.js +0 -198
  73. package/dist/events/index.d.ts +0 -7
  74. package/dist/events/index.js +0 -6
  75. package/dist/events/types.d.ts +0 -286
  76. package/dist/events/types.js +0 -9
  77. package/dist/examples/basic-usage.d.ts +0 -3
  78. package/dist/examples/basic-usage.js +0 -62
  79. package/dist/examples/run.d.ts +0 -1
  80. package/dist/examples/run.js +0 -4
  81. package/dist/index.d.ts +0 -39
  82. package/dist/index.js +0 -47
  83. package/dist/lifecycle/BatchOperations.d.ts +0 -147
  84. package/dist/lifecycle/BatchOperations.js +0 -251
  85. package/dist/lifecycle/LifecycleManager.d.ts +0 -116
  86. package/dist/lifecycle/LifecycleManager.js +0 -971
  87. package/dist/lifecycle/OriginalsAsset.d.ts +0 -164
  88. package/dist/lifecycle/OriginalsAsset.js +0 -380
  89. package/dist/lifecycle/ProvenanceQuery.d.ts +0 -126
  90. package/dist/lifecycle/ProvenanceQuery.js +0 -220
  91. package/dist/lifecycle/ResourceVersioning.d.ts +0 -73
  92. package/dist/lifecycle/ResourceVersioning.js +0 -127
  93. package/dist/migration/MigrationManager.d.ts +0 -86
  94. package/dist/migration/MigrationManager.js +0 -412
  95. package/dist/migration/audit/AuditLogger.d.ts +0 -51
  96. package/dist/migration/audit/AuditLogger.js +0 -156
  97. package/dist/migration/checkpoint/CheckpointManager.d.ts +0 -31
  98. package/dist/migration/checkpoint/CheckpointManager.js +0 -96
  99. package/dist/migration/checkpoint/CheckpointStorage.d.ts +0 -26
  100. package/dist/migration/checkpoint/CheckpointStorage.js +0 -89
  101. package/dist/migration/index.d.ts +0 -22
  102. package/dist/migration/index.js +0 -27
  103. package/dist/migration/operations/BaseMigration.d.ts +0 -48
  104. package/dist/migration/operations/BaseMigration.js +0 -83
  105. package/dist/migration/operations/PeerToBtcoMigration.d.ts +0 -25
  106. package/dist/migration/operations/PeerToBtcoMigration.js +0 -67
  107. package/dist/migration/operations/PeerToWebvhMigration.d.ts +0 -19
  108. package/dist/migration/operations/PeerToWebvhMigration.js +0 -46
  109. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +0 -25
  110. package/dist/migration/operations/WebvhToBtcoMigration.js +0 -67
  111. package/dist/migration/rollback/RollbackManager.d.ts +0 -29
  112. package/dist/migration/rollback/RollbackManager.js +0 -146
  113. package/dist/migration/state/StateMachine.d.ts +0 -25
  114. package/dist/migration/state/StateMachine.js +0 -76
  115. package/dist/migration/state/StateTracker.d.ts +0 -36
  116. package/dist/migration/state/StateTracker.js +0 -123
  117. package/dist/migration/types.d.ts +0 -306
  118. package/dist/migration/types.js +0 -33
  119. package/dist/migration/validation/BitcoinValidator.d.ts +0 -13
  120. package/dist/migration/validation/BitcoinValidator.js +0 -83
  121. package/dist/migration/validation/CredentialValidator.d.ts +0 -13
  122. package/dist/migration/validation/CredentialValidator.js +0 -46
  123. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +0 -16
  124. package/dist/migration/validation/DIDCompatibilityValidator.js +0 -127
  125. package/dist/migration/validation/LifecycleValidator.d.ts +0 -10
  126. package/dist/migration/validation/LifecycleValidator.js +0 -52
  127. package/dist/migration/validation/StorageValidator.d.ts +0 -10
  128. package/dist/migration/validation/StorageValidator.js +0 -65
  129. package/dist/migration/validation/ValidationPipeline.d.ts +0 -29
  130. package/dist/migration/validation/ValidationPipeline.js +0 -180
  131. package/dist/storage/LocalStorageAdapter.d.ts +0 -11
  132. package/dist/storage/LocalStorageAdapter.js +0 -53
  133. package/dist/storage/MemoryStorageAdapter.d.ts +0 -6
  134. package/dist/storage/MemoryStorageAdapter.js +0 -21
  135. package/dist/storage/StorageAdapter.d.ts +0 -16
  136. package/dist/storage/StorageAdapter.js +0 -1
  137. package/dist/storage/index.d.ts +0 -2
  138. package/dist/storage/index.js +0 -2
  139. package/dist/types/bitcoin.d.ts +0 -84
  140. package/dist/types/bitcoin.js +0 -1
  141. package/dist/types/common.d.ts +0 -82
  142. package/dist/types/common.js +0 -1
  143. package/dist/types/credentials.d.ts +0 -75
  144. package/dist/types/credentials.js +0 -1
  145. package/dist/types/did.d.ts +0 -26
  146. package/dist/types/did.js +0 -1
  147. package/dist/types/index.d.ts +0 -5
  148. package/dist/types/index.js +0 -5
  149. package/dist/types/network.d.ts +0 -78
  150. package/dist/types/network.js +0 -145
  151. package/dist/utils/EventLogger.d.ts +0 -71
  152. package/dist/utils/EventLogger.js +0 -232
  153. package/dist/utils/Logger.d.ts +0 -106
  154. package/dist/utils/Logger.js +0 -257
  155. package/dist/utils/MetricsCollector.d.ts +0 -110
  156. package/dist/utils/MetricsCollector.js +0 -264
  157. package/dist/utils/bitcoin-address.d.ts +0 -38
  158. package/dist/utils/bitcoin-address.js +0 -113
  159. package/dist/utils/cbor.d.ts +0 -2
  160. package/dist/utils/cbor.js +0 -9
  161. package/dist/utils/encoding.d.ts +0 -37
  162. package/dist/utils/encoding.js +0 -120
  163. package/dist/utils/hash.d.ts +0 -1
  164. package/dist/utils/hash.js +0 -5
  165. package/dist/utils/retry.d.ts +0 -10
  166. package/dist/utils/retry.js +0 -35
  167. package/dist/utils/satoshi-validation.d.ts +0 -60
  168. package/dist/utils/satoshi-validation.js +0 -156
  169. package/dist/utils/serialization.d.ts +0 -14
  170. package/dist/utils/serialization.js +0 -76
  171. package/dist/utils/telemetry.d.ts +0 -17
  172. package/dist/utils/telemetry.js +0 -24
  173. package/dist/utils/validation.d.ts +0 -5
  174. package/dist/utils/validation.js +0 -98
  175. package/dist/vc/CredentialManager.d.ts +0 -22
  176. package/dist/vc/CredentialManager.js +0 -227
  177. package/dist/vc/Issuer.d.ts +0 -27
  178. package/dist/vc/Issuer.js +0 -70
  179. package/dist/vc/Verifier.d.ts +0 -16
  180. package/dist/vc/Verifier.js +0 -50
  181. package/dist/vc/cryptosuites/bbs.d.ts +0 -44
  182. package/dist/vc/cryptosuites/bbs.js +0 -213
  183. package/dist/vc/cryptosuites/bbsSimple.d.ts +0 -9
  184. package/dist/vc/cryptosuites/bbsSimple.js +0 -12
  185. package/dist/vc/cryptosuites/eddsa.d.ts +0 -30
  186. package/dist/vc/cryptosuites/eddsa.js +0 -81
  187. package/dist/vc/documentLoader.d.ts +0 -16
  188. package/dist/vc/documentLoader.js +0 -59
  189. package/dist/vc/proofs/data-integrity.d.ts +0 -21
  190. package/dist/vc/proofs/data-integrity.js +0 -15
  191. package/dist/vc/utils/jsonld.d.ts +0 -2
  192. package/dist/vc/utils/jsonld.js +0 -15
  193. package/src/adapters/FeeOracleMock.ts +0 -9
  194. package/src/adapters/index.ts +0 -5
  195. package/src/adapters/providers/OrdHttpProvider.ts +0 -126
  196. package/src/adapters/providers/OrdMockProvider.ts +0 -101
  197. package/src/adapters/types.ts +0 -66
  198. package/src/bitcoin/BitcoinManager.ts +0 -330
  199. package/src/bitcoin/BroadcastClient.ts +0 -54
  200. package/src/bitcoin/OrdinalsClient.ts +0 -119
  201. package/src/bitcoin/PSBTBuilder.ts +0 -106
  202. package/src/bitcoin/fee-calculation.ts +0 -38
  203. package/src/bitcoin/providers/OrdNodeProvider.ts +0 -92
  204. package/src/bitcoin/providers/OrdinalsProvider.ts +0 -56
  205. package/src/bitcoin/providers/types.ts +0 -59
  206. package/src/bitcoin/transactions/commit.ts +0 -465
  207. package/src/bitcoin/transactions/index.ts +0 -13
  208. package/src/bitcoin/transfer.ts +0 -43
  209. package/src/bitcoin/utxo-selection.ts +0 -322
  210. package/src/bitcoin/utxo.ts +0 -113
  211. package/src/contexts/credentials-v1.json +0 -237
  212. package/src/contexts/credentials-v2-examples.json +0 -5
  213. package/src/contexts/credentials-v2.json +0 -340
  214. package/src/contexts/credentials.json +0 -237
  215. package/src/contexts/data-integrity-v2.json +0 -81
  216. package/src/contexts/dids.json +0 -58
  217. package/src/contexts/ed255192020.json +0 -93
  218. package/src/contexts/ordinals-plus.json +0 -23
  219. package/src/contexts/originals.json +0 -22
  220. package/src/core/OriginalsSDK.ts +0 -416
  221. package/src/crypto/Multikey.ts +0 -194
  222. package/src/crypto/Signer.ts +0 -254
  223. package/src/crypto/noble-init.ts +0 -121
  224. package/src/did/BtcoDidResolver.ts +0 -227
  225. package/src/did/DIDManager.ts +0 -694
  226. package/src/did/Ed25519Verifier.ts +0 -68
  227. package/src/did/KeyManager.ts +0 -236
  228. package/src/did/WebVHManager.ts +0 -489
  229. package/src/did/createBtcoDidDocument.ts +0 -59
  230. package/src/did/providers/OrdinalsClientProviderAdapter.ts +0 -68
  231. package/src/events/EventEmitter.ts +0 -222
  232. package/src/events/index.ts +0 -19
  233. package/src/events/types.ts +0 -331
  234. package/src/examples/basic-usage.ts +0 -78
  235. package/src/examples/run.ts +0 -5
  236. package/src/index.ts +0 -84
  237. package/src/lifecycle/BatchOperations.ts +0 -373
  238. package/src/lifecycle/LifecycleManager.ts +0 -1218
  239. package/src/lifecycle/OriginalsAsset.ts +0 -524
  240. package/src/lifecycle/ProvenanceQuery.ts +0 -280
  241. package/src/lifecycle/ResourceVersioning.ts +0 -163
  242. package/src/migration/MigrationManager.ts +0 -527
  243. package/src/migration/audit/AuditLogger.ts +0 -176
  244. package/src/migration/checkpoint/CheckpointManager.ts +0 -112
  245. package/src/migration/checkpoint/CheckpointStorage.ts +0 -101
  246. package/src/migration/index.ts +0 -33
  247. package/src/migration/operations/BaseMigration.ts +0 -126
  248. package/src/migration/operations/PeerToBtcoMigration.ts +0 -105
  249. package/src/migration/operations/PeerToWebvhMigration.ts +0 -62
  250. package/src/migration/operations/WebvhToBtcoMigration.ts +0 -105
  251. package/src/migration/rollback/RollbackManager.ts +0 -170
  252. package/src/migration/state/StateMachine.ts +0 -92
  253. package/src/migration/state/StateTracker.ts +0 -156
  254. package/src/migration/types.ts +0 -344
  255. package/src/migration/validation/BitcoinValidator.ts +0 -107
  256. package/src/migration/validation/CredentialValidator.ts +0 -62
  257. package/src/migration/validation/DIDCompatibilityValidator.ts +0 -151
  258. package/src/migration/validation/LifecycleValidator.ts +0 -64
  259. package/src/migration/validation/StorageValidator.ts +0 -79
  260. package/src/migration/validation/ValidationPipeline.ts +0 -213
  261. package/src/storage/LocalStorageAdapter.ts +0 -61
  262. package/src/storage/MemoryStorageAdapter.ts +0 -29
  263. package/src/storage/StorageAdapter.ts +0 -25
  264. package/src/storage/index.ts +0 -3
  265. package/src/types/bitcoin.ts +0 -98
  266. package/src/types/common.ts +0 -92
  267. package/src/types/credentials.ts +0 -88
  268. package/src/types/did.ts +0 -31
  269. package/src/types/external-shims.d.ts +0 -53
  270. package/src/types/index.ts +0 -7
  271. package/src/types/network.ts +0 -175
  272. package/src/utils/EventLogger.ts +0 -298
  273. package/src/utils/Logger.ts +0 -322
  274. package/src/utils/MetricsCollector.ts +0 -358
  275. package/src/utils/bitcoin-address.ts +0 -130
  276. package/src/utils/cbor.ts +0 -12
  277. package/src/utils/encoding.ts +0 -127
  278. package/src/utils/hash.ts +0 -6
  279. package/src/utils/retry.ts +0 -46
  280. package/src/utils/satoshi-validation.ts +0 -196
  281. package/src/utils/serialization.ts +0 -96
  282. package/src/utils/telemetry.ts +0 -40
  283. package/src/utils/validation.ts +0 -119
  284. package/src/vc/CredentialManager.ts +0 -273
  285. package/src/vc/Issuer.ts +0 -100
  286. package/src/vc/Verifier.ts +0 -47
  287. package/src/vc/cryptosuites/bbs.ts +0 -253
  288. package/src/vc/cryptosuites/bbsSimple.ts +0 -21
  289. package/src/vc/cryptosuites/eddsa.ts +0 -99
  290. package/src/vc/documentLoader.ts +0 -67
  291. package/src/vc/proofs/data-integrity.ts +0 -33
  292. package/src/vc/utils/jsonld.ts +0 -18
  293. package/test/logs/did_webvh_QmNTn9Kkp8dQ75WrF9xqJ2kuDp9QhKc3aPiERRMj8XoTBN_example_com.jsonl +0 -1
  294. package/test/logs/did_webvh_QmNu4MNr8Lr5txx5gYNhuhZDchXsZEu3hJXKYuphpWTPDp_example_com_users_etc_passwd.jsonl +0 -1
  295. package/test/logs/did_webvh_QmR9MrGZACzjKETA8SBRNCKG11HxU85c4bVR2qN5eDCfsD_example_com.jsonl +0 -1
  296. package/test/logs/did_webvh_QmUc5suaqRM2P4nrXxZwqYMfqzhdMqjuL7oJaJbEpCQVCd_example_com_users_etc_passwd.jsonl +0 -1
  297. package/test/logs/did_webvh_QmUkiB2RCV2VZ1RTXsCebWN25Eiy9TLvpzDWAJNjhgvB4X_example_com_etc_passwd.jsonl +0 -1
  298. package/test/logs/did_webvh_QmUoRTe8UMwpAQXZSAW7pjAgZK1tq2X3C6Kfxq3UXGcaGy_example_com_secret.jsonl +0 -1
  299. package/test/logs/did_webvh_QmWWot3chx1t6KwTmcE5i2FeDZ5JMkQw3qXycsKDVmJ9Be_example_com_users_alice.jsonl +0 -1
  300. package/test/logs/did_webvh_QmWvVgALL5kjZdpgR7KZay7J8UiiUr834kkRmWeFAxjAuC_example_com_users_etc_passwd.jsonl +0 -1
  301. package/test/logs/did_webvh_QmWwaRQHUZAFcKihFC6xR6tRTTrQhHPTku6azf1egWbpy1_example_com_users_alice.jsonl +0 -1
  302. package/test/logs/did_webvh_QmXJLtkz23r7AozbtXsZMKWnVU6rd38CkVtjdWuATU3Yp6_example_com_users_alice123_profile.jsonl +0 -1
  303. package/test/logs/did_webvh_QmYsce448po14oDE1wXbyaP6wY9HQgHSKLwdezn1k577SF_example_com_my_org_user_name_test_123.jsonl +0 -1
  304. package/test/logs/did_webvh_QmZBeNzzqajxdfwcDUPZ4P8C5YSXyRztrAwmPiKuKUxmAK_example_com.jsonl +0 -1
  305. package/test/logs/did_webvh_QmZhJsqxizwVbRtqCUkmE6XQunSxtxMt3gbTYadVBNAaEq_example_com.jsonl +0 -1
  306. package/test/logs/did_webvh_QmZk7NHU2D57RzzbMq4tWW9gBa9AqtVTWfiRM6RFdwGVj2_example_com.jsonl +0 -1
  307. package/test/logs/did_webvh_QmZshSXp9w8ovH62zGGBS1b5pGGPsuYiu1VQ935sga2hWF_example_com_level1_level2.jsonl +0 -1
  308. package/test/logs/did_webvh_QmbWAmw7HQL7vKJyCsctZihXf1rmT4sGvggKCPKWcUWjw1_example_com.jsonl +0 -1
  309. package/test/logs/did_webvh_QmbdLUMbYs3juR39TLB6hhrFWLcNg45ybUzeBJCS1MhCh1_example_com_C_Windows_System32.jsonl +0 -1
  310. package/test/logs/did_webvh_QmcaQ1Ma4gkSbae85aCm8Mv4rvdT2Sb2RR3JzYwrm5XBq8_example_com_etc_passwd.jsonl +0 -1
  311. package/test/logs/did_webvh_QmcbA7WQhsBqZSoDpKJHjV8Q5o53h8vmgJhQfo6rqTY5ho_example_com.jsonl +0 -1
  312. package/test/logs/did_webvh_Qmdy8uWr2gkUJrXsThynAug3DASTWwb3onEj89LKmMGZYB_example_com.jsonl +0 -1
  313. package/tests/__mocks__/bbs-signatures.js +0 -17
  314. package/tests/__mocks__/mf-base58.js +0 -24
  315. package/tests/e2e/README.md +0 -97
  316. package/tests/e2e/example.spec.ts +0 -78
  317. package/tests/fixtures/did-documents.ts +0 -247
  318. package/tests/index.test.ts +0 -21
  319. package/tests/integration/BatchOperations.test.ts +0 -531
  320. package/tests/integration/CompleteLifecycle.e2e.test.ts +0 -735
  321. package/tests/integration/CredentialManager.test.ts +0 -42
  322. package/tests/integration/DIDManager.test.ts +0 -41
  323. package/tests/integration/DidPeerToWebVhFlow.test.ts +0 -351
  324. package/tests/integration/Events.test.ts +0 -435
  325. package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +0 -25
  326. package/tests/integration/LifecycleManager.test.ts +0 -21
  327. package/tests/integration/MultikeyFlow.test.ts +0 -52
  328. package/tests/integration/TelemetryIntegration.test.ts +0 -395
  329. package/tests/integration/WebVhPublish.test.ts +0 -48
  330. package/tests/integration/migration/peer-to-webvh.test.ts +0 -172
  331. package/tests/manual/test-commit-creation.ts +0 -323
  332. package/tests/mocks/MockKeyStore.ts +0 -38
  333. package/tests/mocks/adapters/MemoryStorageAdapter.ts +0 -24
  334. package/tests/mocks/adapters/MockFeeOracle.ts +0 -11
  335. package/tests/mocks/adapters/MockOrdinalsProvider.ts +0 -76
  336. package/tests/mocks/adapters/OrdMockProvider.test.ts +0 -176
  337. package/tests/mocks/adapters/index.ts +0 -6
  338. package/tests/performance/BatchOperations.perf.test.ts +0 -403
  339. package/tests/performance/logging.perf.test.ts +0 -336
  340. package/tests/sdk.test.ts +0 -43
  341. package/tests/security/bitcoin-penetration-tests.test.ts +0 -622
  342. package/tests/setup.bun.ts +0 -69
  343. package/tests/setup.jest.ts +0 -23
  344. package/tests/stress/batch-operations-stress.test.ts +0 -571
  345. package/tests/unit/adapters/FeeOracleMock.test.ts +0 -40
  346. package/tests/unit/bitcoin/BitcoinManager.test.ts +0 -293
  347. package/tests/unit/bitcoin/BroadcastClient.test.ts +0 -52
  348. package/tests/unit/bitcoin/OrdNodeProvider.test.ts +0 -53
  349. package/tests/unit/bitcoin/OrdinalsClient.test.ts +0 -381
  350. package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +0 -102
  351. package/tests/unit/bitcoin/PSBTBuilder.test.ts +0 -84
  352. package/tests/unit/bitcoin/fee-calculation.test.ts +0 -261
  353. package/tests/unit/bitcoin/transactions/commit.test.ts +0 -649
  354. package/tests/unit/bitcoin/transfer.test.ts +0 -31
  355. package/tests/unit/bitcoin/utxo-selection-new.test.ts +0 -502
  356. package/tests/unit/bitcoin/utxo.more.test.ts +0 -39
  357. package/tests/unit/bitcoin/utxo.selection.test.ts +0 -38
  358. package/tests/unit/core/OriginalsSDK.test.ts +0 -152
  359. package/tests/unit/crypto/Multikey.test.ts +0 -206
  360. package/tests/unit/crypto/Signer.test.ts +0 -408
  361. package/tests/unit/did/BtcoDidResolver.test.ts +0 -611
  362. package/tests/unit/did/DIDManager.more.test.ts +0 -43
  363. package/tests/unit/did/DIDManager.test.ts +0 -185
  364. package/tests/unit/did/Ed25519Verifier.test.ts +0 -160
  365. package/tests/unit/did/KeyManager.test.ts +0 -452
  366. package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +0 -45
  367. package/tests/unit/did/WebVHManager.test.ts +0 -435
  368. package/tests/unit/did/createBtcoDidDocument.test.ts +0 -67
  369. package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +0 -159
  370. package/tests/unit/events/EventEmitter.test.ts +0 -407
  371. package/tests/unit/lifecycle/BatchOperations.test.ts +0 -527
  372. package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +0 -312
  373. package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +0 -18
  374. package/tests/unit/lifecycle/LifecycleManager.test.ts +0 -213
  375. package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +0 -30
  376. package/tests/unit/lifecycle/OriginalsAsset.test.ts +0 -176
  377. package/tests/unit/lifecycle/ProvenanceQuery.test.ts +0 -577
  378. package/tests/unit/lifecycle/ResourceVersioning.test.ts +0 -651
  379. package/tests/unit/storage/MemoryStorageAdapter.test.ts +0 -93
  380. package/tests/unit/types/network.test.ts +0 -255
  381. package/tests/unit/utils/EventIntegration.test.ts +0 -384
  382. package/tests/unit/utils/Logger.test.ts +0 -473
  383. package/tests/unit/utils/MetricsCollector.test.ts +0 -358
  384. package/tests/unit/utils/bitcoin-address.test.ts +0 -250
  385. package/tests/unit/utils/cbor.test.ts +0 -35
  386. package/tests/unit/utils/encoding.test.ts +0 -318
  387. package/tests/unit/utils/hash.test.ts +0 -12
  388. package/tests/unit/utils/retry.test.ts +0 -100
  389. package/tests/unit/utils/satoshi-validation.test.ts +0 -354
  390. package/tests/unit/utils/serialization.test.ts +0 -124
  391. package/tests/unit/utils/telemetry.test.ts +0 -52
  392. package/tests/unit/utils/validation.test.ts +0 -141
  393. package/tests/unit/vc/CredentialManager.test.ts +0 -487
  394. package/tests/unit/vc/Issuer.test.ts +0 -107
  395. package/tests/unit/vc/Verifier.test.ts +0 -525
  396. package/tests/unit/vc/bbs.test.ts +0 -282
  397. package/tests/unit/vc/cryptosuites/eddsa.test.ts +0 -398
  398. package/tests/unit/vc/documentLoader.test.ts +0 -121
  399. package/tests/unit/vc/proofs/data-integrity.test.ts +0 -24
  400. package/tsconfig.json +0 -31
  401. package/tsconfig.test.json +0 -15
@@ -1,312 +0,0 @@
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
- });
@@ -1,18 +0,0 @@
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
- });
@@ -1,213 +0,0 @@
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
- });
@@ -1,30 +0,0 @@
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
-