@originals/sdk 1.4.2 → 1.4.5

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