@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,64 @@
1
+ /**
2
+ * LifecycleValidator - Validates lifecycle state transitions
3
+ */
4
+
5
+ import {
6
+ MigrationOptions,
7
+ MigrationValidationResult,
8
+ ValidationError,
9
+ ValidationWarning,
10
+ IValidator
11
+ } from '../types';
12
+ import { OriginalsConfig } from '../../types';
13
+
14
+ export class LifecycleValidator implements IValidator {
15
+ constructor(private config: OriginalsConfig) {}
16
+
17
+ async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
18
+ const errors: ValidationError[] = [];
19
+ const warnings: ValidationWarning[] = [];
20
+
21
+ try {
22
+ // All lifecycle states are compatible with all layers
23
+ // This validator checks for pending operations that might interfere
24
+
25
+ // For now, lifecycle is always compatible
26
+ // Future enhancements could check for:
27
+ // - Pending operations on source DID
28
+ // - State machine compatibility
29
+ // - Event history preservation capability
30
+
31
+ return {
32
+ valid: errors.length === 0,
33
+ errors,
34
+ warnings,
35
+ estimatedCost: {
36
+ storageCost: 0,
37
+ networkFees: 0,
38
+ totalCost: 0,
39
+ currency: 'sats'
40
+ },
41
+ estimatedDuration: 30
42
+ };
43
+ } catch (error) {
44
+ errors.push({
45
+ code: 'LIFECYCLE_VALIDATION_ERROR',
46
+ message: 'Error validating lifecycle compatibility',
47
+ details: { error: error instanceof Error ? error.message : String(error) }
48
+ });
49
+
50
+ return {
51
+ valid: false,
52
+ errors,
53
+ warnings,
54
+ estimatedCost: {
55
+ storageCost: 0,
56
+ networkFees: 0,
57
+ totalCost: 0,
58
+ currency: 'sats'
59
+ },
60
+ estimatedDuration: 0
61
+ };
62
+ }
63
+ }
64
+ }
@@ -0,0 +1,79 @@
1
+ /**
2
+ * StorageValidator - Validates storage adapter compatibility
3
+ */
4
+
5
+ import {
6
+ MigrationOptions,
7
+ MigrationValidationResult,
8
+ ValidationError,
9
+ ValidationWarning,
10
+ IValidator
11
+ } from '../types';
12
+ import { OriginalsConfig } from '../../types';
13
+
14
+ export class StorageValidator implements IValidator {
15
+ constructor(private config: OriginalsConfig) {}
16
+
17
+ async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
18
+ const errors: ValidationError[] = [];
19
+ const warnings: ValidationWarning[] = [];
20
+
21
+ try {
22
+ const storageAdapter = (this.config as any).storageAdapter;
23
+
24
+ // Check if storage adapter is available
25
+ if (!storageAdapter) {
26
+ warnings.push({
27
+ code: 'NO_STORAGE_ADAPTER',
28
+ message: 'No storage adapter configured; using memory storage (not persistent)'
29
+ });
30
+ }
31
+
32
+ // Check large file support for partial migrations
33
+ if (options.partialMode) {
34
+ // Verify storage adapter supports chunked uploads
35
+ if (storageAdapter && typeof storageAdapter.putChunk !== 'function') {
36
+ warnings.push({
37
+ code: 'NO_CHUNKED_UPLOAD_SUPPORT',
38
+ message: 'Storage adapter does not support chunked uploads; partial mode may be inefficient'
39
+ });
40
+ }
41
+ }
42
+
43
+ // Estimate storage costs (minimal for webvh, zero for peer/btco)
44
+ const storageCost = options.targetLayer === 'webvh' ? 0.001 : 0;
45
+
46
+ return {
47
+ valid: errors.length === 0,
48
+ errors,
49
+ warnings,
50
+ estimatedCost: {
51
+ storageCost,
52
+ networkFees: 0,
53
+ totalCost: storageCost,
54
+ currency: 'sats'
55
+ },
56
+ estimatedDuration: 50
57
+ };
58
+ } catch (error) {
59
+ errors.push({
60
+ code: 'STORAGE_VALIDATION_ERROR',
61
+ message: 'Error validating storage compatibility',
62
+ details: { error: error instanceof Error ? error.message : String(error) }
63
+ });
64
+
65
+ return {
66
+ valid: false,
67
+ errors,
68
+ warnings,
69
+ estimatedCost: {
70
+ storageCost: 0,
71
+ networkFees: 0,
72
+ totalCost: 0,
73
+ currency: 'sats'
74
+ },
75
+ estimatedDuration: 0
76
+ };
77
+ }
78
+ }
79
+ }
@@ -0,0 +1,213 @@
1
+ /**
2
+ * ValidationPipeline - Orchestrates all validation checks before migration
3
+ */
4
+
5
+ import {
6
+ MigrationOptions,
7
+ MigrationValidationResult,
8
+ ValidationError,
9
+ ValidationWarning,
10
+ CostEstimate,
11
+ IValidator
12
+ } from '../types';
13
+ import { DIDCompatibilityValidator } from './DIDCompatibilityValidator';
14
+ import { CredentialValidator } from './CredentialValidator';
15
+ import { StorageValidator } from './StorageValidator';
16
+ import { LifecycleValidator } from './LifecycleValidator';
17
+ import { BitcoinValidator } from './BitcoinValidator';
18
+ import { OriginalsConfig } from '../../types';
19
+ import { DIDManager } from '../../did/DIDManager';
20
+ import { CredentialManager } from '../../vc/CredentialManager';
21
+ import { BitcoinManager } from '../../bitcoin/BitcoinManager';
22
+
23
+ export class ValidationPipeline {
24
+ private validators: Map<string, IValidator>;
25
+
26
+ constructor(
27
+ private config: OriginalsConfig,
28
+ private didManager: DIDManager,
29
+ private credentialManager: CredentialManager,
30
+ private bitcoinManager?: BitcoinManager
31
+ ) {
32
+ this.validators = new Map();
33
+ this.initializeValidators();
34
+ }
35
+
36
+ private initializeValidators(): void {
37
+ this.validators.set('did', new DIDCompatibilityValidator(this.config, this.didManager));
38
+ this.validators.set('credential', new CredentialValidator(this.config, this.credentialManager));
39
+ this.validators.set('storage', new StorageValidator(this.config));
40
+ this.validators.set('lifecycle', new LifecycleValidator(this.config));
41
+ if (this.bitcoinManager) {
42
+ this.validators.set('bitcoin', new BitcoinValidator(this.config, this.bitcoinManager));
43
+ }
44
+ }
45
+
46
+ /**
47
+ * Run all validation checks for a migration
48
+ */
49
+ async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
50
+ const errors: ValidationError[] = [];
51
+ const warnings: ValidationWarning[] = [];
52
+ let estimatedCost: CostEstimate = {
53
+ storageCost: 0,
54
+ networkFees: 0,
55
+ totalCost: 0,
56
+ currency: 'sats'
57
+ };
58
+ let estimatedDuration = 0;
59
+
60
+ try {
61
+ // Basic input validation
62
+ const inputErrors = this.validateInput(options);
63
+ if (inputErrors.length > 0) {
64
+ return {
65
+ valid: false,
66
+ errors: inputErrors,
67
+ warnings: [],
68
+ estimatedCost,
69
+ estimatedDuration: 0
70
+ };
71
+ }
72
+
73
+ // Run DID compatibility validation
74
+ const didResult = await this.validators.get('did')!.validate(options);
75
+ errors.push(...didResult.errors);
76
+ warnings.push(...didResult.warnings);
77
+ estimatedDuration = Math.max(estimatedDuration, didResult.estimatedDuration);
78
+
79
+ // Run credential validation if enabled
80
+ if (options.credentialIssuance !== false) {
81
+ const credResult = await this.validators.get('credential')!.validate(options);
82
+ errors.push(...credResult.errors);
83
+ warnings.push(...credResult.warnings);
84
+ }
85
+
86
+ // Run storage validation
87
+ const storageResult = await this.validators.get('storage')!.validate(options);
88
+ errors.push(...storageResult.errors);
89
+ warnings.push(...storageResult.warnings);
90
+ estimatedCost.storageCost = storageResult.estimatedCost.storageCost;
91
+
92
+ // Run lifecycle validation
93
+ const lifecycleResult = await this.validators.get('lifecycle')!.validate(options);
94
+ errors.push(...lifecycleResult.errors);
95
+ warnings.push(...lifecycleResult.warnings);
96
+
97
+ // Run Bitcoin validation for btco migrations
98
+ if (options.targetLayer === 'btco') {
99
+ const bitcoinValidator = this.validators.get('bitcoin');
100
+ if (!bitcoinValidator) {
101
+ errors.push({
102
+ code: 'BITCOIN_VALIDATOR_MISSING',
103
+ message: 'Bitcoin validator required for btco migrations but not configured',
104
+ details: { targetLayer: options.targetLayer }
105
+ });
106
+ } else {
107
+ const bitcoinResult = await bitcoinValidator.validate(options);
108
+ errors.push(...bitcoinResult.errors);
109
+ warnings.push(...bitcoinResult.warnings);
110
+ estimatedCost.networkFees = bitcoinResult.estimatedCost.networkFees;
111
+ estimatedDuration = Math.max(estimatedDuration, bitcoinResult.estimatedDuration);
112
+ }
113
+ }
114
+
115
+ // Calculate total cost
116
+ estimatedCost.totalCost = estimatedCost.storageCost + estimatedCost.networkFees;
117
+
118
+ return {
119
+ valid: errors.length === 0,
120
+ errors,
121
+ warnings,
122
+ estimatedCost,
123
+ estimatedDuration
124
+ };
125
+ } catch (error) {
126
+ errors.push({
127
+ code: 'VALIDATION_PIPELINE_ERROR',
128
+ message: 'Unexpected error during validation',
129
+ details: { error: error instanceof Error ? error.message : String(error) }
130
+ });
131
+
132
+ return {
133
+ valid: false,
134
+ errors,
135
+ warnings,
136
+ estimatedCost,
137
+ estimatedDuration
138
+ };
139
+ }
140
+ }
141
+
142
+ /**
143
+ * Validate basic input parameters
144
+ */
145
+ private validateInput(options: MigrationOptions): ValidationError[] {
146
+ const errors: ValidationError[] = [];
147
+
148
+ // Validate source DID
149
+ if (!options.sourceDid || typeof options.sourceDid !== 'string') {
150
+ errors.push({
151
+ code: 'INVALID_SOURCE_DID',
152
+ message: 'Source DID is required and must be a string',
153
+ field: 'sourceDid'
154
+ });
155
+ }
156
+
157
+ // Validate target layer
158
+ if (!options.targetLayer) {
159
+ errors.push({
160
+ code: 'INVALID_TARGET_LAYER',
161
+ message: 'Target layer is required',
162
+ field: 'targetLayer'
163
+ });
164
+ } else if (!['peer', 'webvh', 'btco'].includes(options.targetLayer)) {
165
+ errors.push({
166
+ code: 'INVALID_TARGET_LAYER',
167
+ message: 'Target layer must be one of: peer, webvh, btco',
168
+ field: 'targetLayer',
169
+ details: { received: options.targetLayer }
170
+ });
171
+ }
172
+
173
+ // Validate partial mode options
174
+ if (options.partialMode) {
175
+ if (typeof options.partialMode.chunkSize !== 'number' || options.partialMode.chunkSize <= 0) {
176
+ errors.push({
177
+ code: 'INVALID_CHUNK_SIZE',
178
+ message: 'Chunk size must be a positive number',
179
+ field: 'partialMode.chunkSize'
180
+ });
181
+ }
182
+ }
183
+
184
+ // Validate webvh-specific options
185
+ if (options.targetLayer === 'webvh' && !options.domain) {
186
+ errors.push({
187
+ code: 'DOMAIN_REQUIRED',
188
+ message: 'Domain is required for webvh migrations',
189
+ field: 'domain'
190
+ });
191
+ }
192
+
193
+ // Validate btco-specific options
194
+ if (options.targetLayer === 'btco') {
195
+ if (options.feeRate !== undefined && (typeof options.feeRate !== 'number' || options.feeRate <= 0)) {
196
+ errors.push({
197
+ code: 'INVALID_FEE_RATE',
198
+ message: 'Fee rate must be a positive number',
199
+ field: 'feeRate'
200
+ });
201
+ }
202
+ }
203
+
204
+ return errors;
205
+ }
206
+
207
+ /**
208
+ * Quick validation check (basic only, no async operations)
209
+ */
210
+ validateQuick(options: MigrationOptions): ValidationError[] {
211
+ return this.validateInput(options);
212
+ }
213
+ }
@@ -0,0 +1,61 @@
1
+ // Local adapter is optional in this environment; keeping implementation but avoid Node typings
2
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
3
+ // @ts-nocheck
4
+ import * as fs from 'fs/promises';
5
+ import * as path from 'path';
6
+ import { GetObjectResult, LocalStorageAdapterOptions, StorageAdapter } from './StorageAdapter';
7
+
8
+ export class LocalStorageAdapter implements StorageAdapter {
9
+ private baseDir: string;
10
+ private baseUrl?: string;
11
+
12
+ constructor(options: LocalStorageAdapterOptions) {
13
+ this.baseDir = options.baseDir;
14
+ this.baseUrl = options.baseUrl;
15
+ }
16
+
17
+ private resolvePath(domain: string, objectPath: string): string {
18
+ const safeDomain = domain.replace(/[^a-zA-Z0-9.-]/g, '_');
19
+ const cleanPath = objectPath.replace(/^\/+/, '');
20
+ return path.join(this.baseDir, safeDomain, cleanPath);
21
+ }
22
+
23
+ private toUrl(domain: string, objectPath: string): string {
24
+ const cleanPath = objectPath.replace(/^\/+/, '');
25
+ if (this.baseUrl) {
26
+ const trimmed = this.baseUrl.replace(/\/$/, '');
27
+ return `${trimmed}/${domain}/${cleanPath}`;
28
+ }
29
+ return `file://${this.resolvePath(domain, cleanPath)}`;
30
+ }
31
+
32
+ async putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string> {
33
+ const fullPath = this.resolvePath(domain, objectPath);
34
+ await fs.mkdir(path.dirname(fullPath), { recursive: true });
35
+ const data = typeof content === 'string' ? Buffer.from(content) : Buffer.from(content);
36
+ await fs.writeFile(fullPath, data);
37
+ return this.toUrl(domain, objectPath);
38
+ }
39
+
40
+ async getObject(domain: string, objectPath: string): Promise<GetObjectResult | null> {
41
+ const fullPath = this.resolvePath(domain, objectPath);
42
+ try {
43
+ const content = await fs.readFile(fullPath);
44
+ return { content: new Uint8Array(content) };
45
+ } catch (e: any) {
46
+ if (e && e.code === 'ENOENT') return null;
47
+ throw e;
48
+ }
49
+ }
50
+
51
+ async exists(domain: string, objectPath: string): Promise<boolean> {
52
+ const fullPath = this.resolvePath(domain, objectPath);
53
+ try {
54
+ await fs.access(fullPath);
55
+ return true;
56
+ } catch {
57
+ return false;
58
+ }
59
+ }
60
+ }
61
+
@@ -0,0 +1,29 @@
1
+ import { GetObjectResult, StorageAdapter } from './StorageAdapter';
2
+
3
+ type DomainPath = string;
4
+
5
+ const globalStore: Map<DomainPath, Uint8Array> = new Map();
6
+
7
+ function key(domain: string, objectPath: string): string {
8
+ const cleanPath = objectPath.replace(/^\/+/, '');
9
+ return `${domain}::${cleanPath}`;
10
+ }
11
+
12
+ export class MemoryStorageAdapter implements StorageAdapter {
13
+ async putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string> {
14
+ const data = typeof content === 'string' ? new TextEncoder().encode(content) : content;
15
+ globalStore.set(key(domain, objectPath), data);
16
+ return `mem://${domain}/${objectPath.replace(/^\/+/, '')}`;
17
+ }
18
+
19
+ async getObject(domain: string, objectPath: string): Promise<GetObjectResult | null> {
20
+ const stored = globalStore.get(key(domain, objectPath));
21
+ if (!stored) return null;
22
+ return { content: stored };
23
+ }
24
+
25
+ async exists(domain: string, objectPath: string): Promise<boolean> {
26
+ return globalStore.has(key(domain, objectPath));
27
+ }
28
+ }
29
+
@@ -0,0 +1,25 @@
1
+ export interface PutOptions {
2
+ contentType?: string;
3
+ }
4
+
5
+ export interface GetObjectResult {
6
+ content: Uint8Array;
7
+ contentType?: string;
8
+ }
9
+
10
+ export interface StorageAdapter {
11
+ // Writes content at a path under a logical domain root and returns a public URL
12
+ putObject(domain: string, path: string, content: Uint8Array | string, options?: PutOptions): Promise<string>;
13
+
14
+ // Reads content from a path under a domain root
15
+ getObject(domain: string, path: string): Promise<GetObjectResult | null>;
16
+
17
+ // Checks whether a path exists
18
+ exists(domain: string, path: string): Promise<boolean>;
19
+ }
20
+
21
+ export interface LocalStorageAdapterOptions {
22
+ baseDir: string;
23
+ baseUrl?: string;
24
+ }
25
+
@@ -0,0 +1,3 @@
1
+ export * from './StorageAdapter';
2
+ export * from './MemoryStorageAdapter';
3
+
@@ -0,0 +1,98 @@
1
+ // Bitcoin/Ordinals types
2
+ export interface OrdinalsInscription {
3
+ satoshi: string; // Unique satoshi identifier
4
+ inscriptionId: string;
5
+ content: Buffer;
6
+ contentType: string;
7
+ txid: string;
8
+ vout: number;
9
+ blockHeight?: number;
10
+ }
11
+
12
+ export interface BitcoinTransaction {
13
+ txid: string;
14
+ vin: TransactionInput[];
15
+ vout: TransactionOutput[];
16
+ fee: number;
17
+ blockHeight?: number;
18
+ confirmations?: number;
19
+ }
20
+
21
+ export interface TransactionInput {
22
+ txid: string;
23
+ vout: number;
24
+ scriptSig?: string;
25
+ witness?: string[];
26
+ }
27
+
28
+ export interface TransactionOutput {
29
+ value: number; // satoshis
30
+ scriptPubKey: string;
31
+ address?: string;
32
+ }
33
+
34
+ export interface Utxo {
35
+ txid: string;
36
+ vout: number;
37
+ value: number; // satoshis
38
+ scriptPubKey?: string;
39
+ address?: string;
40
+ inscriptions?: string[]; // inscription ids located on this outpoint
41
+ locked?: boolean; // if true, cannot be spent due to wallet locks
42
+ }
43
+
44
+ /**
45
+ * Extended UTXO interface that tracks whether it contains an Ordinals resource (inscription)
46
+ */
47
+ export interface ResourceUtxo extends Utxo {
48
+ /** True if this UTXO contains an inscription or other Ordinals resource */
49
+ hasResource?: boolean;
50
+ }
51
+
52
+ /**
53
+ * Strategy for selecting UTXOs
54
+ */
55
+ export type UtxoSelectionStrategy = 'minimize_change' | 'minimize_inputs' | 'optimize_size';
56
+
57
+ /**
58
+ * Options for resource-aware UTXO selection
59
+ */
60
+ export interface ResourceUtxoSelectionOptions {
61
+ /** Required amount in satoshis */
62
+ requiredAmount: number;
63
+ /** Fee rate in satoshis per vbyte */
64
+ feeRate: number;
65
+ /** Allow using UTXOs that contain resources (default: false) */
66
+ allowResourceUtxos?: boolean;
67
+ /** Prefer older UTXOs (default: false) */
68
+ preferOlder?: boolean;
69
+ /** Prefer UTXOs with value closer to required amount (default: false) */
70
+ preferCloserAmount?: boolean;
71
+ /** List of UTXO IDs to avoid using (format: "txid:vout") */
72
+ avoidUtxoIds?: string[];
73
+ }
74
+
75
+ /**
76
+ * Result of resource-aware UTXO selection
77
+ */
78
+ export interface ResourceUtxoSelectionResult {
79
+ /** Selected UTXOs for the transaction */
80
+ selectedUtxos: ResourceUtxo[];
81
+ /** Total value of selected UTXOs */
82
+ totalSelectedValue: number;
83
+ /** Estimated transaction fee in satoshis */
84
+ estimatedFee: number;
85
+ /** Change amount in satoshis (0 if less than dust) */
86
+ changeAmount: number;
87
+ }
88
+
89
+ export const DUST_LIMIT_SATS = 546;
90
+
91
+ export interface KeyPair {
92
+ privateKey: string; // multibase encoded
93
+ publicKey: string; // multibase encoded
94
+ }
95
+
96
+ export type KeyType = 'ES256K' | 'Ed25519' | 'ES256';
97
+
98
+
@@ -0,0 +1,92 @@
1
+ import { StorageAdapter, FeeOracleAdapter, OrdinalsProvider } from '../adapters';
2
+ import { TelemetryHooks } from '../utils/telemetry';
3
+ import type { LogLevel, LogOutput } from '../utils/Logger';
4
+ import type { EventLoggingConfig } from '../utils/EventLogger';
5
+ import type { WebVHNetworkName } from './network';
6
+
7
+ // Base types for the Originals protocol
8
+ export type LayerType = 'did:peer' | 'did:webvh' | 'did:btco';
9
+
10
+ export interface OriginalsConfig {
11
+ network: 'mainnet' | 'regtest' | 'signet';
12
+ bitcoinRpcUrl?: string;
13
+ defaultKeyType: 'ES256K' | 'Ed25519' | 'ES256';
14
+ keyStore?: KeyStore;
15
+ enableLogging?: boolean;
16
+ // WebVH network selection (defaults to 'pichu' - production)
17
+ webvhNetwork?: WebVHNetworkName;
18
+ // Optional pluggable adapters
19
+ storageAdapter?: StorageAdapter;
20
+ feeOracle?: FeeOracleAdapter;
21
+ ordinalsProvider?: OrdinalsProvider;
22
+ // Optional telemetry hooks
23
+ telemetry?: TelemetryHooks;
24
+ // Enhanced logging configuration
25
+ logging?: {
26
+ level?: LogLevel;
27
+ outputs?: LogOutput[];
28
+ includeTimestamps?: boolean;
29
+ includeContext?: boolean;
30
+ eventLogging?: EventLoggingConfig;
31
+ sanitizeLogs?: boolean; // Remove sensitive data
32
+ };
33
+ // Metrics configuration
34
+ metrics?: {
35
+ enabled?: boolean;
36
+ exportFormat?: 'json' | 'prometheus';
37
+ collectCache?: boolean;
38
+ };
39
+ }
40
+
41
+ export interface AssetResource {
42
+ id: string; // Logical resource ID (stable across versions)
43
+ type: string; // 'image', 'text', 'code', 'data', etc.
44
+ url?: string;
45
+ content?: string;
46
+ contentType: string;
47
+ hash: string; // Content hash (unique per version)
48
+ size?: number;
49
+ version?: number; // Version number (default 1)
50
+ previousVersionHash?: string; // Link to previous version (by content hash)
51
+ createdAt?: string; // ISO timestamp of when this version was created
52
+ }
53
+
54
+ export interface KeyStore {
55
+ getPrivateKey(verificationMethodId: string): Promise<string | null>;
56
+ setPrivateKey(verificationMethodId: string, privateKey: string): Promise<void>;
57
+ }
58
+
59
+ /**
60
+ * External signer interface for DID operations (compatible with didwebvh-ts)
61
+ * This allows integration with external key management systems like Privy
62
+ */
63
+ export interface ExternalSigner {
64
+ /**
65
+ * Sign data and return a proof value
66
+ * @param input - The signing input containing document and proof
67
+ * @returns The proof value (typically multibase-encoded signature)
68
+ */
69
+ sign(input: { document: Record<string, unknown>; proof: Record<string, unknown> }): Promise<{ proofValue: string }>;
70
+
71
+ /**
72
+ * Get the verification method ID for this signer
73
+ * @returns The verification method ID (e.g., "did:key:z6Mk...")
74
+ */
75
+ getVerificationMethodId(): string;
76
+ }
77
+
78
+ /**
79
+ * External verifier interface for DID operations (compatible with didwebvh-ts)
80
+ */
81
+ export interface ExternalVerifier {
82
+ /**
83
+ * Verify a signature
84
+ * @param signature - The signature bytes
85
+ * @param message - The message bytes that were signed
86
+ * @param publicKey - The public key bytes
87
+ * @returns True if the signature is valid
88
+ */
89
+ verify(signature: Uint8Array, message: Uint8Array, publicKey: Uint8Array): Promise<boolean>;
90
+ }
91
+
92
+