@originals/sdk 1.1.0 → 1.4.2

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 (247) hide show
  1. package/package.json +3 -2
  2. package/src/did/DIDManager.ts +1 -1
  3. package/src/did/WebVHManager.ts +11 -2
  4. package/src/examples/create-module-original.ts +435 -0
  5. package/src/examples/full-lifecycle-flow.ts +514 -0
  6. package/src/examples/run.ts +59 -4
  7. package/src/index.ts +69 -3
  8. package/src/kinds/KindRegistry.ts +290 -0
  9. package/src/kinds/index.ts +74 -0
  10. package/src/kinds/types.ts +470 -0
  11. package/src/kinds/validators/AgentValidator.ts +257 -0
  12. package/src/kinds/validators/AppValidator.ts +211 -0
  13. package/src/kinds/validators/DatasetValidator.ts +242 -0
  14. package/src/kinds/validators/DocumentValidator.ts +311 -0
  15. package/src/kinds/validators/MediaValidator.ts +269 -0
  16. package/src/kinds/validators/ModuleValidator.ts +225 -0
  17. package/src/kinds/validators/base.ts +276 -0
  18. package/src/kinds/validators/index.ts +12 -0
  19. package/src/lifecycle/LifecycleManager.ts +909 -1
  20. package/src/resources/ResourceManager.ts +655 -0
  21. package/src/resources/index.ts +21 -0
  22. package/src/resources/types.ts +202 -0
  23. package/src/types/common.ts +1 -1
  24. package/src/vc/CredentialManager.ts +647 -2
  25. package/tests/integration/createTypedOriginal.test.ts +379 -0
  26. package/tests/performance/BatchOperations.perf.test.ts +2 -2
  27. package/tests/unit/kinds/KindRegistry.test.ts +329 -0
  28. package/tests/unit/kinds/types.test.ts +409 -0
  29. package/tests/unit/kinds/validators.test.ts +651 -0
  30. package/tests/unit/lifecycle/LifecycleManager.cleanapi.test.ts +441 -0
  31. package/tests/unit/resources/ResourceManager.test.ts +740 -0
  32. package/tests/unit/vc/CredentialManager.helpers.test.ts +527 -0
  33. package/tsconfig.json +0 -1
  34. package/.turbo/turbo-build.log +0 -1
  35. package/.turbo/turbo-test.log +0 -68353
  36. package/dist/adapters/FeeOracleMock.d.ts +0 -6
  37. package/dist/adapters/FeeOracleMock.js +0 -8
  38. package/dist/adapters/index.d.ts +0 -4
  39. package/dist/adapters/index.js +0 -4
  40. package/dist/adapters/providers/OrdHttpProvider.d.ts +0 -56
  41. package/dist/adapters/providers/OrdHttpProvider.js +0 -110
  42. package/dist/adapters/providers/OrdMockProvider.d.ts +0 -70
  43. package/dist/adapters/providers/OrdMockProvider.js +0 -75
  44. package/dist/adapters/types.d.ts +0 -71
  45. package/dist/adapters/types.js +0 -1
  46. package/dist/bitcoin/BitcoinManager.d.ts +0 -15
  47. package/dist/bitcoin/BitcoinManager.js +0 -262
  48. package/dist/bitcoin/BroadcastClient.d.ts +0 -30
  49. package/dist/bitcoin/BroadcastClient.js +0 -35
  50. package/dist/bitcoin/OrdinalsClient.d.ts +0 -21
  51. package/dist/bitcoin/OrdinalsClient.js +0 -105
  52. package/dist/bitcoin/PSBTBuilder.d.ts +0 -24
  53. package/dist/bitcoin/PSBTBuilder.js +0 -80
  54. package/dist/bitcoin/fee-calculation.d.ts +0 -14
  55. package/dist/bitcoin/fee-calculation.js +0 -31
  56. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +0 -38
  57. package/dist/bitcoin/providers/OrdNodeProvider.js +0 -67
  58. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +0 -33
  59. package/dist/bitcoin/providers/OrdinalsProvider.js +0 -50
  60. package/dist/bitcoin/providers/types.d.ts +0 -63
  61. package/dist/bitcoin/providers/types.js +0 -1
  62. package/dist/bitcoin/transactions/commit.d.ts +0 -89
  63. package/dist/bitcoin/transactions/commit.js +0 -311
  64. package/dist/bitcoin/transactions/index.d.ts +0 -7
  65. package/dist/bitcoin/transactions/index.js +0 -8
  66. package/dist/bitcoin/transfer.d.ts +0 -9
  67. package/dist/bitcoin/transfer.js +0 -26
  68. package/dist/bitcoin/utxo-selection.d.ts +0 -78
  69. package/dist/bitcoin/utxo-selection.js +0 -237
  70. package/dist/bitcoin/utxo.d.ts +0 -26
  71. package/dist/bitcoin/utxo.js +0 -78
  72. package/dist/contexts/credentials-v1.json +0 -195
  73. package/dist/contexts/credentials-v2-examples.json +0 -5
  74. package/dist/contexts/credentials-v2.json +0 -301
  75. package/dist/contexts/credentials.json +0 -195
  76. package/dist/contexts/data-integrity-v2.json +0 -81
  77. package/dist/contexts/dids.json +0 -57
  78. package/dist/contexts/ed255192020.json +0 -93
  79. package/dist/contexts/ordinals-plus.json +0 -23
  80. package/dist/contexts/originals.json +0 -22
  81. package/dist/core/OriginalsSDK.d.ts +0 -158
  82. package/dist/core/OriginalsSDK.js +0 -274
  83. package/dist/crypto/Multikey.d.ts +0 -30
  84. package/dist/crypto/Multikey.js +0 -149
  85. package/dist/crypto/Signer.d.ts +0 -21
  86. package/dist/crypto/Signer.js +0 -196
  87. package/dist/crypto/noble-init.d.ts +0 -18
  88. package/dist/crypto/noble-init.js +0 -106
  89. package/dist/did/BtcoDidResolver.d.ts +0 -57
  90. package/dist/did/BtcoDidResolver.js +0 -166
  91. package/dist/did/DIDManager.d.ts +0 -101
  92. package/dist/did/DIDManager.js +0 -493
  93. package/dist/did/Ed25519Verifier.d.ts +0 -30
  94. package/dist/did/Ed25519Verifier.js +0 -59
  95. package/dist/did/KeyManager.d.ts +0 -17
  96. package/dist/did/KeyManager.js +0 -207
  97. package/dist/did/WebVHManager.d.ts +0 -100
  98. package/dist/did/WebVHManager.js +0 -304
  99. package/dist/did/createBtcoDidDocument.d.ts +0 -10
  100. package/dist/did/createBtcoDidDocument.js +0 -42
  101. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +0 -23
  102. package/dist/did/providers/OrdinalsClientProviderAdapter.js +0 -51
  103. package/dist/events/EventEmitter.d.ts +0 -115
  104. package/dist/events/EventEmitter.js +0 -198
  105. package/dist/events/index.d.ts +0 -7
  106. package/dist/events/index.js +0 -6
  107. package/dist/events/types.d.ts +0 -286
  108. package/dist/events/types.js +0 -9
  109. package/dist/examples/basic-usage.d.ts +0 -3
  110. package/dist/examples/basic-usage.js +0 -62
  111. package/dist/examples/run.d.ts +0 -1
  112. package/dist/examples/run.js +0 -4
  113. package/dist/index.d.ts +0 -39
  114. package/dist/index.js +0 -47
  115. package/dist/lifecycle/BatchOperations.d.ts +0 -147
  116. package/dist/lifecycle/BatchOperations.js +0 -251
  117. package/dist/lifecycle/LifecycleManager.d.ts +0 -116
  118. package/dist/lifecycle/LifecycleManager.js +0 -971
  119. package/dist/lifecycle/OriginalsAsset.d.ts +0 -164
  120. package/dist/lifecycle/OriginalsAsset.js +0 -380
  121. package/dist/lifecycle/ProvenanceQuery.d.ts +0 -126
  122. package/dist/lifecycle/ProvenanceQuery.js +0 -220
  123. package/dist/lifecycle/ResourceVersioning.d.ts +0 -73
  124. package/dist/lifecycle/ResourceVersioning.js +0 -127
  125. package/dist/migration/MigrationManager.d.ts +0 -86
  126. package/dist/migration/MigrationManager.js +0 -412
  127. package/dist/migration/audit/AuditLogger.d.ts +0 -51
  128. package/dist/migration/audit/AuditLogger.js +0 -156
  129. package/dist/migration/checkpoint/CheckpointManager.d.ts +0 -31
  130. package/dist/migration/checkpoint/CheckpointManager.js +0 -96
  131. package/dist/migration/checkpoint/CheckpointStorage.d.ts +0 -26
  132. package/dist/migration/checkpoint/CheckpointStorage.js +0 -89
  133. package/dist/migration/index.d.ts +0 -22
  134. package/dist/migration/index.js +0 -27
  135. package/dist/migration/operations/BaseMigration.d.ts +0 -48
  136. package/dist/migration/operations/BaseMigration.js +0 -83
  137. package/dist/migration/operations/PeerToBtcoMigration.d.ts +0 -25
  138. package/dist/migration/operations/PeerToBtcoMigration.js +0 -67
  139. package/dist/migration/operations/PeerToWebvhMigration.d.ts +0 -19
  140. package/dist/migration/operations/PeerToWebvhMigration.js +0 -46
  141. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +0 -25
  142. package/dist/migration/operations/WebvhToBtcoMigration.js +0 -67
  143. package/dist/migration/rollback/RollbackManager.d.ts +0 -29
  144. package/dist/migration/rollback/RollbackManager.js +0 -146
  145. package/dist/migration/state/StateMachine.d.ts +0 -25
  146. package/dist/migration/state/StateMachine.js +0 -76
  147. package/dist/migration/state/StateTracker.d.ts +0 -36
  148. package/dist/migration/state/StateTracker.js +0 -123
  149. package/dist/migration/types.d.ts +0 -306
  150. package/dist/migration/types.js +0 -33
  151. package/dist/migration/validation/BitcoinValidator.d.ts +0 -13
  152. package/dist/migration/validation/BitcoinValidator.js +0 -83
  153. package/dist/migration/validation/CredentialValidator.d.ts +0 -13
  154. package/dist/migration/validation/CredentialValidator.js +0 -46
  155. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +0 -16
  156. package/dist/migration/validation/DIDCompatibilityValidator.js +0 -127
  157. package/dist/migration/validation/LifecycleValidator.d.ts +0 -10
  158. package/dist/migration/validation/LifecycleValidator.js +0 -52
  159. package/dist/migration/validation/StorageValidator.d.ts +0 -10
  160. package/dist/migration/validation/StorageValidator.js +0 -65
  161. package/dist/migration/validation/ValidationPipeline.d.ts +0 -29
  162. package/dist/migration/validation/ValidationPipeline.js +0 -180
  163. package/dist/storage/LocalStorageAdapter.d.ts +0 -11
  164. package/dist/storage/LocalStorageAdapter.js +0 -53
  165. package/dist/storage/MemoryStorageAdapter.d.ts +0 -6
  166. package/dist/storage/MemoryStorageAdapter.js +0 -21
  167. package/dist/storage/StorageAdapter.d.ts +0 -16
  168. package/dist/storage/StorageAdapter.js +0 -1
  169. package/dist/storage/index.d.ts +0 -2
  170. package/dist/storage/index.js +0 -2
  171. package/dist/types/bitcoin.d.ts +0 -84
  172. package/dist/types/bitcoin.js +0 -1
  173. package/dist/types/common.d.ts +0 -82
  174. package/dist/types/common.js +0 -1
  175. package/dist/types/credentials.d.ts +0 -75
  176. package/dist/types/credentials.js +0 -1
  177. package/dist/types/did.d.ts +0 -26
  178. package/dist/types/did.js +0 -1
  179. package/dist/types/index.d.ts +0 -5
  180. package/dist/types/index.js +0 -5
  181. package/dist/types/network.d.ts +0 -78
  182. package/dist/types/network.js +0 -145
  183. package/dist/utils/EventLogger.d.ts +0 -71
  184. package/dist/utils/EventLogger.js +0 -232
  185. package/dist/utils/Logger.d.ts +0 -106
  186. package/dist/utils/Logger.js +0 -257
  187. package/dist/utils/MetricsCollector.d.ts +0 -110
  188. package/dist/utils/MetricsCollector.js +0 -264
  189. package/dist/utils/bitcoin-address.d.ts +0 -38
  190. package/dist/utils/bitcoin-address.js +0 -113
  191. package/dist/utils/cbor.d.ts +0 -2
  192. package/dist/utils/cbor.js +0 -9
  193. package/dist/utils/encoding.d.ts +0 -37
  194. package/dist/utils/encoding.js +0 -120
  195. package/dist/utils/hash.d.ts +0 -1
  196. package/dist/utils/hash.js +0 -5
  197. package/dist/utils/retry.d.ts +0 -10
  198. package/dist/utils/retry.js +0 -35
  199. package/dist/utils/satoshi-validation.d.ts +0 -60
  200. package/dist/utils/satoshi-validation.js +0 -156
  201. package/dist/utils/serialization.d.ts +0 -14
  202. package/dist/utils/serialization.js +0 -76
  203. package/dist/utils/telemetry.d.ts +0 -17
  204. package/dist/utils/telemetry.js +0 -24
  205. package/dist/utils/validation.d.ts +0 -5
  206. package/dist/utils/validation.js +0 -98
  207. package/dist/vc/CredentialManager.d.ts +0 -22
  208. package/dist/vc/CredentialManager.js +0 -227
  209. package/dist/vc/Issuer.d.ts +0 -27
  210. package/dist/vc/Issuer.js +0 -70
  211. package/dist/vc/Verifier.d.ts +0 -16
  212. package/dist/vc/Verifier.js +0 -50
  213. package/dist/vc/cryptosuites/bbs.d.ts +0 -44
  214. package/dist/vc/cryptosuites/bbs.js +0 -213
  215. package/dist/vc/cryptosuites/bbsSimple.d.ts +0 -9
  216. package/dist/vc/cryptosuites/bbsSimple.js +0 -12
  217. package/dist/vc/cryptosuites/eddsa.d.ts +0 -30
  218. package/dist/vc/cryptosuites/eddsa.js +0 -81
  219. package/dist/vc/documentLoader.d.ts +0 -16
  220. package/dist/vc/documentLoader.js +0 -59
  221. package/dist/vc/proofs/data-integrity.d.ts +0 -21
  222. package/dist/vc/proofs/data-integrity.js +0 -15
  223. package/dist/vc/utils/jsonld.d.ts +0 -2
  224. package/dist/vc/utils/jsonld.js +0 -15
  225. package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +0 -1
  226. package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +0 -1
  227. package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +0 -1
  228. package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +0 -1
  229. package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +0 -1
  230. package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +0 -1
  231. package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +0 -1
  232. package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +0 -1
  233. package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +0 -1
  234. package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +0 -1
  235. package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +0 -1
  236. package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +0 -1
  237. package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +0 -1
  238. package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +0 -1
  239. package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +0 -1
  240. package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +0 -1
  241. package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +0 -1
  242. package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +0 -1
  243. package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +0 -1
  244. package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +0 -1
  245. package/tests/e2e/README.md +0 -97
  246. package/tests/e2e/example.spec.ts +0 -78
  247. package/tsconfig.tsbuildinfo +0 -1
@@ -1,264 +0,0 @@
1
- /**
2
- * Metrics Collector for Originals SDK
3
- *
4
- * Features:
5
- * - Track operation counts and performance
6
- * - Asset lifecycle metrics (created, migrated, transferred)
7
- * - Error tracking by error code
8
- * - Cache statistics (optional)
9
- * - Export in JSON and Prometheus formats
10
- * - Memory-efficient storage
11
- */
12
- /**
13
- * MetricsCollector class
14
- */
15
- export class MetricsCollector {
16
- constructor() {
17
- this.assetsCreatedCount = 0;
18
- this.assetsMigratedMap = new Map();
19
- this.assetsTransferredCount = 0;
20
- this.operationMetrics = new Map();
21
- this.errorCounts = new Map();
22
- this.cacheHits = 0;
23
- this.cacheMisses = 0;
24
- this.startTime = new Date().toISOString();
25
- }
26
- /**
27
- * Record an operation with timing and success status
28
- */
29
- recordOperation(operation, duration, success) {
30
- if (!this.operationMetrics.has(operation)) {
31
- this.operationMetrics.set(operation, {
32
- count: 0,
33
- totalTime: 0,
34
- minTime: Infinity,
35
- maxTime: -Infinity,
36
- errorCount: 0
37
- });
38
- }
39
- const metrics = this.operationMetrics.get(operation);
40
- metrics.count++;
41
- metrics.totalTime += duration;
42
- metrics.minTime = Math.min(metrics.minTime, duration);
43
- metrics.maxTime = Math.max(metrics.maxTime, duration);
44
- if (!success) {
45
- metrics.errorCount++;
46
- }
47
- }
48
- /**
49
- * Start tracking an operation, returns completion function
50
- */
51
- startOperation(operation) {
52
- const startTime = performance.now();
53
- return (success = true) => {
54
- const duration = performance.now() - startTime;
55
- this.recordOperation(operation, duration, success);
56
- };
57
- }
58
- /**
59
- * Record an asset creation
60
- */
61
- recordAssetCreated() {
62
- this.assetsCreatedCount++;
63
- }
64
- /**
65
- * Record an asset migration between layers
66
- */
67
- recordMigration(from, to) {
68
- // Create transition key
69
- const fromShort = from.split(':')[1]; // "peer", "webvh", "btco"
70
- const toShort = to.split(':')[1];
71
- const transitionKey = `${fromShort}→${toShort}`;
72
- const current = this.assetsMigratedMap.get(transitionKey) || 0;
73
- this.assetsMigratedMap.set(transitionKey, current + 1);
74
- }
75
- /**
76
- * Record an asset transfer
77
- */
78
- recordTransfer() {
79
- this.assetsTransferredCount++;
80
- }
81
- /**
82
- * Record an error by error code
83
- */
84
- recordError(code, operation) {
85
- // Track error by code
86
- const current = this.errorCounts.get(code) || 0;
87
- this.errorCounts.set(code, current + 1);
88
- // If operation is provided, increment its error count
89
- if (operation && this.operationMetrics.has(operation)) {
90
- this.operationMetrics.get(operation).errorCount++;
91
- }
92
- }
93
- /**
94
- * Record a cache hit
95
- */
96
- recordCacheHit() {
97
- this.cacheHits++;
98
- }
99
- /**
100
- * Record a cache miss
101
- */
102
- recordCacheMiss() {
103
- this.cacheMisses++;
104
- }
105
- /**
106
- * Get a snapshot of all metrics
107
- */
108
- getMetrics() {
109
- const operationTimes = {};
110
- for (const [operation, metrics] of this.operationMetrics.entries()) {
111
- operationTimes[operation] = {
112
- count: metrics.count,
113
- totalTime: metrics.totalTime,
114
- avgTime: metrics.count > 0 ? metrics.totalTime / metrics.count : 0,
115
- minTime: metrics.minTime === Infinity ? 0 : metrics.minTime,
116
- maxTime: metrics.maxTime === -Infinity ? 0 : metrics.maxTime,
117
- errorCount: metrics.errorCount
118
- };
119
- }
120
- const assetsMigrated = {};
121
- for (const [key, count] of this.assetsMigratedMap.entries()) {
122
- assetsMigrated[key] = count;
123
- }
124
- const errors = {};
125
- for (const [code, count] of this.errorCounts.entries()) {
126
- errors[code] = count;
127
- }
128
- const totalCacheRequests = this.cacheHits + this.cacheMisses;
129
- const cacheStats = totalCacheRequests > 0 ? {
130
- hits: this.cacheHits,
131
- misses: this.cacheMisses,
132
- hitRate: this.cacheHits / totalCacheRequests
133
- } : undefined;
134
- return {
135
- assetsCreated: this.assetsCreatedCount,
136
- assetsMigrated,
137
- assetsTransferred: this.assetsTransferredCount,
138
- operationTimes,
139
- errors,
140
- cacheStats,
141
- startTime: this.startTime,
142
- uptime: Date.now() - new Date(this.startTime).getTime()
143
- };
144
- }
145
- /**
146
- * Get metrics for a specific operation
147
- */
148
- getOperationMetrics(operation) {
149
- const metrics = this.operationMetrics.get(operation);
150
- if (!metrics) {
151
- return null;
152
- }
153
- return {
154
- count: metrics.count,
155
- totalTime: metrics.totalTime,
156
- avgTime: metrics.count > 0 ? metrics.totalTime / metrics.count : 0,
157
- minTime: metrics.minTime === Infinity ? 0 : metrics.minTime,
158
- maxTime: metrics.maxTime === -Infinity ? 0 : metrics.maxTime,
159
- errorCount: metrics.errorCount
160
- };
161
- }
162
- /**
163
- * Reset all metrics
164
- */
165
- reset() {
166
- this.assetsCreatedCount = 0;
167
- this.assetsMigratedMap.clear();
168
- this.assetsTransferredCount = 0;
169
- this.operationMetrics.clear();
170
- this.errorCounts.clear();
171
- this.cacheHits = 0;
172
- this.cacheMisses = 0;
173
- }
174
- /**
175
- * Export metrics in the specified format
176
- */
177
- export(format) {
178
- if (format === 'json') {
179
- return this.exportJSON();
180
- }
181
- else if (format === 'prometheus') {
182
- return this.exportPrometheus();
183
- }
184
- throw new Error(`Unsupported export format: ${format}`);
185
- }
186
- /**
187
- * Export metrics as JSON
188
- */
189
- exportJSON() {
190
- return JSON.stringify(this.getMetrics(), null, 2);
191
- }
192
- /**
193
- * Export metrics in Prometheus format
194
- */
195
- exportPrometheus() {
196
- const lines = [];
197
- const metrics = this.getMetrics();
198
- // Asset metrics
199
- lines.push('# HELP originals_assets_created_total Total number of assets created');
200
- lines.push('# TYPE originals_assets_created_total counter');
201
- lines.push(`originals_assets_created_total ${metrics.assetsCreated}`);
202
- lines.push('');
203
- lines.push('# HELP originals_assets_transferred_total Total number of assets transferred');
204
- lines.push('# TYPE originals_assets_transferred_total counter');
205
- lines.push(`originals_assets_transferred_total ${metrics.assetsTransferred}`);
206
- lines.push('');
207
- // Migration metrics
208
- lines.push('# HELP originals_assets_migrated_total Total number of assets migrated by layer transition');
209
- lines.push('# TYPE originals_assets_migrated_total counter');
210
- for (const [transition, count] of Object.entries(metrics.assetsMigrated)) {
211
- const [from, to] = transition.split('→');
212
- lines.push(`originals_assets_migrated_total{from="${from}",to="${to}"} ${count}`);
213
- }
214
- lines.push('');
215
- // Operation metrics
216
- for (const [operation, opMetrics] of Object.entries(metrics.operationTimes)) {
217
- const safeOpName = operation.replace(/[^a-zA-Z0-9_]/g, '_');
218
- lines.push(`# HELP originals_operation_${safeOpName}_total Total number of ${operation} operations`);
219
- lines.push(`# TYPE originals_operation_${safeOpName}_total counter`);
220
- lines.push(`originals_operation_${safeOpName}_total ${opMetrics.count}`);
221
- lines.push('');
222
- lines.push(`# HELP originals_operation_${safeOpName}_duration_milliseconds Duration of ${operation} operations`);
223
- lines.push(`# TYPE originals_operation_${safeOpName}_duration_milliseconds summary`);
224
- lines.push(`originals_operation_${safeOpName}_duration_milliseconds{quantile="0.0"} ${opMetrics.minTime}`);
225
- lines.push(`originals_operation_${safeOpName}_duration_milliseconds{quantile="0.5"} ${opMetrics.avgTime}`);
226
- lines.push(`originals_operation_${safeOpName}_duration_milliseconds{quantile="1.0"} ${opMetrics.maxTime}`);
227
- lines.push(`originals_operation_${safeOpName}_duration_milliseconds_sum ${opMetrics.totalTime}`);
228
- lines.push(`originals_operation_${safeOpName}_duration_milliseconds_count ${opMetrics.count}`);
229
- lines.push('');
230
- lines.push(`# HELP originals_operation_${safeOpName}_errors_total Total number of errors in ${operation} operations`);
231
- lines.push(`# TYPE originals_operation_${safeOpName}_errors_total counter`);
232
- lines.push(`originals_operation_${safeOpName}_errors_total ${opMetrics.errorCount}`);
233
- lines.push('');
234
- }
235
- // Error metrics
236
- lines.push('# HELP originals_errors_total Total number of errors by code');
237
- lines.push('# TYPE originals_errors_total counter');
238
- for (const [code, count] of Object.entries(metrics.errors)) {
239
- lines.push(`originals_errors_total{code="${code}"} ${count}`);
240
- }
241
- lines.push('');
242
- // Cache metrics
243
- if (metrics.cacheStats) {
244
- lines.push('# HELP originals_cache_hits_total Total number of cache hits');
245
- lines.push('# TYPE originals_cache_hits_total counter');
246
- lines.push(`originals_cache_hits_total ${metrics.cacheStats.hits}`);
247
- lines.push('');
248
- lines.push('# HELP originals_cache_misses_total Total number of cache misses');
249
- lines.push('# TYPE originals_cache_misses_total counter');
250
- lines.push(`originals_cache_misses_total ${metrics.cacheStats.misses}`);
251
- lines.push('');
252
- lines.push('# HELP originals_cache_hit_rate Cache hit rate');
253
- lines.push('# TYPE originals_cache_hit_rate gauge');
254
- lines.push(`originals_cache_hit_rate ${metrics.cacheStats.hitRate}`);
255
- lines.push('');
256
- }
257
- // System metrics
258
- lines.push('# HELP originals_uptime_milliseconds SDK uptime in milliseconds');
259
- lines.push('# TYPE originals_uptime_milliseconds gauge');
260
- lines.push(`originals_uptime_milliseconds ${metrics.uptime}`);
261
- lines.push('');
262
- return lines.join('\n');
263
- }
264
- }
@@ -1,38 +0,0 @@
1
- /**
2
- * Bitcoin network types supported by the validation
3
- */
4
- export type BitcoinNetwork = 'mainnet' | 'regtest' | 'signet';
5
- /**
6
- * Validates a Bitcoin address format and checksum for the given network.
7
- *
8
- * This function uses bitcoinjs-lib's address.toOutputScript() which performs:
9
- * - Format validation (bech32, base58check)
10
- * - Checksum verification
11
- * - Network prefix validation
12
- *
13
- * @param address - The Bitcoin address to validate
14
- * @param network - The network to validate against ('mainnet', 'regtest', 'signet')
15
- * @returns true if the address is valid for the network
16
- * @throws Error with descriptive message if validation fails
17
- *
18
- * @example
19
- * ```typescript
20
- * // Valid mainnet address
21
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq', 'mainnet'); // true
22
- *
23
- * // Invalid checksum
24
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdd', 'mainnet'); // throws
25
- *
26
- * // Wrong network
27
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq', 'testnet'); // throws
28
- * ```
29
- */
30
- export declare function validateBitcoinAddress(address: string, network: BitcoinNetwork): boolean;
31
- /**
32
- * Validates a Bitcoin address and returns a boolean instead of throwing
33
- *
34
- * @param address - The Bitcoin address to validate
35
- * @param network - The network to validate against
36
- * @returns true if valid, false otherwise
37
- */
38
- export declare function isValidBitcoinAddress(address: string, network: BitcoinNetwork): boolean;
@@ -1,113 +0,0 @@
1
- import * as bitcoin from 'bitcoinjs-lib';
2
- /**
3
- * Maps our network names to bitcoinjs-lib network configurations
4
- */
5
- const getNetwork = (network) => {
6
- switch (network) {
7
- case 'mainnet':
8
- return bitcoin.networks.bitcoin;
9
- case 'regtest':
10
- // Regtest uses testnet parameters but with bcrt prefix
11
- // However, since many regtest addresses in tests use testnet format,
12
- // we accept both testnet and regtest addresses for regtest network
13
- return bitcoin.networks.regtest;
14
- case 'signet':
15
- // Signet uses the same bech32 prefix as testnet (tb1)
16
- return bitcoin.networks.testnet;
17
- default:
18
- throw new Error(`Unsupported network: ${network}`);
19
- }
20
- };
21
- /**
22
- * Validates a Bitcoin address format and checksum for the given network.
23
- *
24
- * This function uses bitcoinjs-lib's address.toOutputScript() which performs:
25
- * - Format validation (bech32, base58check)
26
- * - Checksum verification
27
- * - Network prefix validation
28
- *
29
- * @param address - The Bitcoin address to validate
30
- * @param network - The network to validate against ('mainnet', 'regtest', 'signet')
31
- * @returns true if the address is valid for the network
32
- * @throws Error with descriptive message if validation fails
33
- *
34
- * @example
35
- * ```typescript
36
- * // Valid mainnet address
37
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq', 'mainnet'); // true
38
- *
39
- * // Invalid checksum
40
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdd', 'mainnet'); // throws
41
- *
42
- * // Wrong network
43
- * validateBitcoinAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq', 'testnet'); // throws
44
- * ```
45
- */
46
- export function validateBitcoinAddress(address, network) {
47
- // Input validation
48
- if (!address || typeof address !== 'string') {
49
- throw new Error('Address must be a non-empty string');
50
- }
51
- const trimmedAddress = address.trim();
52
- if (trimmedAddress.length === 0) {
53
- throw new Error('Address cannot be empty');
54
- }
55
- // Check for mock/test addresses that should not be allowed in production
56
- if (/^(mock-|test-)/i.test(trimmedAddress)) {
57
- throw new Error('Mock or test addresses are not valid Bitcoin addresses');
58
- }
59
- // Validate address length (Bitcoin addresses are typically 26-90 characters)
60
- if (trimmedAddress.length < 26 || trimmedAddress.length > 90) {
61
- throw new Error(`Invalid address length: ${trimmedAddress.length} characters (expected 26-90)`);
62
- }
63
- try {
64
- // Get the appropriate network configuration
65
- const networkConfig = getNetwork(network);
66
- // Use bitcoinjs-lib to validate the address format and checksum
67
- // This will throw if the address is invalid
68
- bitcoin.address.toOutputScript(trimmedAddress, networkConfig);
69
- return true;
70
- }
71
- catch (error) {
72
- // For regtest, also try testnet network as many tools use testnet addresses for regtest
73
- if (network === 'regtest') {
74
- try {
75
- bitcoin.address.toOutputScript(trimmedAddress, bitcoin.networks.testnet);
76
- return true;
77
- }
78
- catch {
79
- // Fall through to error handling below
80
- }
81
- }
82
- // Parse the error to provide more specific feedback
83
- const errorMessage = error instanceof Error ? error.message : String(error);
84
- // Check for common error patterns and provide helpful messages
85
- if (errorMessage.includes('Invalid checksum') || errorMessage.includes('checksum')) {
86
- throw new Error(`Invalid Bitcoin address checksum for address: ${trimmedAddress}`);
87
- }
88
- if (errorMessage.includes('Invalid prefix') || errorMessage.includes('prefix')) {
89
- throw new Error(`Invalid address prefix for ${network} network: ${trimmedAddress}`);
90
- }
91
- if (errorMessage.includes('too short') || errorMessage.includes('too long')) {
92
- throw new Error(`Invalid address length for ${network}: ${trimmedAddress}`);
93
- }
94
- // Generic invalid address error
95
- throw new Error(`Invalid Bitcoin address for ${network} network: ${trimmedAddress} (${errorMessage})`);
96
- }
97
- }
98
- /**
99
- * Validates a Bitcoin address and returns a boolean instead of throwing
100
- *
101
- * @param address - The Bitcoin address to validate
102
- * @param network - The network to validate against
103
- * @returns true if valid, false otherwise
104
- */
105
- export function isValidBitcoinAddress(address, network) {
106
- try {
107
- validateBitcoinAddress(address, network);
108
- return true;
109
- }
110
- catch {
111
- return false;
112
- }
113
- }
@@ -1,2 +0,0 @@
1
- export declare function encode(input: unknown): Uint8Array;
2
- export declare function decode<T = unknown>(bytes: Uint8Array | ArrayBuffer | Buffer): T;
@@ -1,9 +0,0 @@
1
- import * as cbor from 'cbor-js';
2
- export function encode(input) {
3
- const encoded = cbor.encode(input);
4
- return new Uint8Array(encoded);
5
- }
6
- export function decode(bytes) {
7
- const view = new Uint8Array(bytes);
8
- return cbor.decode(view.buffer);
9
- }
@@ -1,37 +0,0 @@
1
- export declare function encodeBase64UrlMultibase(bytes: Uint8Array): string;
2
- export declare function decodeBase64UrlMultibase(s: string): Uint8Array;
3
- export declare function hexToBytes(hex: string): Uint8Array;
4
- export declare const MULTIBASE_BASE58BTC_HEADER = "z";
5
- export declare const MULTIBASE_BASE64URL_HEADER = "u";
6
- export declare const MULTICODEC_ED25519_PUB_HEADER: Uint8Array<ArrayBuffer>;
7
- export declare const MULTICODEC_ED25519_PRIV_HEADER: Uint8Array<ArrayBuffer>;
8
- export declare const MULTICODEC_X25519_PUB_HEADER: Uint8Array<ArrayBuffer>;
9
- export declare const MULTICODEC_X25519_PRIV_HEADER: Uint8Array<ArrayBuffer>;
10
- export declare const MULTICODEC_SECP256K1_PUB_HEADER: Uint8Array<ArrayBuffer>;
11
- export declare const MULTICODEC_SECP256K1_PRIV_HEADER: Uint8Array<ArrayBuffer>;
12
- export declare const MULTICODEC_BLS12381_G2_PUB_HEADER: Uint8Array<ArrayBuffer>;
13
- export declare const MULTICODEC_BLS12381_G2_PRIV_HEADER: Uint8Array<ArrayBuffer>;
14
- export declare const base64: {
15
- encode: (unencoded: any) => string;
16
- decode: (encoded: any) => Uint8Array;
17
- };
18
- export declare const utf8: {
19
- encode: (unencoded: string) => Uint8Array;
20
- decode: (encoded: Uint8Array) => string;
21
- };
22
- export declare const base64url: {
23
- encode: (unencoded: any) => string;
24
- decode: (encoded: any) => Uint8Array;
25
- };
26
- export declare const base58: {
27
- encode: (unencoded: Uint8Array) => string;
28
- decode: (encoded: string) => Uint8Array;
29
- };
30
- export declare const multibase: {
31
- encode: (val: Uint8Array, encoding: "base58btc" | "base64url") => string;
32
- decode: (val: string) => Uint8Array;
33
- };
34
- export declare const multikey: {
35
- encode: (header: Uint8Array, val: Uint8Array) => string;
36
- decode: (header: Uint8Array, val: string) => Uint8Array;
37
- };
@@ -1,120 +0,0 @@
1
- import b58 from 'b58';
2
- export function encodeBase64UrlMultibase(bytes) {
3
- return 'z' + Buffer.from(bytes).toString('base64url');
4
- }
5
- export function decodeBase64UrlMultibase(s) {
6
- if (!s || s[0] !== 'z') {
7
- throw new Error('Invalid Multibase encoding');
8
- }
9
- return Buffer.from(s.slice(1), 'base64url');
10
- }
11
- export function hexToBytes(hex) {
12
- const clean = hex.startsWith('0x') ? hex.slice(2) : hex;
13
- if (clean.length % 2 !== 0) {
14
- throw new Error('Invalid hex string length');
15
- }
16
- const out = new Uint8Array(clean.length / 2);
17
- for (let i = 0; i < clean.length; i += 2) {
18
- const byteStr = clean.substring(i, i + 2);
19
- const value = parseInt(byteStr, 16);
20
- if (Number.isNaN(value)) {
21
- throw new Error('Invalid hex string');
22
- }
23
- out[i / 2] = value;
24
- }
25
- return out;
26
- }
27
- // multibase base58-btc header
28
- export const MULTIBASE_BASE58BTC_HEADER = 'z';
29
- // multibase base64url header
30
- export const MULTIBASE_BASE64URL_HEADER = 'u';
31
- // multicodec ed25519-pub header as varint
32
- export const MULTICODEC_ED25519_PUB_HEADER = new Uint8Array([0xed, 0x01]);
33
- // multicodec ed25519-priv header as varint
34
- export const MULTICODEC_ED25519_PRIV_HEADER = new Uint8Array([0x80, 0x26]);
35
- // multicodec x25519-pub header as varint
36
- export const MULTICODEC_X25519_PUB_HEADER = new Uint8Array([0xec, 0x01]);
37
- // multicodec x25519-priv header as varint
38
- export const MULTICODEC_X25519_PRIV_HEADER = new Uint8Array([0x82, 0x26]);
39
- // multicode secp256k1-pub header as varint
40
- export const MULTICODEC_SECP256K1_PUB_HEADER = new Uint8Array([0xe7, 0x01]);
41
- // multicode secp256k1-priv header as varint
42
- export const MULTICODEC_SECP256K1_PRIV_HEADER = new Uint8Array([0x13, 0x01]);
43
- // multicodec bls12381g2-pub header as varint
44
- export const MULTICODEC_BLS12381_G2_PUB_HEADER = new Uint8Array([0xeb, 0x01]);
45
- // multicodec bls12381g2-priv header as varint
46
- export const MULTICODEC_BLS12381_G2_PRIV_HEADER = new Uint8Array([0x8a, 0x26]);
47
- export const base64 = {
48
- encode: (unencoded) => {
49
- return Buffer.from(unencoded || '').toString('base64');
50
- },
51
- decode: (encoded) => {
52
- return new Uint8Array(Buffer.from(encoded || '', 'base64').buffer);
53
- }
54
- };
55
- export const utf8 = {
56
- encode: (unencoded) => {
57
- return new TextEncoder().encode(unencoded);
58
- },
59
- decode: (encoded) => {
60
- return new TextDecoder().decode(encoded);
61
- }
62
- };
63
- export const base64url = {
64
- encode: (unencoded) => {
65
- const encoded = base64.encode(unencoded);
66
- return encoded.replace(/\+/g, '-').replace(/\//g, '_').replace(/=+$/g, '');
67
- },
68
- decode: (encoded) => {
69
- encoded = encoded.replace(/-/g, '+').replace(/_/g, '/');
70
- while (encoded.length % 4)
71
- encoded += '=';
72
- return base64.decode(encoded);
73
- }
74
- };
75
- export const base58 = {
76
- encode: (unencoded) => {
77
- return b58.encode(unencoded);
78
- },
79
- decode: (encoded) => {
80
- return b58.decode(encoded);
81
- }
82
- };
83
- export const multibase = {
84
- encode: (val, encoding) => {
85
- if (encoding === 'base58btc') {
86
- const baseEncoded = base58.encode(val);
87
- return MULTIBASE_BASE58BTC_HEADER + baseEncoded;
88
- }
89
- else if (encoding === 'base64url') {
90
- return MULTIBASE_BASE64URL_HEADER + base64url.encode(val);
91
- }
92
- throw new Error('Invalid multibase encoding.');
93
- },
94
- decode: (val) => {
95
- if (val.startsWith(MULTIBASE_BASE58BTC_HEADER)) {
96
- return base58.decode(val.substring(1));
97
- }
98
- else if (val.startsWith(MULTIBASE_BASE64URL_HEADER)) {
99
- return base64url.decode(val.substring(1));
100
- }
101
- throw new Error('Multibase value does not have expected header.');
102
- }
103
- };
104
- export const multikey = {
105
- encode: (header, val) => {
106
- const mcBytes = new Uint8Array(header.length + val.length);
107
- mcBytes.set(header);
108
- mcBytes.set(val, header.length);
109
- return multibase.encode(mcBytes, 'base58btc');
110
- },
111
- decode: (header, val) => {
112
- const mcValue = multibase.decode(val);
113
- for (let i = 0; i < header.length; i++) {
114
- if (mcValue[i] !== header[i]) {
115
- throw new Error('Multikey value does not have expected header.');
116
- }
117
- }
118
- return mcValue.slice(header.length);
119
- }
120
- };
@@ -1 +0,0 @@
1
- export declare function sha256Bytes(input: string | Uint8Array): Promise<Uint8Array>;
@@ -1,5 +0,0 @@
1
- export async function sha256Bytes(input) {
2
- const data = typeof input === 'string' ? new TextEncoder().encode(input) : input;
3
- const digest = await globalThis.crypto.subtle.digest('SHA-256', data);
4
- return new Uint8Array(digest);
5
- }
@@ -1,10 +0,0 @@
1
- export interface RetryOptions {
2
- maxRetries?: number;
3
- baseDelayMs?: number;
4
- maxDelayMs?: number;
5
- backoffFactor?: number;
6
- jitterFactor?: number;
7
- isRetriable?: (error: unknown) => boolean;
8
- onRetry?: (attempt: number, delayMs: number, error: unknown) => void;
9
- }
10
- export declare function withRetry<T>(fn: () => Promise<T>, options?: RetryOptions): Promise<T>;
@@ -1,35 +0,0 @@
1
- const DEFAULTS = {
2
- maxRetries: 3,
3
- baseDelayMs: 300,
4
- maxDelayMs: 10000,
5
- backoffFactor: 2,
6
- jitterFactor: 0.1,
7
- isRetriable: () => true,
8
- onRetry: () => { }
9
- };
10
- function sleep(ms) {
11
- return new Promise(resolve => setTimeout(resolve, ms));
12
- }
13
- function computeDelay(attempt, opts) {
14
- const exp = opts.baseDelayMs * Math.pow(opts.backoffFactor, attempt);
15
- const withJitter = exp + ((Math.random() * 2 - 1) * opts.jitterFactor * exp);
16
- return Math.min(Math.max(0, Math.floor(withJitter)), opts.maxDelayMs);
17
- }
18
- export async function withRetry(fn, options = {}) {
19
- const opts = { ...DEFAULTS, ...options };
20
- let lastError;
21
- for (let attempt = 0; attempt <= opts.maxRetries; attempt++) {
22
- try {
23
- return await fn();
24
- }
25
- catch (err) {
26
- lastError = err;
27
- if (attempt >= opts.maxRetries || !opts.isRetriable(err))
28
- break;
29
- const delay = computeDelay(attempt, opts);
30
- opts.onRetry(attempt + 1, delay, err);
31
- await sleep(delay);
32
- }
33
- }
34
- throw lastError;
35
- }