@originals/sdk 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (403) hide show
  1. package/.eslintrc.json +33 -0
  2. package/.turbo/turbo-build.log +1 -0
  3. package/.turbo/turbo-test.log +68353 -0
  4. package/dist/adapters/FeeOracleMock.d.ts +6 -0
  5. package/dist/adapters/FeeOracleMock.js +8 -0
  6. package/dist/adapters/index.d.ts +4 -0
  7. package/dist/adapters/index.js +4 -0
  8. package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
  9. package/dist/adapters/providers/OrdHttpProvider.js +110 -0
  10. package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
  11. package/dist/adapters/providers/OrdMockProvider.js +75 -0
  12. package/dist/adapters/types.d.ts +71 -0
  13. package/dist/adapters/types.js +1 -0
  14. package/dist/bitcoin/BitcoinManager.d.ts +15 -0
  15. package/dist/bitcoin/BitcoinManager.js +262 -0
  16. package/dist/bitcoin/BroadcastClient.d.ts +30 -0
  17. package/dist/bitcoin/BroadcastClient.js +35 -0
  18. package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
  19. package/dist/bitcoin/OrdinalsClient.js +105 -0
  20. package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
  21. package/dist/bitcoin/PSBTBuilder.js +80 -0
  22. package/dist/bitcoin/fee-calculation.d.ts +14 -0
  23. package/dist/bitcoin/fee-calculation.js +31 -0
  24. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
  25. package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
  26. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
  27. package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
  28. package/dist/bitcoin/providers/types.d.ts +63 -0
  29. package/dist/bitcoin/providers/types.js +1 -0
  30. package/dist/bitcoin/transactions/commit.d.ts +89 -0
  31. package/dist/bitcoin/transactions/commit.js +311 -0
  32. package/dist/bitcoin/transactions/index.d.ts +7 -0
  33. package/dist/bitcoin/transactions/index.js +8 -0
  34. package/dist/bitcoin/transfer.d.ts +9 -0
  35. package/dist/bitcoin/transfer.js +26 -0
  36. package/dist/bitcoin/utxo-selection.d.ts +78 -0
  37. package/dist/bitcoin/utxo-selection.js +237 -0
  38. package/dist/bitcoin/utxo.d.ts +26 -0
  39. package/dist/bitcoin/utxo.js +78 -0
  40. package/dist/contexts/credentials-v1.json +195 -0
  41. package/dist/contexts/credentials-v2-examples.json +5 -0
  42. package/dist/contexts/credentials-v2.json +301 -0
  43. package/dist/contexts/credentials.json +195 -0
  44. package/dist/contexts/data-integrity-v2.json +81 -0
  45. package/dist/contexts/dids.json +57 -0
  46. package/dist/contexts/ed255192020.json +93 -0
  47. package/dist/contexts/ordinals-plus.json +23 -0
  48. package/dist/contexts/originals.json +22 -0
  49. package/dist/core/OriginalsSDK.d.ts +158 -0
  50. package/dist/core/OriginalsSDK.js +274 -0
  51. package/dist/crypto/Multikey.d.ts +30 -0
  52. package/dist/crypto/Multikey.js +149 -0
  53. package/dist/crypto/Signer.d.ts +21 -0
  54. package/dist/crypto/Signer.js +196 -0
  55. package/dist/crypto/noble-init.d.ts +18 -0
  56. package/dist/crypto/noble-init.js +106 -0
  57. package/dist/did/BtcoDidResolver.d.ts +57 -0
  58. package/dist/did/BtcoDidResolver.js +166 -0
  59. package/dist/did/DIDManager.d.ts +101 -0
  60. package/dist/did/DIDManager.js +493 -0
  61. package/dist/did/Ed25519Verifier.d.ts +30 -0
  62. package/dist/did/Ed25519Verifier.js +59 -0
  63. package/dist/did/KeyManager.d.ts +17 -0
  64. package/dist/did/KeyManager.js +207 -0
  65. package/dist/did/WebVHManager.d.ts +100 -0
  66. package/dist/did/WebVHManager.js +304 -0
  67. package/dist/did/createBtcoDidDocument.d.ts +10 -0
  68. package/dist/did/createBtcoDidDocument.js +42 -0
  69. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
  70. package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
  71. package/dist/events/EventEmitter.d.ts +115 -0
  72. package/dist/events/EventEmitter.js +198 -0
  73. package/dist/events/index.d.ts +7 -0
  74. package/dist/events/index.js +6 -0
  75. package/dist/events/types.d.ts +286 -0
  76. package/dist/events/types.js +9 -0
  77. package/dist/examples/basic-usage.d.ts +3 -0
  78. package/dist/examples/basic-usage.js +62 -0
  79. package/dist/examples/run.d.ts +1 -0
  80. package/dist/examples/run.js +4 -0
  81. package/dist/index.d.ts +39 -0
  82. package/dist/index.js +47 -0
  83. package/dist/lifecycle/BatchOperations.d.ts +147 -0
  84. package/dist/lifecycle/BatchOperations.js +251 -0
  85. package/dist/lifecycle/LifecycleManager.d.ts +116 -0
  86. package/dist/lifecycle/LifecycleManager.js +971 -0
  87. package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
  88. package/dist/lifecycle/OriginalsAsset.js +380 -0
  89. package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
  90. package/dist/lifecycle/ProvenanceQuery.js +220 -0
  91. package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
  92. package/dist/lifecycle/ResourceVersioning.js +127 -0
  93. package/dist/migration/MigrationManager.d.ts +86 -0
  94. package/dist/migration/MigrationManager.js +412 -0
  95. package/dist/migration/audit/AuditLogger.d.ts +51 -0
  96. package/dist/migration/audit/AuditLogger.js +156 -0
  97. package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
  98. package/dist/migration/checkpoint/CheckpointManager.js +96 -0
  99. package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
  100. package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
  101. package/dist/migration/index.d.ts +22 -0
  102. package/dist/migration/index.js +27 -0
  103. package/dist/migration/operations/BaseMigration.d.ts +48 -0
  104. package/dist/migration/operations/BaseMigration.js +83 -0
  105. package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
  106. package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
  107. package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
  108. package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
  109. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
  110. package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
  111. package/dist/migration/rollback/RollbackManager.d.ts +29 -0
  112. package/dist/migration/rollback/RollbackManager.js +146 -0
  113. package/dist/migration/state/StateMachine.d.ts +25 -0
  114. package/dist/migration/state/StateMachine.js +76 -0
  115. package/dist/migration/state/StateTracker.d.ts +36 -0
  116. package/dist/migration/state/StateTracker.js +123 -0
  117. package/dist/migration/types.d.ts +306 -0
  118. package/dist/migration/types.js +33 -0
  119. package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
  120. package/dist/migration/validation/BitcoinValidator.js +83 -0
  121. package/dist/migration/validation/CredentialValidator.d.ts +13 -0
  122. package/dist/migration/validation/CredentialValidator.js +46 -0
  123. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
  124. package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
  125. package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
  126. package/dist/migration/validation/LifecycleValidator.js +52 -0
  127. package/dist/migration/validation/StorageValidator.d.ts +10 -0
  128. package/dist/migration/validation/StorageValidator.js +65 -0
  129. package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
  130. package/dist/migration/validation/ValidationPipeline.js +180 -0
  131. package/dist/storage/LocalStorageAdapter.d.ts +11 -0
  132. package/dist/storage/LocalStorageAdapter.js +53 -0
  133. package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
  134. package/dist/storage/MemoryStorageAdapter.js +21 -0
  135. package/dist/storage/StorageAdapter.d.ts +16 -0
  136. package/dist/storage/StorageAdapter.js +1 -0
  137. package/dist/storage/index.d.ts +2 -0
  138. package/dist/storage/index.js +2 -0
  139. package/dist/types/bitcoin.d.ts +84 -0
  140. package/dist/types/bitcoin.js +1 -0
  141. package/dist/types/common.d.ts +82 -0
  142. package/dist/types/common.js +1 -0
  143. package/dist/types/credentials.d.ts +75 -0
  144. package/dist/types/credentials.js +1 -0
  145. package/dist/types/did.d.ts +26 -0
  146. package/dist/types/did.js +1 -0
  147. package/dist/types/index.d.ts +5 -0
  148. package/dist/types/index.js +5 -0
  149. package/dist/types/network.d.ts +78 -0
  150. package/dist/types/network.js +145 -0
  151. package/dist/utils/EventLogger.d.ts +71 -0
  152. package/dist/utils/EventLogger.js +232 -0
  153. package/dist/utils/Logger.d.ts +106 -0
  154. package/dist/utils/Logger.js +257 -0
  155. package/dist/utils/MetricsCollector.d.ts +110 -0
  156. package/dist/utils/MetricsCollector.js +264 -0
  157. package/dist/utils/bitcoin-address.d.ts +38 -0
  158. package/dist/utils/bitcoin-address.js +113 -0
  159. package/dist/utils/cbor.d.ts +2 -0
  160. package/dist/utils/cbor.js +9 -0
  161. package/dist/utils/encoding.d.ts +37 -0
  162. package/dist/utils/encoding.js +120 -0
  163. package/dist/utils/hash.d.ts +1 -0
  164. package/dist/utils/hash.js +5 -0
  165. package/dist/utils/retry.d.ts +10 -0
  166. package/dist/utils/retry.js +35 -0
  167. package/dist/utils/satoshi-validation.d.ts +60 -0
  168. package/dist/utils/satoshi-validation.js +156 -0
  169. package/dist/utils/serialization.d.ts +14 -0
  170. package/dist/utils/serialization.js +76 -0
  171. package/dist/utils/telemetry.d.ts +17 -0
  172. package/dist/utils/telemetry.js +24 -0
  173. package/dist/utils/validation.d.ts +5 -0
  174. package/dist/utils/validation.js +98 -0
  175. package/dist/vc/CredentialManager.d.ts +22 -0
  176. package/dist/vc/CredentialManager.js +227 -0
  177. package/dist/vc/Issuer.d.ts +27 -0
  178. package/dist/vc/Issuer.js +70 -0
  179. package/dist/vc/Verifier.d.ts +16 -0
  180. package/dist/vc/Verifier.js +50 -0
  181. package/dist/vc/cryptosuites/bbs.d.ts +44 -0
  182. package/dist/vc/cryptosuites/bbs.js +213 -0
  183. package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
  184. package/dist/vc/cryptosuites/bbsSimple.js +12 -0
  185. package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
  186. package/dist/vc/cryptosuites/eddsa.js +81 -0
  187. package/dist/vc/documentLoader.d.ts +16 -0
  188. package/dist/vc/documentLoader.js +59 -0
  189. package/dist/vc/proofs/data-integrity.d.ts +21 -0
  190. package/dist/vc/proofs/data-integrity.js +15 -0
  191. package/dist/vc/utils/jsonld.d.ts +2 -0
  192. package/dist/vc/utils/jsonld.js +15 -0
  193. package/package.json +79 -0
  194. package/src/adapters/FeeOracleMock.ts +9 -0
  195. package/src/adapters/index.ts +5 -0
  196. package/src/adapters/providers/OrdHttpProvider.ts +126 -0
  197. package/src/adapters/providers/OrdMockProvider.ts +101 -0
  198. package/src/adapters/types.ts +66 -0
  199. package/src/bitcoin/BitcoinManager.ts +330 -0
  200. package/src/bitcoin/BroadcastClient.ts +54 -0
  201. package/src/bitcoin/OrdinalsClient.ts +119 -0
  202. package/src/bitcoin/PSBTBuilder.ts +106 -0
  203. package/src/bitcoin/fee-calculation.ts +38 -0
  204. package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
  205. package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
  206. package/src/bitcoin/providers/types.ts +59 -0
  207. package/src/bitcoin/transactions/commit.ts +465 -0
  208. package/src/bitcoin/transactions/index.ts +13 -0
  209. package/src/bitcoin/transfer.ts +43 -0
  210. package/src/bitcoin/utxo-selection.ts +322 -0
  211. package/src/bitcoin/utxo.ts +113 -0
  212. package/src/contexts/credentials-v1.json +237 -0
  213. package/src/contexts/credentials-v2-examples.json +5 -0
  214. package/src/contexts/credentials-v2.json +340 -0
  215. package/src/contexts/credentials.json +237 -0
  216. package/src/contexts/data-integrity-v2.json +81 -0
  217. package/src/contexts/dids.json +58 -0
  218. package/src/contexts/ed255192020.json +93 -0
  219. package/src/contexts/ordinals-plus.json +23 -0
  220. package/src/contexts/originals.json +22 -0
  221. package/src/core/OriginalsSDK.ts +416 -0
  222. package/src/crypto/Multikey.ts +194 -0
  223. package/src/crypto/Signer.ts +254 -0
  224. package/src/crypto/noble-init.ts +121 -0
  225. package/src/did/BtcoDidResolver.ts +227 -0
  226. package/src/did/DIDManager.ts +694 -0
  227. package/src/did/Ed25519Verifier.ts +68 -0
  228. package/src/did/KeyManager.ts +236 -0
  229. package/src/did/WebVHManager.ts +489 -0
  230. package/src/did/createBtcoDidDocument.ts +59 -0
  231. package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
  232. package/src/events/EventEmitter.ts +222 -0
  233. package/src/events/index.ts +19 -0
  234. package/src/events/types.ts +331 -0
  235. package/src/examples/basic-usage.ts +78 -0
  236. package/src/examples/run.ts +5 -0
  237. package/src/index.ts +84 -0
  238. package/src/lifecycle/BatchOperations.ts +373 -0
  239. package/src/lifecycle/LifecycleManager.ts +1218 -0
  240. package/src/lifecycle/OriginalsAsset.ts +524 -0
  241. package/src/lifecycle/ProvenanceQuery.ts +280 -0
  242. package/src/lifecycle/ResourceVersioning.ts +163 -0
  243. package/src/migration/MigrationManager.ts +527 -0
  244. package/src/migration/audit/AuditLogger.ts +176 -0
  245. package/src/migration/checkpoint/CheckpointManager.ts +112 -0
  246. package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
  247. package/src/migration/index.ts +33 -0
  248. package/src/migration/operations/BaseMigration.ts +126 -0
  249. package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
  250. package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
  251. package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
  252. package/src/migration/rollback/RollbackManager.ts +170 -0
  253. package/src/migration/state/StateMachine.ts +92 -0
  254. package/src/migration/state/StateTracker.ts +156 -0
  255. package/src/migration/types.ts +344 -0
  256. package/src/migration/validation/BitcoinValidator.ts +107 -0
  257. package/src/migration/validation/CredentialValidator.ts +62 -0
  258. package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
  259. package/src/migration/validation/LifecycleValidator.ts +64 -0
  260. package/src/migration/validation/StorageValidator.ts +79 -0
  261. package/src/migration/validation/ValidationPipeline.ts +213 -0
  262. package/src/storage/LocalStorageAdapter.ts +61 -0
  263. package/src/storage/MemoryStorageAdapter.ts +29 -0
  264. package/src/storage/StorageAdapter.ts +25 -0
  265. package/src/storage/index.ts +3 -0
  266. package/src/types/bitcoin.ts +98 -0
  267. package/src/types/common.ts +92 -0
  268. package/src/types/credentials.ts +88 -0
  269. package/src/types/did.ts +31 -0
  270. package/src/types/external-shims.d.ts +53 -0
  271. package/src/types/index.ts +7 -0
  272. package/src/types/network.ts +175 -0
  273. package/src/utils/EventLogger.ts +298 -0
  274. package/src/utils/Logger.ts +322 -0
  275. package/src/utils/MetricsCollector.ts +358 -0
  276. package/src/utils/bitcoin-address.ts +130 -0
  277. package/src/utils/cbor.ts +12 -0
  278. package/src/utils/encoding.ts +127 -0
  279. package/src/utils/hash.ts +6 -0
  280. package/src/utils/retry.ts +46 -0
  281. package/src/utils/satoshi-validation.ts +196 -0
  282. package/src/utils/serialization.ts +96 -0
  283. package/src/utils/telemetry.ts +40 -0
  284. package/src/utils/validation.ts +119 -0
  285. package/src/vc/CredentialManager.ts +273 -0
  286. package/src/vc/Issuer.ts +100 -0
  287. package/src/vc/Verifier.ts +47 -0
  288. package/src/vc/cryptosuites/bbs.ts +253 -0
  289. package/src/vc/cryptosuites/bbsSimple.ts +21 -0
  290. package/src/vc/cryptosuites/eddsa.ts +99 -0
  291. package/src/vc/documentLoader.ts +67 -0
  292. package/src/vc/proofs/data-integrity.ts +33 -0
  293. package/src/vc/utils/jsonld.ts +18 -0
  294. package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +1 -0
  295. package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +1 -0
  296. package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +1 -0
  297. package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +1 -0
  298. package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +1 -0
  299. package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +1 -0
  300. package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +1 -0
  301. package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +1 -0
  302. package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +1 -0
  303. package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +1 -0
  304. package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +1 -0
  305. package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +1 -0
  306. package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +1 -0
  307. package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +1 -0
  308. package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +1 -0
  309. package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +1 -0
  310. package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +1 -0
  311. package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +1 -0
  312. package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +1 -0
  313. package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +1 -0
  314. package/tests/__mocks__/bbs-signatures.js +17 -0
  315. package/tests/__mocks__/mf-base58.js +24 -0
  316. package/tests/e2e/README.md +97 -0
  317. package/tests/e2e/example.spec.ts +78 -0
  318. package/tests/fixtures/did-documents.ts +247 -0
  319. package/tests/index.test.ts +21 -0
  320. package/tests/integration/BatchOperations.test.ts +531 -0
  321. package/tests/integration/CompleteLifecycle.e2e.test.ts +735 -0
  322. package/tests/integration/CredentialManager.test.ts +42 -0
  323. package/tests/integration/DIDManager.test.ts +41 -0
  324. package/tests/integration/DidPeerToWebVhFlow.test.ts +351 -0
  325. package/tests/integration/Events.test.ts +435 -0
  326. package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +25 -0
  327. package/tests/integration/LifecycleManager.test.ts +21 -0
  328. package/tests/integration/MultikeyFlow.test.ts +52 -0
  329. package/tests/integration/TelemetryIntegration.test.ts +395 -0
  330. package/tests/integration/WebVhPublish.test.ts +48 -0
  331. package/tests/integration/migration/peer-to-webvh.test.ts +172 -0
  332. package/tests/manual/test-commit-creation.ts +323 -0
  333. package/tests/mocks/MockKeyStore.ts +38 -0
  334. package/tests/mocks/adapters/MemoryStorageAdapter.ts +24 -0
  335. package/tests/mocks/adapters/MockFeeOracle.ts +11 -0
  336. package/tests/mocks/adapters/MockOrdinalsProvider.ts +76 -0
  337. package/tests/mocks/adapters/OrdMockProvider.test.ts +176 -0
  338. package/tests/mocks/adapters/index.ts +6 -0
  339. package/tests/performance/BatchOperations.perf.test.ts +403 -0
  340. package/tests/performance/logging.perf.test.ts +336 -0
  341. package/tests/sdk.test.ts +43 -0
  342. package/tests/security/bitcoin-penetration-tests.test.ts +622 -0
  343. package/tests/setup.bun.ts +69 -0
  344. package/tests/setup.jest.ts +23 -0
  345. package/tests/stress/batch-operations-stress.test.ts +571 -0
  346. package/tests/unit/adapters/FeeOracleMock.test.ts +40 -0
  347. package/tests/unit/bitcoin/BitcoinManager.test.ts +293 -0
  348. package/tests/unit/bitcoin/BroadcastClient.test.ts +52 -0
  349. package/tests/unit/bitcoin/OrdNodeProvider.test.ts +53 -0
  350. package/tests/unit/bitcoin/OrdinalsClient.test.ts +381 -0
  351. package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +102 -0
  352. package/tests/unit/bitcoin/PSBTBuilder.test.ts +84 -0
  353. package/tests/unit/bitcoin/fee-calculation.test.ts +261 -0
  354. package/tests/unit/bitcoin/transactions/commit.test.ts +649 -0
  355. package/tests/unit/bitcoin/transfer.test.ts +31 -0
  356. package/tests/unit/bitcoin/utxo-selection-new.test.ts +502 -0
  357. package/tests/unit/bitcoin/utxo.more.test.ts +39 -0
  358. package/tests/unit/bitcoin/utxo.selection.test.ts +38 -0
  359. package/tests/unit/core/OriginalsSDK.test.ts +152 -0
  360. package/tests/unit/crypto/Multikey.test.ts +206 -0
  361. package/tests/unit/crypto/Signer.test.ts +408 -0
  362. package/tests/unit/did/BtcoDidResolver.test.ts +611 -0
  363. package/tests/unit/did/DIDManager.more.test.ts +43 -0
  364. package/tests/unit/did/DIDManager.test.ts +185 -0
  365. package/tests/unit/did/Ed25519Verifier.test.ts +160 -0
  366. package/tests/unit/did/KeyManager.test.ts +452 -0
  367. package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +45 -0
  368. package/tests/unit/did/WebVHManager.test.ts +435 -0
  369. package/tests/unit/did/createBtcoDidDocument.test.ts +67 -0
  370. package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +159 -0
  371. package/tests/unit/events/EventEmitter.test.ts +407 -0
  372. package/tests/unit/lifecycle/BatchOperations.test.ts +527 -0
  373. package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +312 -0
  374. package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +18 -0
  375. package/tests/unit/lifecycle/LifecycleManager.test.ts +213 -0
  376. package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +30 -0
  377. package/tests/unit/lifecycle/OriginalsAsset.test.ts +176 -0
  378. package/tests/unit/lifecycle/ProvenanceQuery.test.ts +577 -0
  379. package/tests/unit/lifecycle/ResourceVersioning.test.ts +651 -0
  380. package/tests/unit/storage/MemoryStorageAdapter.test.ts +93 -0
  381. package/tests/unit/types/network.test.ts +255 -0
  382. package/tests/unit/utils/EventIntegration.test.ts +384 -0
  383. package/tests/unit/utils/Logger.test.ts +473 -0
  384. package/tests/unit/utils/MetricsCollector.test.ts +358 -0
  385. package/tests/unit/utils/bitcoin-address.test.ts +250 -0
  386. package/tests/unit/utils/cbor.test.ts +35 -0
  387. package/tests/unit/utils/encoding.test.ts +318 -0
  388. package/tests/unit/utils/hash.test.ts +12 -0
  389. package/tests/unit/utils/retry.test.ts +100 -0
  390. package/tests/unit/utils/satoshi-validation.test.ts +354 -0
  391. package/tests/unit/utils/serialization.test.ts +124 -0
  392. package/tests/unit/utils/telemetry.test.ts +52 -0
  393. package/tests/unit/utils/validation.test.ts +141 -0
  394. package/tests/unit/vc/CredentialManager.test.ts +487 -0
  395. package/tests/unit/vc/Issuer.test.ts +107 -0
  396. package/tests/unit/vc/Verifier.test.ts +525 -0
  397. package/tests/unit/vc/bbs.test.ts +282 -0
  398. package/tests/unit/vc/cryptosuites/eddsa.test.ts +398 -0
  399. package/tests/unit/vc/documentLoader.test.ts +121 -0
  400. package/tests/unit/vc/proofs/data-integrity.test.ts +24 -0
  401. package/tsconfig.json +32 -0
  402. package/tsconfig.test.json +15 -0
  403. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,524 @@
1
+ import {
2
+ AssetResource,
3
+ DIDDocument,
4
+ VerifiableCredential,
5
+ LayerType
6
+ } from '../types';
7
+ import { validateDIDDocument, validateCredential, hashResource } from '../utils/validation';
8
+ import { CredentialManager } from '../vc/CredentialManager';
9
+ import { DIDManager } from '../did/DIDManager';
10
+ import { ProvenanceQuery, Migration, Transfer } from './ProvenanceQuery';
11
+ import { EventEmitter } from '../events/EventEmitter';
12
+ import type { EventHandler, EventTypeMap } from '../events/types';
13
+ import { ResourceVersionManager, ResourceHistory } from './ResourceVersioning';
14
+
15
+ export interface ProvenanceChain {
16
+ createdAt: string;
17
+ creator: string;
18
+ txid?: string;
19
+ migrations: Array<{
20
+ from: LayerType;
21
+ to: LayerType;
22
+ timestamp: string;
23
+ transactionId?: string;
24
+ inscriptionId?: string;
25
+ satoshi?: string;
26
+ commitTxId?: string;
27
+ revealTxId?: string;
28
+ feeRate?: number;
29
+ }>;
30
+ transfers: Array<{
31
+ from: string;
32
+ to: string;
33
+ timestamp: string;
34
+ transactionId: string;
35
+ }>;
36
+ resourceUpdates: Array<{
37
+ resourceId: string;
38
+ fromVersion: number;
39
+ toVersion: number;
40
+ fromHash: string;
41
+ toHash: string;
42
+ timestamp: string;
43
+ changes?: string;
44
+ }>;
45
+ }
46
+
47
+ export class OriginalsAsset {
48
+ public readonly id: string;
49
+ public readonly resources: AssetResource[];
50
+ public readonly did: DIDDocument;
51
+ public readonly credentials: VerifiableCredential[];
52
+ public currentLayer: LayerType;
53
+ public bindings?: Record<string, string>;
54
+ private provenance: ProvenanceChain;
55
+ private eventEmitter: EventEmitter;
56
+ private versionManager: ResourceVersionManager;
57
+
58
+ constructor(
59
+ resources: AssetResource[],
60
+ did: DIDDocument,
61
+ credentials: VerifiableCredential[]
62
+ ) {
63
+ this.id = did.id;
64
+ this.resources = resources;
65
+ this.did = did;
66
+ this.credentials = credentials;
67
+ this.currentLayer = this.determineCurrentLayer(did.id);
68
+ this.provenance = {
69
+ createdAt: new Date().toISOString(),
70
+ creator: did.id,
71
+ migrations: [],
72
+ transfers: [],
73
+ resourceUpdates: []
74
+ };
75
+ this.eventEmitter = new EventEmitter();
76
+ this.versionManager = new ResourceVersionManager();
77
+
78
+ // Initialize version manager with existing resources
79
+ // Group resources by ID and sort each group by version to handle unsorted persisted data
80
+ const resourcesByIdMap = new Map<string, AssetResource[]>();
81
+ for (const resource of resources) {
82
+ const existing = resourcesByIdMap.get(resource.id) || [];
83
+ existing.push(resource);
84
+ resourcesByIdMap.set(resource.id, existing);
85
+ }
86
+
87
+ // Process each resource ID's versions in sorted order
88
+ for (const [resourceId, resourceVersions] of resourcesByIdMap.entries()) {
89
+ // Sort by version number (ascending)
90
+ const sorted = resourceVersions.sort((a, b) => {
91
+ const versionA = a.version || 1;
92
+ const versionB = b.version || 1;
93
+ return versionA - versionB;
94
+ });
95
+
96
+ // Add versions in correct order to version manager
97
+ for (const resource of sorted) {
98
+ this.versionManager.addVersion(
99
+ resource.id,
100
+ resource.hash,
101
+ resource.contentType,
102
+ resource.previousVersionHash
103
+ );
104
+ }
105
+ }
106
+ }
107
+
108
+ async migrate(
109
+ toLayer: LayerType,
110
+ details?: {
111
+ transactionId?: string;
112
+ inscriptionId?: string;
113
+ satoshi?: string;
114
+ commitTxId?: string;
115
+ revealTxId?: string;
116
+ feeRate?: number;
117
+ }
118
+ ): Promise<void> {
119
+ // Handle migration between layers
120
+ const validTransitions: Record<LayerType, LayerType[]> = {
121
+ 'did:peer': ['did:webvh', 'did:btco'],
122
+ 'did:webvh': ['did:btco'],
123
+ 'did:btco': [] // No further migrations possible
124
+ };
125
+
126
+ if (!validTransitions[this.currentLayer].includes(toLayer)) {
127
+ throw new Error(`Invalid migration from ${this.currentLayer} to ${toLayer}`);
128
+ }
129
+
130
+ const fromLayer = this.currentLayer;
131
+
132
+ this.provenance.migrations.push({
133
+ from: fromLayer,
134
+ to: toLayer,
135
+ timestamp: new Date().toISOString(),
136
+ transactionId: details?.transactionId,
137
+ inscriptionId: details?.inscriptionId,
138
+ satoshi: details?.satoshi,
139
+ commitTxId: details?.commitTxId,
140
+ revealTxId: details?.revealTxId,
141
+ feeRate: details?.feeRate
142
+ });
143
+ if (details?.transactionId) {
144
+ this.provenance.txid = details.transactionId;
145
+ }
146
+ this.currentLayer = toLayer;
147
+
148
+ // Emit migration event and await handlers
149
+ await this.eventEmitter.emit({
150
+ type: 'asset:migrated',
151
+ timestamp: new Date().toISOString(),
152
+ asset: {
153
+ id: this.id,
154
+ fromLayer,
155
+ toLayer
156
+ },
157
+ details
158
+ });
159
+ }
160
+
161
+ getProvenance(): ProvenanceChain {
162
+ return this.provenance;
163
+ }
164
+
165
+ async recordTransfer(from: string, to: string, transactionId: string): Promise<void> {
166
+ this.provenance.transfers.push({
167
+ from,
168
+ to,
169
+ timestamp: new Date().toISOString(),
170
+ transactionId
171
+ });
172
+ this.provenance.txid = transactionId;
173
+
174
+ // Emit transfer event and await handlers
175
+ await this.eventEmitter.emit({
176
+ type: 'asset:transferred',
177
+ timestamp: new Date().toISOString(),
178
+ asset: {
179
+ id: this.id,
180
+ layer: this.currentLayer
181
+ },
182
+ from,
183
+ to,
184
+ transactionId
185
+ });
186
+ }
187
+
188
+ /**
189
+ * Query provenance with fluent API
190
+ */
191
+ queryProvenance(): ProvenanceQuery {
192
+ return new ProvenanceQuery(this.provenance);
193
+ }
194
+
195
+ /**
196
+ * Get all migrations to a specific layer
197
+ */
198
+ getMigrationsToLayer(layer: LayerType): Migration[] {
199
+ return this.provenance.migrations.filter(m => m.to === layer);
200
+ }
201
+
202
+ /**
203
+ * Get all transfers from an address
204
+ */
205
+ getTransfersFrom(address: string): Transfer[] {
206
+ return this.provenance.transfers.filter(t => t.from === address);
207
+ }
208
+
209
+ /**
210
+ * Get all transfers to an address
211
+ */
212
+ getTransfersTo(address: string): Transfer[] {
213
+ return this.provenance.transfers.filter(t => t.to === address);
214
+ }
215
+
216
+ /**
217
+ * Get provenance summary
218
+ */
219
+ getProvenanceSummary(): {
220
+ created: string;
221
+ creator: string;
222
+ currentLayer: LayerType;
223
+ migrationCount: number;
224
+ transferCount: number;
225
+ lastActivity: string;
226
+ } {
227
+ const lastMigration = this.provenance.migrations[this.provenance.migrations.length - 1];
228
+ const lastTransfer = this.provenance.transfers[this.provenance.transfers.length - 1];
229
+
230
+ return {
231
+ created: this.provenance.createdAt,
232
+ creator: this.id,
233
+ currentLayer: this.currentLayer,
234
+ migrationCount: this.provenance.migrations.length,
235
+ transferCount: this.provenance.transfers.length,
236
+ lastActivity: lastTransfer?.timestamp || lastMigration?.timestamp || this.provenance.createdAt
237
+ };
238
+ }
239
+
240
+ /**
241
+ * Find migration or transfer by transaction ID
242
+ */
243
+ findByTransactionId(txId: string): Migration | Transfer | null {
244
+ const migration = this.provenance.migrations.find(m => m.transactionId === txId);
245
+ if (migration) return migration;
246
+
247
+ const transfer = this.provenance.transfers.find(t => t.transactionId === txId);
248
+ return transfer || null;
249
+ }
250
+
251
+ /**
252
+ * Find migration by inscription ID
253
+ */
254
+ findByInscriptionId(inscriptionId: string): Migration | null {
255
+ return this.provenance.migrations.find(m => m.inscriptionId === inscriptionId) || null;
256
+ }
257
+
258
+ async verify(deps?: {
259
+ didManager?: DIDManager;
260
+ credentialManager?: CredentialManager;
261
+ fetch?: (url: string) => Promise<{ arrayBuffer: () => Promise<ArrayBuffer> }>;
262
+ }): Promise<boolean> {
263
+ try {
264
+ // 1) DID Document validation (structure + supported method via validateDID)
265
+ if (!validateDIDDocument(this.did)) {
266
+ return false;
267
+ }
268
+
269
+ // 2) Resources integrity
270
+ for (const res of this.resources) {
271
+ if (!res || typeof res.id !== 'string' || typeof res.type !== 'string' || typeof res.contentType !== 'string') {
272
+ return false;
273
+ }
274
+ if (typeof res.hash !== 'string' || !/[0-9a-f]+/i.test(res.hash)) {
275
+ return false;
276
+ }
277
+
278
+ // If inline content is present, verify by hashing it
279
+ if (typeof res.content === 'string') {
280
+ const data = Buffer.from(res.content, 'utf8');
281
+ const computed = hashResource(data);
282
+ const expected = (res.hash || '').toLowerCase();
283
+ if (computed.toLowerCase() !== expected) {
284
+ return false;
285
+ }
286
+ continue;
287
+ }
288
+
289
+ // If URL present and fetch is provided, attempt to fetch and hash
290
+ if (typeof res.url === 'string' && deps?.fetch) {
291
+ try {
292
+ const response = await deps.fetch(res.url);
293
+ const buf = Buffer.from(await response.arrayBuffer());
294
+ const computed = hashResource(buf);
295
+ const expected = (res.hash || '').toLowerCase();
296
+ if (computed.toLowerCase() !== expected) {
297
+ return false;
298
+ }
299
+ } catch {
300
+ // On fetch error, treat as unverifiable but do not fail the entire asset
301
+ // Fall back to structural validation only
302
+ }
303
+ }
304
+ }
305
+
306
+ // 3) Credentials validation
307
+ for (const cred of this.credentials) {
308
+ if (!validateCredential(cred)) {
309
+ return false;
310
+ }
311
+ }
312
+
313
+ // If a credentialManager with didManager is provided, verify each credential cryptographically
314
+ if (deps?.credentialManager && deps.credentialManager instanceof CredentialManager && deps?.didManager) {
315
+ for (const cred of this.credentials) {
316
+ const ok = await deps.credentialManager.verifyCredential(cred);
317
+ if (!ok) return false;
318
+ }
319
+ }
320
+
321
+ return true;
322
+ } catch {
323
+ return false;
324
+ }
325
+ }
326
+
327
+ /**
328
+ * Subscribe to an event
329
+ *
330
+ * @param eventType - The type of event to listen for
331
+ * @param handler - The handler function to call when the event is emitted
332
+ * @returns A function to unsubscribe the handler
333
+ */
334
+ on<K extends keyof EventTypeMap>(
335
+ eventType: K,
336
+ handler: EventHandler<EventTypeMap[K]>
337
+ ): () => void {
338
+ return this.eventEmitter.on(eventType, handler);
339
+ }
340
+
341
+ /**
342
+ * Subscribe to an event for a single emission
343
+ *
344
+ * @param eventType - The type of event to listen for
345
+ * @param handler - The handler function to call when the event is emitted (only once)
346
+ * @returns A function to unsubscribe the handler
347
+ */
348
+ once<K extends keyof EventTypeMap>(
349
+ eventType: K,
350
+ handler: EventHandler<EventTypeMap[K]>
351
+ ): () => void {
352
+ return this.eventEmitter.once(eventType, handler);
353
+ }
354
+
355
+ /**
356
+ * Unsubscribe from an event
357
+ *
358
+ * @param eventType - The type of event to stop listening for
359
+ * @param handler - The handler function to remove
360
+ */
361
+ off<K extends keyof EventTypeMap>(
362
+ eventType: K,
363
+ handler: EventHandler<EventTypeMap[K]>
364
+ ): void {
365
+ this.eventEmitter.off(eventType, handler);
366
+ }
367
+
368
+ /**
369
+ * Internal method for LifecycleManager to emit events
370
+ * This allows type-safe event emission without exposing the internal EventEmitter
371
+ *
372
+ * @internal
373
+ * @param event - The event to emit
374
+ */
375
+ _internalEmit<K extends keyof EventTypeMap>(event: EventTypeMap[K]): Promise<void> {
376
+ return this.eventEmitter.emit(event);
377
+ }
378
+
379
+ /**
380
+ * Add a new version of a resource (immutable versioning).
381
+ * Creates a new AssetResource with incremented version number and links it to the previous version.
382
+ *
383
+ * @param resourceId - The logical resource ID
384
+ * @param newContent - The new content (string or Buffer)
385
+ * @param contentType - The content type
386
+ * @param changes - Optional description of changes
387
+ * @returns The newly created AssetResource
388
+ * @throws Error if content is unchanged or resource not found
389
+ */
390
+ addResourceVersion(
391
+ resourceId: string,
392
+ newContent: string | Buffer,
393
+ contentType: string,
394
+ changes?: string
395
+ ): AssetResource {
396
+ // Find the current version of the resource by id
397
+ const currentResources = this.resources.filter(r => r.id === resourceId);
398
+ if (currentResources.length === 0) {
399
+ throw new Error(`Resource with id ${resourceId} not found`);
400
+ }
401
+
402
+ // Get the latest version
403
+ const currentResource = currentResources.sort((a, b) => {
404
+ const versionA = a.version || 1;
405
+ const versionB = b.version || 1;
406
+ return versionB - versionA;
407
+ })[0];
408
+
409
+ // Compute new hash
410
+ const contentBuffer = typeof newContent === 'string'
411
+ ? Buffer.from(newContent, 'utf-8')
412
+ : newContent;
413
+ const newHash = hashResource(contentBuffer);
414
+
415
+ // Check if content has actually changed
416
+ if (newHash === currentResource.hash) {
417
+ throw new Error('Content unchanged - new version would be identical to current version');
418
+ }
419
+
420
+ // Create new resource version
421
+ const newVersion = (currentResource.version || 1) + 1;
422
+ const newResource: AssetResource = {
423
+ id: resourceId,
424
+ type: currentResource.type,
425
+ content: typeof newContent === 'string' ? newContent : undefined,
426
+ contentType,
427
+ hash: newHash,
428
+ size: contentBuffer.length,
429
+ version: newVersion,
430
+ previousVersionHash: currentResource.hash,
431
+ createdAt: new Date().toISOString()
432
+ };
433
+
434
+ // Add to resources array (immutable - don't modify old resource)
435
+ (this.resources as AssetResource[]).push(newResource);
436
+
437
+ // Track in version manager
438
+ this.versionManager.addVersion(
439
+ resourceId,
440
+ newHash,
441
+ contentType,
442
+ currentResource.hash,
443
+ changes
444
+ );
445
+
446
+ // Update provenance
447
+ const timestamp = new Date().toISOString();
448
+ this.provenance.resourceUpdates.push({
449
+ resourceId,
450
+ fromVersion: currentResource.version || 1,
451
+ toVersion: newVersion,
452
+ fromHash: currentResource.hash,
453
+ toHash: newHash,
454
+ timestamp,
455
+ changes
456
+ });
457
+
458
+ // Emit version-created event
459
+ const event = {
460
+ type: 'resource:version:created' as const,
461
+ timestamp,
462
+ asset: {
463
+ id: this.id
464
+ },
465
+ resource: {
466
+ id: resourceId,
467
+ fromVersion: currentResource.version || 1,
468
+ toVersion: newVersion,
469
+ fromHash: currentResource.hash,
470
+ toHash: newHash
471
+ },
472
+ changes
473
+ };
474
+
475
+ // Emit asynchronously (don't block)
476
+ queueMicrotask(() => {
477
+ this.eventEmitter.emit(event);
478
+ });
479
+
480
+ return newResource;
481
+ }
482
+
483
+ /**
484
+ * Get a specific version of a resource
485
+ * @param resourceId - The logical resource ID
486
+ * @param version - The version number (1-indexed)
487
+ * @returns The AssetResource for that version, or null if not found
488
+ */
489
+ getResourceVersion(resourceId: string, version: number): AssetResource | null {
490
+ const resource = this.resources.find(r =>
491
+ r.id === resourceId && (r.version || 1) === version
492
+ );
493
+ return resource || null;
494
+ }
495
+
496
+ /**
497
+ * Get all versions of a resource
498
+ * @param resourceId - The logical resource ID
499
+ * @returns Array of all AssetResource versions, sorted by version number
500
+ */
501
+ getAllVersions(resourceId: string): AssetResource[] {
502
+ return this.resources
503
+ .filter(r => r.id === resourceId)
504
+ .sort((a, b) => (a.version || 1) - (b.version || 1));
505
+ }
506
+
507
+ /**
508
+ * Get the version history for a resource
509
+ * @param resourceId - The logical resource ID
510
+ * @returns ResourceHistory or null if resource not found
511
+ */
512
+ getResourceHistory(resourceId: string): ResourceHistory | null {
513
+ return this.versionManager.getHistory(resourceId);
514
+ }
515
+
516
+ private determineCurrentLayer(didId: string): LayerType {
517
+ if (didId.startsWith('did:peer:')) return 'did:peer';
518
+ if (didId.startsWith('did:webvh:')) return 'did:webvh';
519
+ if (didId.startsWith('did:btco:')) return 'did:btco';
520
+ throw new Error('Unknown DID method');
521
+ }
522
+ }
523
+
524
+