@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,435 +0,0 @@
1
- import { describe, test, expect, beforeEach, afterEach } from 'bun:test';
2
- import { WebVHManager } from '../../../src/did/WebVHManager';
3
- import * as fs from 'fs';
4
- import * as path from 'path';
5
- import * as os from 'os';
6
-
7
- describe('WebVHManager', () => {
8
- let manager: WebVHManager;
9
- let tempDir: string;
10
-
11
- beforeEach(async () => {
12
- manager = new WebVHManager();
13
- // Create a temporary directory for test outputs
14
- tempDir = await fs.promises.mkdtemp(path.join(os.tmpdir(), 'webvh-test-'));
15
- });
16
-
17
- afterEach(async () => {
18
- // Clean up temporary directory
19
- try {
20
- await fs.promises.rm(tempDir, { recursive: true, force: true });
21
- } catch (err) {
22
- // Ignore cleanup errors
23
- }
24
- });
25
-
26
- describe('createDIDWebVH', () => {
27
- test('creates a valid did:webvh DID with document and log', async () => {
28
- const result = await manager.createDIDWebVH({
29
- domain: 'example.com',
30
- outputDir: tempDir,
31
- });
32
-
33
- // Verify DID format (includes SCID hash before domain)
34
- expect(result.did).toMatch(/^did:webvh:[A-Za-z0-9]+:example\.com$/);
35
-
36
- // Verify DID document structure
37
- expect(result.didDocument).toBeDefined();
38
- expect(result.didDocument.id).toBe(result.did);
39
- expect(result.didDocument['@context']).toContain('https://www.w3.org/ns/did/v1');
40
- expect(result.didDocument['@context']).toContain('https://w3id.org/security/multikey/v1');
41
-
42
- // Verify verification methods
43
- expect(result.didDocument.verificationMethod).toBeDefined();
44
- expect(Array.isArray(result.didDocument.verificationMethod)).toBe(true);
45
- expect(result.didDocument.verificationMethod!.length).toBeGreaterThan(0);
46
-
47
- // Verify authentication and assertion methods
48
- expect(result.didDocument.authentication).toBeDefined();
49
- expect(result.didDocument.assertionMethod).toBeDefined();
50
-
51
- // Verify key pair
52
- expect(result.keyPair).toBeDefined();
53
- expect(result.keyPair.publicKey).toMatch(/^z/);
54
- expect(result.keyPair.privateKey).toMatch(/^z/);
55
-
56
- // Verify log
57
- expect(result.log).toBeDefined();
58
- expect(Array.isArray(result.log)).toBe(true);
59
- expect(result.log.length).toBeGreaterThan(0);
60
-
61
- // Verify first log entry
62
- const firstEntry = result.log[0];
63
- expect(firstEntry.versionId).toBeDefined();
64
- expect(firstEntry.versionTime).toBeDefined();
65
- expect(firstEntry.state).toBeDefined();
66
- expect(firstEntry.proof).toBeDefined();
67
-
68
- // Verify log path
69
- expect(result.logPath).toBeDefined();
70
- expect(result.logPath).toContain('did.jsonl');
71
- }, 10000);
72
-
73
- test('creates DID with custom paths', async () => {
74
- const result = await manager.createDIDWebVH({
75
- domain: 'example.com',
76
- paths: ['users', 'alice'],
77
- outputDir: tempDir,
78
- });
79
-
80
- expect(result.did).toMatch(/^did:webvh:[A-Za-z0-9]+:example\.com:users:alice$/);
81
- }, 10000);
82
-
83
- test('creates portable DID when specified', async () => {
84
- const result = await manager.createDIDWebVH({
85
- domain: 'example.com',
86
- portable: true,
87
- outputDir: tempDir,
88
- });
89
-
90
- expect(result.didDocument).toBeDefined();
91
- expect(result.log).toBeDefined();
92
- // Verify portable flag in log metadata
93
- const firstEntry = result.log[0];
94
- expect(firstEntry.parameters).toBeDefined();
95
- }, 10000);
96
-
97
- test('uses provided key pair when given', async () => {
98
- // First, generate a key pair
99
- const keyManager = new (await import('../../../src/did/KeyManager')).KeyManager();
100
- const customKeyPair = await keyManager.generateKeyPair('Ed25519');
101
-
102
- const result = await manager.createDIDWebVH({
103
- domain: 'example.com',
104
- keyPair: customKeyPair,
105
- outputDir: tempDir,
106
- });
107
-
108
- // Verify the same key pair is used
109
- expect(result.keyPair.publicKey).toBe(customKeyPair.publicKey);
110
- expect(result.keyPair.privateKey).toBe(customKeyPair.privateKey);
111
- }, 10000);
112
-
113
- test('creates DID without saving log when outputDir is not provided', async () => {
114
- const result = await manager.createDIDWebVH({
115
- domain: 'example.com',
116
- });
117
-
118
- expect(result.did).toBeDefined();
119
- expect(result.didDocument).toBeDefined();
120
- expect(result.log).toBeDefined();
121
- expect(result.logPath).toBeUndefined();
122
- }, 10000);
123
- });
124
-
125
- describe('saveDIDLog', () => {
126
- test('saves log to correct path for simple DID', async () => {
127
- const result = await manager.createDIDWebVH({
128
- domain: 'example.com',
129
- outputDir: tempDir,
130
- });
131
-
132
- expect(result.logPath).toBeDefined();
133
-
134
- // Verify file exists
135
- const fileExists = await fs.promises.access(result.logPath!)
136
- .then(() => true)
137
- .catch(() => false);
138
- expect(fileExists).toBe(true);
139
-
140
- // Verify file content
141
- const content = await fs.promises.readFile(result.logPath!, 'utf8');
142
- const lines = content.trim().split('\n');
143
- expect(lines.length).toBe(result.log.length);
144
-
145
- // Verify each line is valid JSON
146
- lines.forEach(line => {
147
- expect(() => JSON.parse(line)).not.toThrow();
148
- });
149
- }, 10000);
150
-
151
- test('saves log to correct path with nested paths', async () => {
152
- const result = await manager.createDIDWebVH({
153
- domain: 'example.com',
154
- paths: ['users', 'alice'],
155
- outputDir: tempDir,
156
- });
157
-
158
- expect(result.logPath).toBeDefined();
159
- expect(result.logPath).toContain(path.join('users', 'alice'));
160
-
161
- // Verify file exists
162
- const fileExists = await fs.promises.access(result.logPath!)
163
- .then(() => true)
164
- .catch(() => false);
165
- expect(fileExists).toBe(true);
166
- }, 10000);
167
-
168
- test('creates nested directories as needed', async () => {
169
- const deepPath = path.join(tempDir, 'deep', 'nested', 'structure');
170
-
171
- const result = await manager.createDIDWebVH({
172
- domain: 'example.com',
173
- paths: ['level1', 'level2'],
174
- outputDir: deepPath,
175
- });
176
-
177
- expect(result.logPath).toBeDefined();
178
-
179
- // Verify file exists in nested structure
180
- const fileExists = await fs.promises.access(result.logPath!)
181
- .then(() => true)
182
- .catch(() => false);
183
- expect(fileExists).toBe(true);
184
- }, 10000);
185
- });
186
-
187
- describe('loadDIDLog', () => {
188
- test('loads saved DID log correctly', async () => {
189
- // First create and save a DID
190
- const createResult = await manager.createDIDWebVH({
191
- domain: 'example.com',
192
- outputDir: tempDir,
193
- });
194
-
195
- expect(createResult.logPath).toBeDefined();
196
-
197
- // Load the log
198
- const loadedLog = await manager.loadDIDLog(createResult.logPath!);
199
-
200
- // Verify loaded log matches original
201
- expect(loadedLog.length).toBe(createResult.log.length);
202
- expect(loadedLog[0].versionId).toBe(createResult.log[0].versionId);
203
- expect(loadedLog[0].versionTime).toBe(createResult.log[0].versionTime);
204
- }, 10000);
205
- });
206
-
207
- describe('saveDIDLog error handling', () => {
208
- test('throws error for invalid DID format (missing parts)', async () => {
209
- const validLog = [{
210
- versionId: '1',
211
- versionTime: new Date().toISOString(),
212
- parameters: {},
213
- state: {}
214
- }];
215
-
216
- await expect(
217
- manager.saveDIDLog('invalid:did', validLog, tempDir)
218
- ).rejects.toThrow('Invalid did:webvh format');
219
- }, 10000);
220
-
221
- test('throws error for non-webvh DID', async () => {
222
- const validLog = [{
223
- versionId: '1',
224
- versionTime: new Date().toISOString(),
225
- parameters: {},
226
- state: {}
227
- }];
228
-
229
- await expect(
230
- manager.saveDIDLog('did:key:abc123', validLog, tempDir)
231
- ).rejects.toThrow('Invalid did:webvh format');
232
- }, 10000);
233
-
234
- test('saves DID without path parts correctly', async () => {
235
- const validLog = [{
236
- versionId: '1',
237
- versionTime: new Date().toISOString(),
238
- parameters: {},
239
- state: {}
240
- }];
241
-
242
- const logPath = await manager.saveDIDLog('did:webvh:example.com', validLog, tempDir);
243
-
244
- expect(logPath).toContain('did.jsonl');
245
- expect(logPath.startsWith(tempDir)).toBe(true);
246
-
247
- // Verify file exists
248
- const fileExists = await fs.promises.access(logPath)
249
- .then(() => true)
250
- .catch(() => false);
251
- expect(fileExists).toBe(true);
252
- }, 10000);
253
-
254
- test('handles URL-encoded domain correctly', async () => {
255
- const validLog = [{
256
- versionId: '1',
257
- versionTime: new Date().toISOString(),
258
- parameters: {},
259
- state: {}
260
- }];
261
-
262
- const logPath = await manager.saveDIDLog('did:webvh:localhost%3A5000:test', validLog, tempDir);
263
-
264
- expect(logPath).toBeDefined();
265
- expect(logPath.startsWith(tempDir)).toBe(true);
266
- }, 10000);
267
-
268
- test('rejects empty path segments', async () => {
269
- const validLog = [{
270
- versionId: '1',
271
- versionTime: new Date().toISOString(),
272
- parameters: {},
273
- state: {}
274
- }];
275
-
276
- await expect(
277
- manager.saveDIDLog('did:webvh:example.com::test', validLog, tempDir)
278
- ).rejects.toThrow('Invalid path segment in DID');
279
- }, 10000);
280
-
281
- test('throws error when resolved path escapes base directory', async () => {
282
- const validLog = [{
283
- versionId: '1',
284
- versionTime: new Date().toISOString(),
285
- parameters: {},
286
- state: {}
287
- }];
288
-
289
- // This should be caught by the validation, but testing defense in depth
290
- // Create a mock DID that would try to escape (though validation prevents it)
291
- await expect(
292
- manager.saveDIDLog('did:webvh:example.com:..', validLog, tempDir)
293
- ).rejects.toThrow();
294
- }, 10000);
295
- });
296
-
297
- describe('security: path traversal prevention', () => {
298
- test('rejects DIDs with ".." in path segments', async () => {
299
- await expect(
300
- manager.createDIDWebVH({
301
- domain: 'example.com',
302
- paths: ['..', 'etc', 'passwd'],
303
- outputDir: tempDir,
304
- })
305
- ).rejects.toThrow('Invalid path segment in DID');
306
- }, 10000);
307
-
308
- test('rejects DIDs with "." in path segments', async () => {
309
- await expect(
310
- manager.createDIDWebVH({
311
- domain: 'example.com',
312
- paths: ['.', 'secret'],
313
- outputDir: tempDir,
314
- })
315
- ).rejects.toThrow('Invalid path segment in DID');
316
- }, 10000);
317
-
318
- test('rejects DIDs with path separators in segments', async () => {
319
- await expect(
320
- manager.createDIDWebVH({
321
- domain: 'example.com',
322
- paths: ['users/../../etc', 'passwd'],
323
- outputDir: tempDir,
324
- })
325
- ).rejects.toThrow('Invalid path segment in DID');
326
- }, 10000);
327
-
328
- test('rejects DIDs with backslashes in path segments', async () => {
329
- await expect(
330
- manager.createDIDWebVH({
331
- domain: 'example.com',
332
- paths: ['users\\..\\..\\etc', 'passwd'],
333
- outputDir: tempDir,
334
- })
335
- ).rejects.toThrow('Invalid path segment in DID');
336
- }, 10000);
337
-
338
- test('rejects DIDs with null bytes in path segments', async () => {
339
- await expect(
340
- manager.createDIDWebVH({
341
- domain: 'example.com',
342
- paths: ['users\0etc', 'passwd'],
343
- outputDir: tempDir,
344
- })
345
- ).rejects.toThrow('Invalid path segment in DID');
346
- }, 10000);
347
-
348
- test('rejects DIDs with absolute paths (Unix)', async () => {
349
- await expect(
350
- manager.createDIDWebVH({
351
- domain: 'example.com',
352
- paths: ['/etc/passwd'],
353
- outputDir: tempDir,
354
- })
355
- ).rejects.toThrow('Invalid path segment in DID');
356
- }, 10000);
357
-
358
- test('rejects DIDs with absolute paths (Windows)', async () => {
359
- await expect(
360
- manager.createDIDWebVH({
361
- domain: 'example.com',
362
- paths: ['C:\\Windows\\System32'],
363
- outputDir: tempDir,
364
- })
365
- ).rejects.toThrow('Invalid path segment in DID');
366
- }, 10000);
367
-
368
- test('accepts valid alphanumeric path segments', async () => {
369
- const result = await manager.createDIDWebVH({
370
- domain: 'example.com',
371
- paths: ['users', 'alice123', 'profile'],
372
- outputDir: tempDir,
373
- });
374
-
375
- expect(result.did).toBeDefined();
376
- expect(result.logPath).toBeDefined();
377
-
378
- // Verify file was created in the correct location
379
- const fileExists = await fs.promises.access(result.logPath!)
380
- .then(() => true)
381
- .catch(() => false);
382
- expect(fileExists).toBe(true);
383
-
384
- // Verify path is within temp directory
385
- expect(result.logPath!.startsWith(tempDir)).toBe(true);
386
- }, 10000);
387
-
388
- test('accepts valid path segments with hyphens and underscores', async () => {
389
- const result = await manager.createDIDWebVH({
390
- domain: 'example.com',
391
- paths: ['my-org', 'user_name', 'test-123'],
392
- outputDir: tempDir,
393
- });
394
-
395
- expect(result.did).toBeDefined();
396
- expect(result.logPath).toBeDefined();
397
- expect(result.logPath!.startsWith(tempDir)).toBe(true);
398
- }, 10000);
399
- });
400
-
401
- describe('integration with didwebvh-ts', () => {
402
- test('creates cryptographically valid DID with proper proofs', async () => {
403
- const result = await manager.createDIDWebVH({
404
- domain: 'example.com',
405
- outputDir: tempDir,
406
- });
407
-
408
- // Verify proof exists and has required fields
409
- const firstEntry = result.log[0];
410
- expect(firstEntry.proof).toBeDefined();
411
- expect(Array.isArray(firstEntry.proof)).toBe(true);
412
- expect(firstEntry.proof!.length).toBeGreaterThan(0);
413
-
414
- const proof = firstEntry.proof![0];
415
- expect(proof.type).toBeDefined();
416
- expect(proof.cryptosuite).toBeDefined();
417
- expect(proof.verificationMethod).toBeDefined();
418
- expect(proof.created).toBeDefined();
419
- expect(proof.proofValue).toBeDefined();
420
- expect(proof.proofPurpose).toBeDefined();
421
- }, 10000);
422
-
423
- test('creates DID with proper SCID', async () => {
424
- const result = await manager.createDIDWebVH({
425
- domain: 'example.com',
426
- outputDir: tempDir,
427
- });
428
-
429
- const firstEntry = result.log[0];
430
- expect(firstEntry.parameters).toBeDefined();
431
- expect(firstEntry.parameters.scid).toBeDefined();
432
- expect(typeof firstEntry.parameters.scid).toBe('string');
433
- }, 10000);
434
- });
435
- });
@@ -1,67 +0,0 @@
1
- import { describe, test, expect, it } from 'bun:test';
2
- import { createBtcoDidDocument } from '../../../src/did/createBtcoDidDocument';
3
- import { multikey } from '../../../src/crypto/Multikey';
4
-
5
- function rangeBytes(len: number, start: number): Uint8Array {
6
- return new Uint8Array(len).map((_, i) => (start + i) & 0xff);
7
- }
8
-
9
- describe('createBtcoDidDocument', () => {
10
- it('creates document for mainnet with deterministic fragment and relationships', () => {
11
- const pub = rangeBytes(32, 1);
12
- const doc = createBtcoDidDocument('1066296127976657', 'mainnet', { publicKey: pub, keyType: 'Ed25519' });
13
- expect(doc['@context']).toEqual([
14
- 'https://www.w3.org/ns/did/v1',
15
- 'https://w3id.org/security/multikey/v1'
16
- ]);
17
- expect(doc.id).toBe('did:btco:1066296127976657');
18
- expect(doc.verificationMethod?.length).toBe(1);
19
- const vm = doc.verificationMethod![0];
20
- expect(vm.id).toBe('did:btco:1066296127976657#0');
21
- expect(vm.type).toBe('Multikey');
22
- expect(vm.controller).toBe(doc.id);
23
- expect(doc.authentication).toEqual([vm.id]);
24
- expect(doc.assertionMethod).toEqual([vm.id]);
25
- const decoded = multikey.decodePublicKey(vm.publicKeyMultibase);
26
- expect(decoded.type).toBe('Ed25519');
27
- expect(Array.from(decoded.key)).toEqual(Array.from(pub));
28
- });
29
-
30
- it('creates document for regtest with proper prefix', () => {
31
- const pub = rangeBytes(33, 3);
32
- const doc = createBtcoDidDocument(123456, 'regtest', { publicKey: pub, keyType: 'Secp256k1' });
33
- expect(doc.id).toBe('did:btco:reg:123456');
34
- const vm = doc.verificationMethod![0];
35
- expect(vm.id).toBe('did:btco:reg:123456#0');
36
- const decoded = multikey.decodePublicKey(vm.publicKeyMultibase);
37
- expect(decoded.type).toBe('Secp256k1');
38
- expect(Array.from(decoded.key)).toEqual(Array.from(pub));
39
- });
40
-
41
- it('creates document for signet with proper prefix', () => {
42
- const pub = rangeBytes(96, 5);
43
- const doc = createBtcoDidDocument(999, 'signet', { publicKey: pub, keyType: 'Bls12381G2' });
44
- expect(doc.id).toBe('did:btco:sig:999');
45
- const vm = doc.verificationMethod![0];
46
- expect(vm.id).toBe('did:btco:sig:999#0');
47
- const decoded = multikey.decodePublicKey(vm.publicKeyMultibase);
48
- expect(decoded.type).toBe('Bls12381G2');
49
- expect(Array.from(decoded.key)).toEqual(Array.from(pub));
50
- });
51
-
52
- it('supports overriding controller', () => {
53
- const pub = rangeBytes(32, 7);
54
- const controller = 'did:example:controller';
55
- const doc = createBtcoDidDocument('42', 'mainnet', { publicKey: pub, keyType: 'Ed25519', controller });
56
- expect(doc.verificationMethod![0].controller).toBe(controller);
57
- });
58
-
59
- it('throws on unsupported network', () => {
60
- const pub = rangeBytes(32, 9);
61
- expect(() =>
62
- // @ts-expect-error testing invalid network
63
- createBtcoDidDocument('1', 'testnet', { publicKey: pub, keyType: 'Ed25519' })
64
- ).toThrow('Unsupported Bitcoin network: testnet');
65
- });
66
- });
67
-
@@ -1,159 +0,0 @@
1
- import { describe, test, expect, beforeEach, afterEach, mock } from 'bun:test';
2
- import { OrdinalsClient } from '../../../../src/bitcoin/OrdinalsClient';
3
- import { OrdinalsClientProviderAdapter } from '../../../../src/did/providers/OrdinalsClientProviderAdapter';
4
-
5
- describe('OrdinalsClientProviderAdapter.resolveInscription', () => {
6
- const inscriptionId = 'insc123';
7
- const originalFetch = global.fetch as any;
8
-
9
- beforeEach(() => {
10
- // Bun doesn't require resetAllMocks
11
- });
12
-
13
- afterEach(() => {
14
- (global as any).fetch = originalFetch;
15
- });
16
-
17
- test('throws when baseUrl is missing/empty', async () => {
18
- const client = new OrdinalsClient('http://rpc', 'mainnet');
19
- const adapter = new OrdinalsClientProviderAdapter(client, '');
20
- await expect(adapter.resolveInscription(inscriptionId)).rejects.toThrow('OrdinalsClientProviderAdapter requires a baseUrl');
21
- });
22
-
23
- test('throws when inscription endpoint returns non-OK', async () => {
24
- const client = new OrdinalsClient('http://rpc', 'mainnet');
25
- const adapter = new OrdinalsClientProviderAdapter(client, 'https://api.example.com/');
26
-
27
- const fetchMock = mock(() => Promise.resolve({ ok: false, status: 500, json: async () => ({}) }));
28
- (globalThis as any).fetch = fetchMock;
29
-
30
- await expect(adapter.resolveInscription(inscriptionId)).rejects.toThrow(`Failed to resolve inscription: ${inscriptionId}`);
31
-
32
- expect(fetchMock).toHaveBeenCalledTimes(1);
33
- expect(fetchMock).toHaveBeenCalledWith(
34
- 'https://api.example.com/inscription/insc123',
35
- expect.objectContaining({
36
- headers: { Accept: 'application/json' },
37
- signal: expect.any(AbortSignal)
38
- })
39
- );
40
- });
41
-
42
- test('maps fields correctly when JSON has explicit values and numeric sat', async () => {
43
- const client = new OrdinalsClient('http://rpc', 'mainnet');
44
- const adapter = new OrdinalsClientProviderAdapter(client, 'https://ord.example');
45
-
46
- const apiResponse = {
47
- inscription_id: 'abc123',
48
- sat: 42,
49
- content_type: 'image/png',
50
- content_url: 'https://cdn.example/abc123.png'
51
- };
52
-
53
- const fetchMock = mock(() => Promise.resolve({ ok: true, json: async () => apiResponse }));
54
- (globalThis as any).fetch = fetchMock;
55
-
56
- const result = await adapter.resolveInscription(inscriptionId);
57
-
58
- expect(result).toEqual({
59
- id: 'abc123',
60
- sat: 42,
61
- content_type: 'image/png',
62
- content_url: 'https://cdn.example/abc123.png'
63
- });
64
-
65
- expect(fetchMock).toHaveBeenCalledTimes(1);
66
- expect(fetchMock).toHaveBeenCalledWith(
67
- 'https://ord.example/inscription/insc123',
68
- expect.objectContaining({
69
- headers: { Accept: 'application/json' },
70
- signal: expect.any(AbortSignal)
71
- })
72
- );
73
- });
74
-
75
- test('applies fallbacks and coerces string sat to number', async () => {
76
- const client = new OrdinalsClient('http://rpc', 'mainnet');
77
- const adapter = new OrdinalsClientProviderAdapter(client, 'https://api.example.com/');
78
-
79
- const apiResponse = {
80
- sat: '007'
81
- // missing inscription_id, content_type, content_url
82
- } as any;
83
-
84
- const fetchMock = mock(() => Promise.resolve({ ok: true, json: async () => apiResponse }));
85
- (globalThis as any).fetch = fetchMock;
86
-
87
- const result = await adapter.resolveInscription(inscriptionId);
88
-
89
- expect(result).toEqual({
90
- id: 'insc123',
91
- sat: 7,
92
- content_type: 'text/plain',
93
- content_url: 'https://api.example.com/content/insc123'
94
- });
95
-
96
- expect(fetchMock).toHaveBeenCalledTimes(1);
97
- expect(fetchMock).toHaveBeenCalledWith(
98
- 'https://api.example.com/inscription/insc123',
99
- expect.objectContaining({
100
- headers: { Accept: 'application/json' },
101
- signal: expect.any(AbortSignal)
102
- })
103
- );
104
- });
105
-
106
- test('applies default sat=0 when sat is missing', async () => {
107
- const client = new OrdinalsClient('http://rpc', 'mainnet');
108
- const adapter = new OrdinalsClientProviderAdapter(client, 'https://api.example.com/');
109
-
110
- const apiResponse = { } as any;
111
-
112
- const fetchMock = mock(() => Promise.resolve({ ok: true, json: async () => apiResponse }));
113
- (globalThis as any).fetch = fetchMock;
114
-
115
- const result = await adapter.resolveInscription(inscriptionId);
116
-
117
- expect(result).toEqual({
118
- id: 'insc123',
119
- sat: 0,
120
- content_type: 'text/plain',
121
- content_url: 'https://api.example.com/content/insc123'
122
- });
123
-
124
- expect(fetchMock).toHaveBeenCalledTimes(1);
125
- expect(fetchMock).toHaveBeenCalledWith(
126
- 'https://api.example.com/inscription/insc123',
127
- expect.objectContaining({
128
- headers: { Accept: 'application/json' },
129
- signal: expect.any(AbortSignal)
130
- })
131
- );
132
- });
133
-
134
- test('getSatInfo proxies to client.getSatInfo', async () => {
135
- const mockClient = {
136
- getSatInfo: mock(async (n: string) => ({ inscription_ids: ['a', 'b'] })),
137
- getMetadata: mock()
138
- } as unknown as OrdinalsClient;
139
-
140
- const adapter = new OrdinalsClientProviderAdapter(mockClient, 'https://x');
141
- const result = await adapter.getSatInfo('12345');
142
- expect(result).toEqual({ inscription_ids: ['a', 'b'] });
143
- expect((mockClient as any).getSatInfo).toHaveBeenCalledWith('12345');
144
- });
145
-
146
- test('getMetadata proxies to client.getMetadata', async () => {
147
- const expected = { hello: 'world' };
148
- const mockClient = {
149
- getSatInfo: mock(),
150
- getMetadata: mock(async (id: string) => expected)
151
- } as unknown as OrdinalsClient;
152
-
153
- const adapter = new OrdinalsClientProviderAdapter(mockClient, 'https://x');
154
- const result = await adapter.getMetadata('iid');
155
- expect(result).toBe(expected);
156
- expect((mockClient as any).getMetadata).toHaveBeenCalledWith('iid');
157
- });
158
- });
159
-