@originals/sdk 1.4.3 → 1.4.5

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 (222) hide show
  1. package/dist/adapters/FeeOracleMock.d.ts +6 -0
  2. package/dist/adapters/FeeOracleMock.js +8 -0
  3. package/dist/adapters/index.d.ts +4 -0
  4. package/dist/adapters/index.js +4 -0
  5. package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
  6. package/dist/adapters/providers/OrdHttpProvider.js +110 -0
  7. package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
  8. package/dist/adapters/providers/OrdMockProvider.js +75 -0
  9. package/dist/adapters/types.d.ts +71 -0
  10. package/dist/adapters/types.js +1 -0
  11. package/dist/bitcoin/BitcoinManager.d.ts +15 -0
  12. package/dist/bitcoin/BitcoinManager.js +262 -0
  13. package/dist/bitcoin/BroadcastClient.d.ts +30 -0
  14. package/dist/bitcoin/BroadcastClient.js +35 -0
  15. package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
  16. package/dist/bitcoin/OrdinalsClient.js +105 -0
  17. package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
  18. package/dist/bitcoin/PSBTBuilder.js +80 -0
  19. package/dist/bitcoin/fee-calculation.d.ts +14 -0
  20. package/dist/bitcoin/fee-calculation.js +31 -0
  21. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
  22. package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
  23. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
  24. package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
  25. package/dist/bitcoin/providers/types.d.ts +63 -0
  26. package/dist/bitcoin/providers/types.js +1 -0
  27. package/dist/bitcoin/transactions/commit.d.ts +89 -0
  28. package/dist/bitcoin/transactions/commit.js +311 -0
  29. package/dist/bitcoin/transactions/index.d.ts +7 -0
  30. package/dist/bitcoin/transactions/index.js +8 -0
  31. package/dist/bitcoin/transfer.d.ts +9 -0
  32. package/dist/bitcoin/transfer.js +26 -0
  33. package/dist/bitcoin/utxo-selection.d.ts +78 -0
  34. package/dist/bitcoin/utxo-selection.js +237 -0
  35. package/dist/bitcoin/utxo.d.ts +26 -0
  36. package/dist/bitcoin/utxo.js +78 -0
  37. package/dist/contexts/credentials-v1.json +195 -0
  38. package/dist/contexts/credentials-v2-examples.json +5 -0
  39. package/dist/contexts/credentials-v2.json +301 -0
  40. package/dist/contexts/credentials.json +195 -0
  41. package/dist/contexts/data-integrity-v2.json +81 -0
  42. package/dist/contexts/dids.json +57 -0
  43. package/dist/contexts/ed255192020.json +93 -0
  44. package/dist/contexts/ordinals-plus.json +23 -0
  45. package/dist/contexts/originals.json +22 -0
  46. package/dist/core/OriginalsSDK.d.ts +158 -0
  47. package/dist/core/OriginalsSDK.js +274 -0
  48. package/dist/crypto/Multikey.d.ts +30 -0
  49. package/dist/crypto/Multikey.js +149 -0
  50. package/dist/crypto/Signer.d.ts +21 -0
  51. package/dist/crypto/Signer.js +196 -0
  52. package/dist/crypto/noble-init.d.ts +18 -0
  53. package/dist/crypto/noble-init.js +106 -0
  54. package/dist/did/BtcoDidResolver.d.ts +57 -0
  55. package/dist/did/BtcoDidResolver.js +166 -0
  56. package/dist/did/DIDManager.d.ts +101 -0
  57. package/dist/did/DIDManager.js +493 -0
  58. package/dist/did/Ed25519Verifier.d.ts +30 -0
  59. package/dist/did/Ed25519Verifier.js +59 -0
  60. package/dist/did/KeyManager.d.ts +17 -0
  61. package/dist/did/KeyManager.js +207 -0
  62. package/dist/did/WebVHManager.d.ts +100 -0
  63. package/dist/did/WebVHManager.js +312 -0
  64. package/dist/did/createBtcoDidDocument.d.ts +10 -0
  65. package/dist/did/createBtcoDidDocument.js +42 -0
  66. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
  67. package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
  68. package/dist/events/EventEmitter.d.ts +115 -0
  69. package/dist/events/EventEmitter.js +198 -0
  70. package/dist/events/index.d.ts +7 -0
  71. package/dist/events/index.js +6 -0
  72. package/dist/events/types.d.ts +286 -0
  73. package/dist/events/types.js +9 -0
  74. package/dist/examples/basic-usage.d.ts +3 -0
  75. package/dist/examples/basic-usage.js +62 -0
  76. package/dist/examples/create-module-original.d.ts +32 -0
  77. package/dist/examples/create-module-original.js +376 -0
  78. package/dist/examples/full-lifecycle-flow.d.ts +56 -0
  79. package/dist/examples/full-lifecycle-flow.js +419 -0
  80. package/dist/examples/run.d.ts +12 -0
  81. package/dist/examples/run.js +51 -0
  82. package/dist/index.d.ts +43 -0
  83. package/dist/index.js +52 -0
  84. package/dist/kinds/KindRegistry.d.ts +76 -0
  85. package/dist/kinds/KindRegistry.js +216 -0
  86. package/dist/kinds/index.d.ts +33 -0
  87. package/dist/kinds/index.js +36 -0
  88. package/dist/kinds/types.d.ts +363 -0
  89. package/dist/kinds/types.js +25 -0
  90. package/dist/kinds/validators/AgentValidator.d.ts +14 -0
  91. package/dist/kinds/validators/AgentValidator.js +155 -0
  92. package/dist/kinds/validators/AppValidator.d.ts +14 -0
  93. package/dist/kinds/validators/AppValidator.js +135 -0
  94. package/dist/kinds/validators/DatasetValidator.d.ts +14 -0
  95. package/dist/kinds/validators/DatasetValidator.js +148 -0
  96. package/dist/kinds/validators/DocumentValidator.d.ts +14 -0
  97. package/dist/kinds/validators/DocumentValidator.js +180 -0
  98. package/dist/kinds/validators/MediaValidator.d.ts +14 -0
  99. package/dist/kinds/validators/MediaValidator.js +172 -0
  100. package/dist/kinds/validators/ModuleValidator.d.ts +14 -0
  101. package/dist/kinds/validators/ModuleValidator.js +140 -0
  102. package/dist/kinds/validators/base.d.ts +96 -0
  103. package/dist/kinds/validators/base.js +218 -0
  104. package/dist/kinds/validators/index.d.ts +10 -0
  105. package/dist/kinds/validators/index.js +10 -0
  106. package/dist/lifecycle/BatchOperations.d.ts +147 -0
  107. package/dist/lifecycle/BatchOperations.js +251 -0
  108. package/dist/lifecycle/LifecycleManager.d.ts +362 -0
  109. package/dist/lifecycle/LifecycleManager.js +1692 -0
  110. package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
  111. package/dist/lifecycle/OriginalsAsset.js +380 -0
  112. package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
  113. package/dist/lifecycle/ProvenanceQuery.js +220 -0
  114. package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
  115. package/dist/lifecycle/ResourceVersioning.js +127 -0
  116. package/dist/migration/MigrationManager.d.ts +86 -0
  117. package/dist/migration/MigrationManager.js +412 -0
  118. package/dist/migration/audit/AuditLogger.d.ts +51 -0
  119. package/dist/migration/audit/AuditLogger.js +156 -0
  120. package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
  121. package/dist/migration/checkpoint/CheckpointManager.js +96 -0
  122. package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
  123. package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
  124. package/dist/migration/index.d.ts +22 -0
  125. package/dist/migration/index.js +27 -0
  126. package/dist/migration/operations/BaseMigration.d.ts +48 -0
  127. package/dist/migration/operations/BaseMigration.js +83 -0
  128. package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
  129. package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
  130. package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
  131. package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
  132. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
  133. package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
  134. package/dist/migration/rollback/RollbackManager.d.ts +29 -0
  135. package/dist/migration/rollback/RollbackManager.js +146 -0
  136. package/dist/migration/state/StateMachine.d.ts +25 -0
  137. package/dist/migration/state/StateMachine.js +76 -0
  138. package/dist/migration/state/StateTracker.d.ts +36 -0
  139. package/dist/migration/state/StateTracker.js +123 -0
  140. package/dist/migration/types.d.ts +306 -0
  141. package/dist/migration/types.js +33 -0
  142. package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
  143. package/dist/migration/validation/BitcoinValidator.js +83 -0
  144. package/dist/migration/validation/CredentialValidator.d.ts +13 -0
  145. package/dist/migration/validation/CredentialValidator.js +46 -0
  146. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
  147. package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
  148. package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
  149. package/dist/migration/validation/LifecycleValidator.js +52 -0
  150. package/dist/migration/validation/StorageValidator.d.ts +10 -0
  151. package/dist/migration/validation/StorageValidator.js +65 -0
  152. package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
  153. package/dist/migration/validation/ValidationPipeline.js +180 -0
  154. package/dist/resources/ResourceManager.d.ts +231 -0
  155. package/dist/resources/ResourceManager.js +573 -0
  156. package/dist/resources/index.d.ts +11 -0
  157. package/dist/resources/index.js +10 -0
  158. package/dist/resources/types.d.ts +93 -0
  159. package/dist/resources/types.js +80 -0
  160. package/dist/storage/LocalStorageAdapter.d.ts +11 -0
  161. package/dist/storage/LocalStorageAdapter.js +53 -0
  162. package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
  163. package/dist/storage/MemoryStorageAdapter.js +21 -0
  164. package/dist/storage/StorageAdapter.d.ts +16 -0
  165. package/dist/storage/StorageAdapter.js +1 -0
  166. package/dist/storage/index.d.ts +2 -0
  167. package/dist/storage/index.js +2 -0
  168. package/dist/types/bitcoin.d.ts +84 -0
  169. package/dist/types/bitcoin.js +1 -0
  170. package/dist/types/common.d.ts +82 -0
  171. package/dist/types/common.js +1 -0
  172. package/dist/types/credentials.d.ts +75 -0
  173. package/dist/types/credentials.js +1 -0
  174. package/dist/types/did.d.ts +26 -0
  175. package/dist/types/did.js +1 -0
  176. package/dist/types/index.d.ts +5 -0
  177. package/dist/types/index.js +5 -0
  178. package/dist/types/network.d.ts +78 -0
  179. package/dist/types/network.js +145 -0
  180. package/dist/utils/EventLogger.d.ts +71 -0
  181. package/dist/utils/EventLogger.js +232 -0
  182. package/dist/utils/Logger.d.ts +106 -0
  183. package/dist/utils/Logger.js +257 -0
  184. package/dist/utils/MetricsCollector.d.ts +110 -0
  185. package/dist/utils/MetricsCollector.js +264 -0
  186. package/dist/utils/bitcoin-address.d.ts +38 -0
  187. package/dist/utils/bitcoin-address.js +113 -0
  188. package/dist/utils/cbor.d.ts +2 -0
  189. package/dist/utils/cbor.js +9 -0
  190. package/dist/utils/encoding.d.ts +37 -0
  191. package/dist/utils/encoding.js +120 -0
  192. package/dist/utils/hash.d.ts +1 -0
  193. package/dist/utils/hash.js +5 -0
  194. package/dist/utils/retry.d.ts +10 -0
  195. package/dist/utils/retry.js +35 -0
  196. package/dist/utils/satoshi-validation.d.ts +60 -0
  197. package/dist/utils/satoshi-validation.js +156 -0
  198. package/dist/utils/serialization.d.ts +14 -0
  199. package/dist/utils/serialization.js +76 -0
  200. package/dist/utils/telemetry.d.ts +17 -0
  201. package/dist/utils/telemetry.js +24 -0
  202. package/dist/utils/validation.d.ts +5 -0
  203. package/dist/utils/validation.js +98 -0
  204. package/dist/vc/CredentialManager.d.ts +329 -0
  205. package/dist/vc/CredentialManager.js +615 -0
  206. package/dist/vc/Issuer.d.ts +27 -0
  207. package/dist/vc/Issuer.js +70 -0
  208. package/dist/vc/Verifier.d.ts +16 -0
  209. package/dist/vc/Verifier.js +50 -0
  210. package/dist/vc/cryptosuites/bbs.d.ts +44 -0
  211. package/dist/vc/cryptosuites/bbs.js +213 -0
  212. package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
  213. package/dist/vc/cryptosuites/bbsSimple.js +12 -0
  214. package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
  215. package/dist/vc/cryptosuites/eddsa.js +81 -0
  216. package/dist/vc/documentLoader.d.ts +16 -0
  217. package/dist/vc/documentLoader.js +59 -0
  218. package/dist/vc/proofs/data-integrity.d.ts +21 -0
  219. package/dist/vc/proofs/data-integrity.js +15 -0
  220. package/dist/vc/utils/jsonld.d.ts +2 -0
  221. package/dist/vc/utils/jsonld.js +15 -0
  222. package/package.json +2 -1
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Kind validators exports
3
+ */
4
+ export { BaseKindValidator, ValidationUtils } from './base';
5
+ export { AppValidator } from './AppValidator';
6
+ export { AgentValidator } from './AgentValidator';
7
+ export { ModuleValidator } from './ModuleValidator';
8
+ export { DatasetValidator } from './DatasetValidator';
9
+ export { MediaValidator } from './MediaValidator';
10
+ export { DocumentValidator } from './DocumentValidator';
@@ -0,0 +1,147 @@
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
+ * Result of a batch operation containing successful and failed items
13
+ */
14
+ export interface BatchResult<T> {
15
+ successful: Array<{
16
+ index: number;
17
+ result: T;
18
+ duration: number;
19
+ }>;
20
+ failed: Array<{
21
+ index: number;
22
+ error: Error;
23
+ duration: number;
24
+ retryAttempts?: number;
25
+ }>;
26
+ totalProcessed: number;
27
+ totalDuration: number;
28
+ batchId: string;
29
+ startedAt: string;
30
+ completedAt: string;
31
+ }
32
+ /**
33
+ * Options for configuring batch operation execution
34
+ */
35
+ export interface BatchOperationOptions {
36
+ continueOnError?: boolean;
37
+ maxConcurrent?: number;
38
+ retryCount?: number;
39
+ retryDelay?: number;
40
+ timeoutMs?: number;
41
+ validateFirst?: boolean;
42
+ }
43
+ /**
44
+ * Options for batch inscription operations with Bitcoin-specific settings
45
+ */
46
+ export interface BatchInscriptionOptions extends BatchOperationOptions {
47
+ singleTransaction?: boolean;
48
+ feeRate?: number;
49
+ }
50
+ /**
51
+ * Error thrown when a batch operation fails
52
+ */
53
+ export declare class BatchError extends Error {
54
+ batchId: string;
55
+ operation: string;
56
+ partialResults: {
57
+ successful: number;
58
+ failed: number;
59
+ };
60
+ constructor(batchId: string, operation: string, partialResults: {
61
+ successful: number;
62
+ failed: number;
63
+ }, message: string);
64
+ }
65
+ /**
66
+ * Result of a single-transaction batch inscription with cost analysis
67
+ */
68
+ export interface BatchInscriptionResult<T> {
69
+ batchTransactionId: string;
70
+ individualInscriptionIds: string[];
71
+ assets: T[];
72
+ totalFee: number;
73
+ feePerAsset: number[];
74
+ feeSavings: {
75
+ batchFee: number;
76
+ individualFees: number;
77
+ savings: number;
78
+ savingsPercentage: number;
79
+ };
80
+ batchId: string;
81
+ processingTime: number;
82
+ }
83
+ /**
84
+ * Executor for batch operations with configurable options
85
+ */
86
+ export declare class BatchOperationExecutor {
87
+ private defaultOptions;
88
+ constructor(defaultOptions?: BatchOperationOptions);
89
+ /**
90
+ * Execute a batch operation on multiple items
91
+ *
92
+ * @param items - Array of items to process
93
+ * @param operation - Function to execute on each item
94
+ * @param options - Batch operation options
95
+ * @param predeterminedBatchId - Optional pre-generated batch ID for event correlation
96
+ * @returns BatchResult with successful and failed operations
97
+ */
98
+ execute<T, R>(items: T[], operation: (item: T, index: number) => Promise<R>, options?: BatchOperationOptions, predeterminedBatchId?: string): Promise<BatchResult<R>>;
99
+ /**
100
+ * Generate unique batch ID
101
+ */
102
+ generateBatchId(): string;
103
+ /**
104
+ * Calculate retry delay with exponential backoff
105
+ */
106
+ private calculateRetryDelay;
107
+ /**
108
+ * Execute operation with timeout
109
+ */
110
+ private executeWithTimeout;
111
+ /**
112
+ * Sleep for specified milliseconds
113
+ */
114
+ private sleep;
115
+ /**
116
+ * Chunk array into smaller arrays of specified size
117
+ */
118
+ private chunkArray;
119
+ }
120
+ /**
121
+ * Validation result for batch operations
122
+ */
123
+ export interface ValidationResult {
124
+ isValid: boolean;
125
+ errors: string[];
126
+ warnings?: string[];
127
+ }
128
+ /**
129
+ * Validator for batch operations
130
+ */
131
+ export declare class BatchValidator {
132
+ /**
133
+ * Validate batch of resources for asset creation
134
+ */
135
+ validateBatchCreate(resourcesList: any[][]): ValidationResult[];
136
+ /**
137
+ * Validate batch of assets for inscription
138
+ */
139
+ validateBatchInscription(assets: any[]): ValidationResult[];
140
+ /**
141
+ * Validate batch of transfer operations
142
+ */
143
+ validateBatchTransfer(transfers: Array<{
144
+ asset: any;
145
+ to: string;
146
+ }>): ValidationResult[];
147
+ }
@@ -0,0 +1,251 @@
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
+ import { randomBytes, bytesToHex } from '@noble/hashes/utils.js';
12
+ /**
13
+ * Error thrown when a batch operation fails
14
+ */
15
+ export class BatchError extends Error {
16
+ constructor(batchId, operation, partialResults, message) {
17
+ super(message);
18
+ this.batchId = batchId;
19
+ this.operation = operation;
20
+ this.partialResults = partialResults;
21
+ this.name = 'BatchError';
22
+ }
23
+ }
24
+ /**
25
+ * Executor for batch operations with configurable options
26
+ */
27
+ export class BatchOperationExecutor {
28
+ constructor(defaultOptions = {}) {
29
+ this.defaultOptions = defaultOptions;
30
+ }
31
+ /**
32
+ * Execute a batch operation on multiple items
33
+ *
34
+ * @param items - Array of items to process
35
+ * @param operation - Function to execute on each item
36
+ * @param options - Batch operation options
37
+ * @param predeterminedBatchId - Optional pre-generated batch ID for event correlation
38
+ * @returns BatchResult with successful and failed operations
39
+ */
40
+ async execute(items, operation, options, predeterminedBatchId) {
41
+ const opts = { ...this.defaultOptions, ...options };
42
+ const { continueOnError = false, maxConcurrent = 1, retryCount = 0, retryDelay = 1000, timeoutMs = 30000 } = opts;
43
+ const batchId = predeterminedBatchId || this.generateBatchId();
44
+ const startedAt = new Date().toISOString();
45
+ const startTime = Date.now();
46
+ const successful = [];
47
+ const failed = [];
48
+ // Process items with concurrency control
49
+ const processItem = async (item, index) => {
50
+ const itemStartTime = Date.now();
51
+ let lastError = null;
52
+ let attempts = 0;
53
+ for (let attempt = 0; attempt <= retryCount; attempt++) {
54
+ attempts = attempt + 1;
55
+ try {
56
+ // Execute with timeout
57
+ const result = await this.executeWithTimeout(() => operation(item, index), timeoutMs);
58
+ const duration = Date.now() - itemStartTime;
59
+ successful.push({ index, result, duration });
60
+ return;
61
+ }
62
+ catch (error) {
63
+ lastError = error instanceof Error ? error : new Error(String(error));
64
+ // If not last attempt, wait with exponential backoff
65
+ if (attempt < retryCount) {
66
+ const delay = this.calculateRetryDelay(attempt, retryDelay);
67
+ await this.sleep(delay);
68
+ }
69
+ }
70
+ }
71
+ // All retries failed
72
+ const duration = Date.now() - itemStartTime;
73
+ failed.push({
74
+ index,
75
+ error: lastError,
76
+ duration,
77
+ retryAttempts: attempts - 1
78
+ });
79
+ // If fail-fast mode, throw error
80
+ if (!continueOnError) {
81
+ throw lastError;
82
+ }
83
+ };
84
+ // Process items in batches based on maxConcurrent
85
+ try {
86
+ if (maxConcurrent === 1) {
87
+ // Sequential processing
88
+ for (let i = 0; i < items.length; i++) {
89
+ await processItem(items[i], i);
90
+ }
91
+ }
92
+ else {
93
+ // Concurrent processing with limit
94
+ const chunks = this.chunkArray(items, maxConcurrent);
95
+ for (const chunk of chunks) {
96
+ await Promise.all(chunk.map((item, chunkIndex) => {
97
+ const globalIndex = chunks.slice(0, chunks.indexOf(chunk))
98
+ .reduce((acc, c) => acc + c.length, 0) + chunkIndex;
99
+ return processItem(item, globalIndex);
100
+ }));
101
+ }
102
+ }
103
+ }
104
+ catch (error) {
105
+ // In fail-fast mode, re-throw the error so callers can handle it
106
+ if (!continueOnError) {
107
+ throw error instanceof Error ? error : new Error(String(error));
108
+ }
109
+ // In continue-on-error mode, the error was already logged in processItem
110
+ // and we'll return the partial results below
111
+ }
112
+ const totalDuration = Date.now() - startTime;
113
+ const completedAt = new Date().toISOString();
114
+ return {
115
+ successful,
116
+ failed,
117
+ totalProcessed: successful.length + failed.length,
118
+ totalDuration,
119
+ batchId,
120
+ startedAt,
121
+ completedAt
122
+ };
123
+ }
124
+ /**
125
+ * Generate unique batch ID
126
+ */
127
+ generateBatchId() {
128
+ return `batch_${Date.now()}_${bytesToHex(randomBytes(8))}`;
129
+ }
130
+ /**
131
+ * Calculate retry delay with exponential backoff
132
+ */
133
+ calculateRetryDelay(attempt, baseDelay) {
134
+ // Exponential backoff: baseDelay * 2^attempt
135
+ return baseDelay * Math.pow(2, attempt);
136
+ }
137
+ /**
138
+ * Execute operation with timeout
139
+ */
140
+ async executeWithTimeout(operation, timeoutMs) {
141
+ return Promise.race([
142
+ operation(),
143
+ new Promise((_, reject) => setTimeout(() => reject(new Error(`Operation timeout after ${timeoutMs}ms`)), timeoutMs))
144
+ ]);
145
+ }
146
+ /**
147
+ * Sleep for specified milliseconds
148
+ */
149
+ sleep(ms) {
150
+ return new Promise(resolve => setTimeout(resolve, ms));
151
+ }
152
+ /**
153
+ * Chunk array into smaller arrays of specified size
154
+ */
155
+ chunkArray(array, size) {
156
+ const chunks = [];
157
+ for (let i = 0; i < array.length; i += size) {
158
+ chunks.push(array.slice(i, i + size));
159
+ }
160
+ return chunks;
161
+ }
162
+ }
163
+ /**
164
+ * Validator for batch operations
165
+ */
166
+ export class BatchValidator {
167
+ /**
168
+ * Validate batch of resources for asset creation
169
+ */
170
+ validateBatchCreate(resourcesList) {
171
+ return resourcesList.map((resources, index) => {
172
+ const errors = [];
173
+ if (!Array.isArray(resources)) {
174
+ errors.push(`Item ${index}: Resources must be an array`);
175
+ return { isValid: false, errors };
176
+ }
177
+ if (resources.length === 0) {
178
+ errors.push(`Item ${index}: At least one resource is required`);
179
+ return { isValid: false, errors };
180
+ }
181
+ // Validate each resource
182
+ for (let i = 0; i < resources.length; i++) {
183
+ const resource = resources[i];
184
+ if (!resource || typeof resource !== 'object') {
185
+ errors.push(`Item ${index}, resource ${i}: Invalid resource object`);
186
+ continue;
187
+ }
188
+ if (!resource.id || typeof resource.id !== 'string') {
189
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid id`);
190
+ }
191
+ if (!resource.type || typeof resource.type !== 'string') {
192
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid type`);
193
+ }
194
+ if (!resource.contentType || typeof resource.contentType !== 'string') {
195
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid contentType`);
196
+ }
197
+ if (!resource.hash || typeof resource.hash !== 'string' || !/^[0-9a-fA-F]+$/.test(resource.hash)) {
198
+ errors.push(`Item ${index}, resource ${i}: Missing or invalid hash`);
199
+ }
200
+ }
201
+ return { isValid: errors.length === 0, errors };
202
+ });
203
+ }
204
+ /**
205
+ * Validate batch of assets for inscription
206
+ */
207
+ validateBatchInscription(assets) {
208
+ return assets.map((asset, index) => {
209
+ const errors = [];
210
+ if (!asset || typeof asset !== 'object') {
211
+ errors.push(`Item ${index}: Invalid asset object`);
212
+ return { isValid: false, errors };
213
+ }
214
+ if (!asset.id || typeof asset.id !== 'string') {
215
+ errors.push(`Item ${index}: Missing or invalid asset id`);
216
+ }
217
+ if (!asset.currentLayer) {
218
+ errors.push(`Item ${index}: Missing currentLayer`);
219
+ }
220
+ else if (asset.currentLayer === 'did:btco') {
221
+ errors.push(`Item ${index}: Asset already inscribed on Bitcoin`);
222
+ }
223
+ if (!asset.resources || !Array.isArray(asset.resources) || asset.resources.length === 0) {
224
+ errors.push(`Item ${index}: Asset must have at least one resource`);
225
+ }
226
+ return { isValid: errors.length === 0, errors };
227
+ });
228
+ }
229
+ /**
230
+ * Validate batch of transfer operations
231
+ */
232
+ validateBatchTransfer(transfers) {
233
+ return transfers.map((transfer, index) => {
234
+ const errors = [];
235
+ if (!transfer || typeof transfer !== 'object') {
236
+ errors.push(`Item ${index}: Invalid transfer object`);
237
+ return { isValid: false, errors };
238
+ }
239
+ if (!transfer.asset || typeof transfer.asset !== 'object') {
240
+ errors.push(`Item ${index}: Invalid asset`);
241
+ }
242
+ else if (transfer.asset.currentLayer !== 'did:btco') {
243
+ errors.push(`Item ${index}: Asset must be inscribed on Bitcoin before transfer`);
244
+ }
245
+ if (!transfer.to || typeof transfer.to !== 'string') {
246
+ errors.push(`Item ${index}: Invalid destination address`);
247
+ }
248
+ return { isValid: errors.length === 0, errors };
249
+ });
250
+ }
251
+ }