@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
package/src/index.ts ADDED
@@ -0,0 +1,84 @@
1
+ /* istanbul ignore file */
2
+ // Initialize noble crypto libraries first (must run before any crypto operations)
3
+ import './crypto/noble-init.js';
4
+
5
+ import { OriginalsSDK } from './core/OriginalsSDK.js';
6
+
7
+ // Main exports
8
+ export { OriginalsSDK } from './core/OriginalsSDK.js';
9
+ export type {
10
+ OriginalsSDKOptions,
11
+ OriginalResult,
12
+ CreateOriginalOptions,
13
+ UpdateOriginalOptions,
14
+ CreateDIDOriginalOptions,
15
+ UpdateDIDOriginalOptions
16
+ } from './core/OriginalsSDK.js';
17
+ export { OriginalsAsset } from './lifecycle/OriginalsAsset.js';
18
+ export type { ProvenanceChain } from './lifecycle/OriginalsAsset.js';
19
+
20
+ // Type exports
21
+ export * from './types/index.js';
22
+
23
+ // Manager exports
24
+ export { DIDManager, type CreateWebVHOptions, type CreateWebVHResult } from './did/DIDManager.js';
25
+ export { KeyManager } from './did/KeyManager.js';
26
+ export { Ed25519Verifier } from './did/Ed25519Verifier.js';
27
+ export * as encoding from './utils/encoding.js';
28
+ export { CredentialManager } from './vc/CredentialManager.js';
29
+ export { LifecycleManager } from './lifecycle/LifecycleManager.js';
30
+ export { BitcoinManager } from './bitcoin/BitcoinManager.js';
31
+ export { OrdinalsClient } from './bitcoin/OrdinalsClient.js';
32
+ export { buildTransferTransaction } from './bitcoin/transfer.js';
33
+ export { selectUtxos, UtxoSelectionError, estimateFeeSats } from './bitcoin/utxo.js';
34
+ export {
35
+ selectUtxos as selectUtxosSimple,
36
+ selectResourceUtxos,
37
+ selectUtxosForPayment,
38
+ tagResourceUtxos,
39
+ estimateTransactionSize
40
+ } from './bitcoin/utxo-selection.js';
41
+ export { calculateFee } from './bitcoin/fee-calculation.js';
42
+ export { BBSCryptosuiteUtils } from './vc/cryptosuites/bbs.js';
43
+ export { BbsSimple } from './vc/cryptosuites/bbsSimple.js';
44
+ export * from './storage/index.js';
45
+
46
+ // Crypto exports
47
+ export { Signer, ES256KSigner, Ed25519Signer, ES256Signer, Bls12381G2Signer } from './crypto/Signer.js';
48
+ export { multikey } from './crypto/Multikey.js';
49
+ export type { MultikeyType } from './crypto/Multikey.js';
50
+
51
+ // Event system exports
52
+ export * from './events/index.js';
53
+
54
+ // Migration system exports
55
+ export { MigrationManager } from './migration/index.js';
56
+ export * from './migration/types.js';
57
+
58
+ // Batch operations exports
59
+ export {
60
+ BatchOperationExecutor,
61
+ BatchValidator,
62
+ BatchError,
63
+ type BatchResult,
64
+ type BatchOperationOptions,
65
+ type BatchInscriptionOptions,
66
+ type BatchInscriptionResult,
67
+ type ValidationResult
68
+ } from './lifecycle/BatchOperations.js';
69
+
70
+ // Utility exports
71
+ export * from './utils/validation.js';
72
+ export * from './utils/satoshi-validation.js';
73
+ export * from './utils/serialization.js';
74
+ export * from './utils/retry.js';
75
+ export * from './utils/telemetry.js';
76
+ export { sha256Bytes } from './utils/hash.js';
77
+
78
+ // Adapter exports (for testing and custom integrations)
79
+ export { OrdMockProvider } from './adapters/providers/OrdMockProvider.js';
80
+ export { FeeOracleMock } from './adapters/FeeOracleMock.js';
81
+ export type { OrdinalsProvider, FeeOracleAdapter, StorageAdapter } from './adapters/types.js';
82
+
83
+ // Default export
84
+ export default OriginalsSDK;
@@ -0,0 +1,373 @@
1
+ /**
2
+ * Batch Operations for Originals SDK
3
+ *
4
+ * Enables efficient processing of multiple assets with:
5
+ * - Configurable concurrency
6
+ * - Retry logic with exponential backoff
7
+ * - Fail-fast vs continue-on-error modes
8
+ * - Pre-validation of all items
9
+ * - Detailed timing and error tracking
10
+ */
11
+
12
+ import { randomBytes, bytesToHex } from '@noble/hashes/utils.js';
13
+
14
+ /**
15
+ * Result of a batch operation containing successful and failed items
16
+ */
17
+ export interface BatchResult<T> {
18
+ successful: Array<{
19
+ index: number;
20
+ result: T;
21
+ duration: number; // milliseconds for this operation
22
+ }>;
23
+ failed: Array<{
24
+ index: number;
25
+ error: Error;
26
+ duration: number;
27
+ retryAttempts?: number;
28
+ }>;
29
+ totalProcessed: number;
30
+ totalDuration: number; // total batch duration
31
+ batchId: string; // unique identifier for this batch
32
+ startedAt: string; // ISO timestamp
33
+ completedAt: string; // ISO timestamp
34
+ }
35
+
36
+ /**
37
+ * Options for configuring batch operation execution
38
+ */
39
+ export interface BatchOperationOptions {
40
+ continueOnError?: boolean; // Default: false (fail fast)
41
+ maxConcurrent?: number; // Default: 1 (sequential)
42
+ retryCount?: number; // Default: 0 (no retries)
43
+ retryDelay?: number; // Default: 1000ms (exponential backoff base)
44
+ timeoutMs?: number; // Default: 30000ms per operation
45
+ validateFirst?: boolean; // Default: true (validate all before processing)
46
+ }
47
+
48
+ /**
49
+ * Options for batch inscription operations with Bitcoin-specific settings
50
+ */
51
+ export interface BatchInscriptionOptions extends BatchOperationOptions {
52
+ singleTransaction?: boolean; // KEY FEATURE: combine into one Bitcoin tx
53
+ feeRate?: number; // sat/vB for inscription
54
+ }
55
+
56
+ /**
57
+ * Error thrown when a batch operation fails
58
+ */
59
+ export class BatchError extends Error {
60
+ constructor(
61
+ public batchId: string,
62
+ public operation: string,
63
+ public partialResults: { successful: number; failed: number },
64
+ message: string
65
+ ) {
66
+ super(message);
67
+ this.name = 'BatchError';
68
+ }
69
+ }
70
+
71
+ /**
72
+ * Result of a single-transaction batch inscription with cost analysis
73
+ */
74
+ export interface BatchInscriptionResult<T> {
75
+ batchTransactionId: string;
76
+ individualInscriptionIds: string[];
77
+ assets: T[];
78
+ totalFee: number;
79
+ feePerAsset: number[];
80
+ feeSavings: {
81
+ batchFee: number;
82
+ individualFees: number;
83
+ savings: number;
84
+ savingsPercentage: number;
85
+ };
86
+ batchId: string;
87
+ processingTime: number;
88
+ }
89
+
90
+ /**
91
+ * Executor for batch operations with configurable options
92
+ */
93
+ export class BatchOperationExecutor {
94
+ constructor(private defaultOptions: BatchOperationOptions = {}) {}
95
+
96
+ /**
97
+ * Execute a batch operation on multiple items
98
+ *
99
+ * @param items - Array of items to process
100
+ * @param operation - Function to execute on each item
101
+ * @param options - Batch operation options
102
+ * @param predeterminedBatchId - Optional pre-generated batch ID for event correlation
103
+ * @returns BatchResult with successful and failed operations
104
+ */
105
+ async execute<T, R>(
106
+ items: T[],
107
+ operation: (item: T, index: number) => Promise<R>,
108
+ options?: BatchOperationOptions,
109
+ predeterminedBatchId?: string
110
+ ): Promise<BatchResult<R>> {
111
+ const opts = { ...this.defaultOptions, ...options };
112
+ const {
113
+ continueOnError = false,
114
+ maxConcurrent = 1,
115
+ retryCount = 0,
116
+ retryDelay = 1000,
117
+ timeoutMs = 30000
118
+ } = opts;
119
+
120
+ const batchId = predeterminedBatchId || this.generateBatchId();
121
+ const startedAt = new Date().toISOString();
122
+ const startTime = Date.now();
123
+
124
+ const successful: BatchResult<R>['successful'] = [];
125
+ const failed: BatchResult<R>['failed'] = [];
126
+
127
+ // Process items with concurrency control
128
+ const processItem = async (item: T, index: number): Promise<void> => {
129
+ const itemStartTime = Date.now();
130
+ let lastError: Error | null = null;
131
+ let attempts = 0;
132
+
133
+ for (let attempt = 0; attempt <= retryCount; attempt++) {
134
+ attempts = attempt + 1;
135
+ try {
136
+ // Execute with timeout
137
+ const result = await this.executeWithTimeout(
138
+ () => operation(item, index),
139
+ timeoutMs
140
+ );
141
+
142
+ const duration = Date.now() - itemStartTime;
143
+ successful.push({ index, result, duration });
144
+ return;
145
+ } catch (error) {
146
+ lastError = error instanceof Error ? error : new Error(String(error));
147
+
148
+ // If not last attempt, wait with exponential backoff
149
+ if (attempt < retryCount) {
150
+ const delay = this.calculateRetryDelay(attempt, retryDelay);
151
+ await this.sleep(delay);
152
+ }
153
+ }
154
+ }
155
+
156
+ // All retries failed
157
+ const duration = Date.now() - itemStartTime;
158
+ failed.push({
159
+ index,
160
+ error: lastError!,
161
+ duration,
162
+ retryAttempts: attempts - 1
163
+ });
164
+
165
+ // If fail-fast mode, throw error
166
+ if (!continueOnError) {
167
+ throw lastError;
168
+ }
169
+ };
170
+
171
+ // Process items in batches based on maxConcurrent
172
+ try {
173
+ if (maxConcurrent === 1) {
174
+ // Sequential processing
175
+ for (let i = 0; i < items.length; i++) {
176
+ await processItem(items[i], i);
177
+ }
178
+ } else {
179
+ // Concurrent processing with limit
180
+ const chunks = this.chunkArray(items, maxConcurrent);
181
+ for (const chunk of chunks) {
182
+ await Promise.all(
183
+ chunk.map((item, chunkIndex) => {
184
+ const globalIndex = chunks.slice(0, chunks.indexOf(chunk))
185
+ .reduce((acc, c) => acc + c.length, 0) + chunkIndex;
186
+ return processItem(item, globalIndex);
187
+ })
188
+ );
189
+ }
190
+ }
191
+ } catch (error) {
192
+ // In fail-fast mode, re-throw the error so callers can handle it
193
+ if (!continueOnError) {
194
+ throw error instanceof Error ? error : new Error(String(error));
195
+ }
196
+ // In continue-on-error mode, the error was already logged in processItem
197
+ // and we'll return the partial results below
198
+ }
199
+
200
+ const totalDuration = Date.now() - startTime;
201
+ const completedAt = new Date().toISOString();
202
+
203
+ return {
204
+ successful,
205
+ failed,
206
+ totalProcessed: successful.length + failed.length,
207
+ totalDuration,
208
+ batchId,
209
+ startedAt,
210
+ completedAt
211
+ };
212
+ }
213
+
214
+ /**
215
+ * Generate unique batch ID
216
+ */
217
+ generateBatchId(): string {
218
+ return `batch_${Date.now()}_${bytesToHex(randomBytes(8))}`;
219
+ }
220
+
221
+ /**
222
+ * Calculate retry delay with exponential backoff
223
+ */
224
+ private calculateRetryDelay(attempt: number, baseDelay: number): number {
225
+ // Exponential backoff: baseDelay * 2^attempt
226
+ return baseDelay * Math.pow(2, attempt);
227
+ }
228
+
229
+ /**
230
+ * Execute operation with timeout
231
+ */
232
+ private async executeWithTimeout<R>(
233
+ operation: () => Promise<R>,
234
+ timeoutMs: number
235
+ ): Promise<R> {
236
+ return Promise.race([
237
+ operation(),
238
+ new Promise<R>((_, reject) =>
239
+ setTimeout(() => reject(new Error(`Operation timeout after ${timeoutMs}ms`)), timeoutMs)
240
+ )
241
+ ]);
242
+ }
243
+
244
+ /**
245
+ * Sleep for specified milliseconds
246
+ */
247
+ private sleep(ms: number): Promise<void> {
248
+ return new Promise(resolve => setTimeout(resolve, ms));
249
+ }
250
+
251
+ /**
252
+ * Chunk array into smaller arrays of specified size
253
+ */
254
+ private chunkArray<T>(array: T[], size: number): T[][] {
255
+ const chunks: T[][] = [];
256
+ for (let i = 0; i < array.length; i += size) {
257
+ chunks.push(array.slice(i, i + size));
258
+ }
259
+ return chunks;
260
+ }
261
+ }
262
+
263
+ /**
264
+ * Validation result for batch operations
265
+ */
266
+ export interface ValidationResult {
267
+ isValid: boolean;
268
+ errors: string[];
269
+ warnings?: string[];
270
+ }
271
+
272
+ /**
273
+ * Validator for batch operations
274
+ */
275
+ export class BatchValidator {
276
+ /**
277
+ * Validate batch of resources for asset creation
278
+ */
279
+ validateBatchCreate(resourcesList: any[][]): ValidationResult[] {
280
+ return resourcesList.map((resources, index) => {
281
+ const errors: string[] = [];
282
+
283
+ if (!Array.isArray(resources)) {
284
+ errors.push(`Item ${index}: Resources must be an array`);
285
+ return { isValid: false, errors };
286
+ }
287
+
288
+ if (resources.length === 0) {
289
+ errors.push(`Item ${index}: At least one resource is required`);
290
+ return { isValid: false, errors };
291
+ }
292
+
293
+ // Validate each resource
294
+ for (let i = 0; i < resources.length; i++) {
295
+ const resource = resources[i];
296
+ if (!resource || typeof resource !== 'object') {
297
+ errors.push(`Item ${index}, resource ${i}: Invalid resource object`);
298
+ continue;
299
+ }
300
+ if (!resource.id || typeof resource.id !== 'string') {
301
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid id`);
302
+ }
303
+ if (!resource.type || typeof resource.type !== 'string') {
304
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid type`);
305
+ }
306
+ if (!resource.contentType || typeof resource.contentType !== 'string') {
307
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid contentType`);
308
+ }
309
+ if (!resource.hash || typeof resource.hash !== 'string' || !/^[0-9a-fA-F]+$/.test(resource.hash)) {
310
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid hash`);
311
+ }
312
+ }
313
+
314
+ return { isValid: errors.length === 0, errors };
315
+ });
316
+ }
317
+
318
+ /**
319
+ * Validate batch of assets for inscription
320
+ */
321
+ validateBatchInscription(assets: any[]): ValidationResult[] {
322
+ return assets.map((asset, index) => {
323
+ const errors: string[] = [];
324
+
325
+ if (!asset || typeof asset !== 'object') {
326
+ errors.push(`Item ${index}: Invalid asset object`);
327
+ return { isValid: false, errors };
328
+ }
329
+
330
+ if (!asset.id || typeof asset.id !== 'string') {
331
+ errors.push(`Item ${index}: Missing or invalid asset id`);
332
+ }
333
+
334
+ if (!asset.currentLayer) {
335
+ errors.push(`Item ${index}: Missing currentLayer`);
336
+ } else if (asset.currentLayer === 'did:btco') {
337
+ errors.push(`Item ${index}: Asset already inscribed on Bitcoin`);
338
+ }
339
+
340
+ if (!asset.resources || !Array.isArray(asset.resources) || asset.resources.length === 0) {
341
+ errors.push(`Item ${index}: Asset must have at least one resource`);
342
+ }
343
+
344
+ return { isValid: errors.length === 0, errors };
345
+ });
346
+ }
347
+
348
+ /**
349
+ * Validate batch of transfer operations
350
+ */
351
+ validateBatchTransfer(transfers: Array<{ asset: any; to: string }>): ValidationResult[] {
352
+ return transfers.map((transfer, index) => {
353
+ const errors: string[] = [];
354
+
355
+ if (!transfer || typeof transfer !== 'object') {
356
+ errors.push(`Item ${index}: Invalid transfer object`);
357
+ return { isValid: false, errors };
358
+ }
359
+
360
+ if (!transfer.asset || typeof transfer.asset !== 'object') {
361
+ errors.push(`Item ${index}: Invalid asset`);
362
+ } else if (transfer.asset.currentLayer !== 'did:btco') {
363
+ errors.push(`Item ${index}: Asset must be inscribed on Bitcoin before transfer`);
364
+ }
365
+
366
+ if (!transfer.to || typeof transfer.to !== 'string') {
367
+ errors.push(`Item ${index}: Invalid destination address`);
368
+ }
369
+
370
+ return { isValid: errors.length === 0, errors };
371
+ });
372
+ }
373
+ }