@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,362 @@
1
+ import { OriginalsConfig, AssetResource, BitcoinTransaction, KeyStore, ExternalSigner, LayerType } from '../types';
2
+ import { BitcoinManager } from '../bitcoin/BitcoinManager';
3
+ import { DIDManager } from '../did/DIDManager';
4
+ import { CredentialManager } from '../vc/CredentialManager';
5
+ import { OriginalsAsset } from './OriginalsAsset';
6
+ import type { EventHandler, EventTypeMap } from '../events/types';
7
+ import { type BatchResult, type BatchOperationOptions, type BatchInscriptionOptions } from './BatchOperations';
8
+ import { type OriginalKind, type OriginalManifest, type CreateTypedOriginalOptions } from '../kinds';
9
+ /**
10
+ * Cost estimation result for migration operations
11
+ */
12
+ export interface CostEstimate {
13
+ /** Total estimated cost in satoshis */
14
+ totalSats: number;
15
+ /** Breakdown of costs */
16
+ breakdown: {
17
+ /** Network fee in satoshis */
18
+ networkFee: number;
19
+ /** Data cost for inscription (sat/vB * size) */
20
+ dataCost: number;
21
+ /** Dust output value */
22
+ dustValue: number;
23
+ };
24
+ /** Fee rate used for estimation (sat/vB) */
25
+ feeRate: number;
26
+ /** Data size in bytes */
27
+ dataSize: number;
28
+ /** Target layer for the migration */
29
+ targetLayer: LayerType;
30
+ /** Confidence level of estimate */
31
+ confidence: 'low' | 'medium' | 'high';
32
+ }
33
+ /**
34
+ * Migration validation result
35
+ */
36
+ export interface MigrationValidation {
37
+ /** Whether the migration is valid */
38
+ valid: boolean;
39
+ /** List of validation errors */
40
+ errors: string[];
41
+ /** List of warnings (non-blocking) */
42
+ warnings: string[];
43
+ /** Current layer of the asset */
44
+ currentLayer: LayerType;
45
+ /** Target layer for migration */
46
+ targetLayer: LayerType;
47
+ /** Checks performed */
48
+ checks: {
49
+ layerTransition: boolean;
50
+ resourcesValid: boolean;
51
+ credentialsValid: boolean;
52
+ didDocumentValid: boolean;
53
+ bitcoinReadiness?: boolean;
54
+ };
55
+ }
56
+ /**
57
+ * Progress callback for long-running operations
58
+ */
59
+ export type ProgressCallback = (progress: LifecycleProgress) => void;
60
+ /**
61
+ * Progress information for lifecycle operations
62
+ */
63
+ export interface LifecycleProgress {
64
+ /** Current operation phase */
65
+ phase: 'preparing' | 'validating' | 'processing' | 'committing' | 'confirming' | 'complete' | 'failed';
66
+ /** Progress percentage (0-100) */
67
+ percentage: number;
68
+ /** Human-readable message */
69
+ message: string;
70
+ /** Current operation details */
71
+ details?: {
72
+ currentStep?: number;
73
+ totalSteps?: number;
74
+ transactionId?: string;
75
+ confirmations?: number;
76
+ };
77
+ }
78
+ /**
79
+ * Options for lifecycle operations with progress tracking
80
+ */
81
+ export interface LifecycleOperationOptions {
82
+ /** Fee rate for Bitcoin operations (sat/vB) */
83
+ feeRate?: number;
84
+ /** Progress callback for operation updates */
85
+ onProgress?: ProgressCallback;
86
+ /** Enable atomic rollback on failure (default: true) */
87
+ atomicRollback?: boolean;
88
+ }
89
+ export declare class LifecycleManager {
90
+ private config;
91
+ private didManager;
92
+ private credentialManager;
93
+ private deps?;
94
+ private keyStore?;
95
+ private eventEmitter;
96
+ private batchExecutor;
97
+ private batchValidator;
98
+ private logger;
99
+ private metrics;
100
+ constructor(config: OriginalsConfig, didManager: DIDManager, credentialManager: CredentialManager, deps?: {
101
+ bitcoinManager?: BitcoinManager;
102
+ } | undefined, keyStore?: KeyStore | undefined);
103
+ /**
104
+ * Subscribe to a lifecycle event
105
+ * @param eventType - The type of event to subscribe to
106
+ * @param handler - The handler function to call when the event is emitted
107
+ * @returns A function to unsubscribe from the event
108
+ */
109
+ on<K extends keyof EventTypeMap>(eventType: K, handler: EventHandler<EventTypeMap[K]>): () => void;
110
+ /**
111
+ * Subscribe to a lifecycle event once
112
+ * @param eventType - The type of event to subscribe to
113
+ * @param handler - The handler function to call when the event is emitted (will only fire once)
114
+ * @returns A function to unsubscribe from the event
115
+ */
116
+ once<K extends keyof EventTypeMap>(eventType: K, handler: EventHandler<EventTypeMap[K]>): () => void;
117
+ /**
118
+ * Unsubscribe from a lifecycle event
119
+ * @param eventType - The type of event to unsubscribe from
120
+ * @param handler - The handler function to remove
121
+ */
122
+ off<K extends keyof EventTypeMap>(eventType: K, handler: EventHandler<EventTypeMap[K]>): void;
123
+ registerKey(verificationMethodId: string, privateKey: string): Promise<void>;
124
+ createAsset(resources: AssetResource[]): Promise<OriginalsAsset>;
125
+ /**
126
+ * Create a typed Original with kind-specific validation
127
+ *
128
+ * This is the recommended way to create Originals with proper typing and validation.
129
+ * Each kind (App, Agent, Module, Dataset, Media, Document) has specific metadata
130
+ * requirements that are validated before creation.
131
+ *
132
+ * @param kind - The kind of Original to create
133
+ * @param manifest - The manifest containing name, version, resources, and kind-specific metadata
134
+ * @param options - Optional creation options (skipValidation, strictMode)
135
+ * @returns The created OriginalsAsset
136
+ * @throws Error if validation fails (unless skipValidation is true)
137
+ *
138
+ * @example
139
+ * ```typescript
140
+ * // Create a Module Original
141
+ * const moduleAsset = await sdk.lifecycle.createTypedOriginal(
142
+ * OriginalKind.Module,
143
+ * {
144
+ * kind: OriginalKind.Module,
145
+ * name: 'my-utility',
146
+ * version: '1.0.0',
147
+ * resources: [{ id: 'index.js', type: 'code', hash: '...', contentType: 'application/javascript' }],
148
+ * metadata: {
149
+ * format: 'esm',
150
+ * main: 'index.js',
151
+ * }
152
+ * }
153
+ * );
154
+ * ```
155
+ */
156
+ createTypedOriginal<K extends OriginalKind>(kind: K, manifest: OriginalManifest<K>, options?: CreateTypedOriginalOptions): Promise<OriginalsAsset>;
157
+ /**
158
+ * Get the manifest from a typed Original asset
159
+ * Returns undefined if the asset was not created with createTypedOriginal
160
+ *
161
+ * @param asset - The OriginalsAsset to get manifest from
162
+ * @returns The manifest or undefined
163
+ */
164
+ getManifest<K extends OriginalKind>(asset: OriginalsAsset): OriginalManifest<K> | undefined;
165
+ /**
166
+ * Estimate the cost of creating a typed Original
167
+ * Useful for showing users estimated fees before creation
168
+ *
169
+ * @param manifest - The manifest to estimate
170
+ * @param targetLayer - The target layer (did:webvh or did:btco)
171
+ * @param feeRate - Optional fee rate override (sat/vB)
172
+ * @returns Cost estimate including fees
173
+ */
174
+ estimateTypedOriginalCost<K extends OriginalKind>(manifest: OriginalManifest<K>, targetLayer: LayerType, feeRate?: number): Promise<CostEstimate>;
175
+ publishToWeb(asset: OriginalsAsset, publisherDidOrSigner: string | ExternalSigner): Promise<OriginalsAsset>;
176
+ private extractPublisherInfo;
177
+ private parseWebVHDid;
178
+ private publishResources;
179
+ private emitResourcePublishedEvent;
180
+ private issuePublicationCredential;
181
+ private signWithKeyStore;
182
+ inscribeOnBitcoin(asset: OriginalsAsset, feeRate?: number): Promise<OriginalsAsset>;
183
+ transferOwnership(asset: OriginalsAsset, newOwner: string): Promise<BitcoinTransaction>;
184
+ /**
185
+ * Create multiple assets in batch
186
+ *
187
+ * @param resourcesList - Array of resource arrays, one per asset to create
188
+ * @param options - Batch operation options
189
+ * @returns BatchResult with created assets
190
+ */
191
+ batchCreateAssets(resourcesList: AssetResource[][], options?: BatchOperationOptions): Promise<BatchResult<OriginalsAsset>>;
192
+ /**
193
+ * Publish multiple assets to web storage in batch
194
+ *
195
+ * @param assets - Array of assets to publish
196
+ * @param domain - Domain to publish to
197
+ * @param options - Batch operation options
198
+ * @returns BatchResult with published assets
199
+ */
200
+ batchPublishToWeb(assets: OriginalsAsset[], domain: string, options?: BatchOperationOptions): Promise<BatchResult<OriginalsAsset>>;
201
+ /**
202
+ * Inscribe multiple assets on Bitcoin with cost optimization
203
+ * KEY FEATURE: singleTransaction option for 30%+ cost savings
204
+ *
205
+ * @param assets - Array of assets to inscribe
206
+ * @param options - Batch inscription options
207
+ * @returns BatchResult with inscribed assets
208
+ */
209
+ batchInscribeOnBitcoin(assets: OriginalsAsset[], options?: BatchInscriptionOptions): Promise<BatchResult<OriginalsAsset>>;
210
+ /**
211
+ * CORE INNOVATION: Single-transaction batch inscription
212
+ * Combines multiple assets into one Bitcoin transaction for 30%+ cost savings
213
+ *
214
+ * @param assets - Array of assets to inscribe
215
+ * @param options - Batch inscription options
216
+ * @returns BatchResult with inscribed assets and cost savings data
217
+ */
218
+ private batchInscribeSingleTransaction;
219
+ /**
220
+ * Individual transaction batch inscription (fallback mode)
221
+ * Each asset is inscribed in its own transaction
222
+ *
223
+ * @param assets - Array of assets to inscribe
224
+ * @param options - Batch inscription options
225
+ * @returns BatchResult with inscribed assets
226
+ */
227
+ private batchInscribeIndividualTransactions;
228
+ /**
229
+ * Transfer ownership of multiple assets in batch
230
+ *
231
+ * @param transfers - Array of transfer operations
232
+ * @param options - Batch operation options
233
+ * @returns BatchResult with transaction results
234
+ */
235
+ batchTransferOwnership(transfers: Array<{
236
+ asset: OriginalsAsset;
237
+ to: string;
238
+ }>, options?: BatchOperationOptions): Promise<BatchResult<BitcoinTransaction>>;
239
+ /**
240
+ * Calculate total data size for all assets in a batch
241
+ */
242
+ private calculateTotalDataSize;
243
+ /**
244
+ * Estimate cost savings from batch inscription vs individual inscriptions
245
+ */
246
+ private estimateBatchSavings;
247
+ /**
248
+ * Create a draft asset (did:peer layer)
249
+ *
250
+ * This is the entry point for creating new Originals. Draft assets are
251
+ * stored locally and can be published or inscribed later.
252
+ *
253
+ * @param resources - Array of resources to include in the asset
254
+ * @param options - Optional configuration including progress callback
255
+ * @returns The newly created OriginalsAsset in did:peer layer
256
+ *
257
+ * @example
258
+ * ```typescript
259
+ * const draft = await sdk.lifecycle.createDraft([
260
+ * { id: 'main', type: 'code', contentType: 'text/javascript', hash: '...' }
261
+ * ], {
262
+ * onProgress: (p) => console.log(p.message)
263
+ * });
264
+ * ```
265
+ */
266
+ createDraft(resources: AssetResource[], options?: LifecycleOperationOptions): Promise<OriginalsAsset>;
267
+ /**
268
+ * Publish an asset to the web (did:webvh layer)
269
+ *
270
+ * Migrates a draft asset from did:peer to did:webvh, making it publicly
271
+ * discoverable via HTTPS.
272
+ *
273
+ * @param asset - The asset to publish (must be in did:peer layer)
274
+ * @param publisherDidOrSigner - Publisher's DID or external signer
275
+ * @param options - Optional configuration including progress callback
276
+ * @returns The published OriginalsAsset in did:webvh layer
277
+ *
278
+ * @example
279
+ * ```typescript
280
+ * const published = await sdk.lifecycle.publish(draft, 'did:webvh:example.com:user');
281
+ * ```
282
+ */
283
+ publish(asset: OriginalsAsset, publisherDidOrSigner: string | ExternalSigner, options?: LifecycleOperationOptions): Promise<OriginalsAsset>;
284
+ /**
285
+ * Inscribe an asset on Bitcoin (did:btco layer)
286
+ *
287
+ * Permanently anchors an asset on the Bitcoin blockchain via Ordinals inscription.
288
+ * This is an irreversible operation.
289
+ *
290
+ * @param asset - The asset to inscribe (must be in did:peer or did:webvh layer)
291
+ * @param options - Optional configuration including fee rate and progress callback
292
+ * @returns The inscribed OriginalsAsset in did:btco layer
293
+ *
294
+ * @example
295
+ * ```typescript
296
+ * const inscribed = await sdk.lifecycle.inscribe(published, {
297
+ * feeRate: 15,
298
+ * onProgress: (p) => console.log(`${p.percentage}%: ${p.message}`)
299
+ * });
300
+ * ```
301
+ */
302
+ inscribe(asset: OriginalsAsset, options?: LifecycleOperationOptions): Promise<OriginalsAsset>;
303
+ /**
304
+ * Transfer ownership of a Bitcoin-inscribed asset
305
+ *
306
+ * Transfers an inscribed asset to a new owner. Only works for assets
307
+ * in the did:btco layer.
308
+ *
309
+ * @param asset - The asset to transfer (must be in did:btco layer)
310
+ * @param newOwnerAddress - Bitcoin address of the new owner
311
+ * @param options - Optional configuration including progress callback
312
+ * @returns The Bitcoin transaction for the transfer
313
+ *
314
+ * @example
315
+ * ```typescript
316
+ * const tx = await sdk.lifecycle.transfer(inscribed, 'bc1q...newowner');
317
+ * console.log('Transfer txid:', tx.txid);
318
+ * ```
319
+ */
320
+ transfer(asset: OriginalsAsset, newOwnerAddress: string, options?: LifecycleOperationOptions): Promise<BitcoinTransaction>;
321
+ /**
322
+ * Estimate the cost of migrating an asset to a target layer
323
+ *
324
+ * Returns a detailed breakdown of expected costs for Bitcoin operations.
325
+ * For did:webvh migrations, costs are minimal (only hosting).
326
+ *
327
+ * @param asset - The asset to estimate costs for
328
+ * @param targetLayer - The target layer for migration
329
+ * @param feeRate - Optional fee rate override (sat/vB)
330
+ * @returns Detailed cost estimate
331
+ *
332
+ * @example
333
+ * ```typescript
334
+ * const cost = await sdk.lifecycle.estimateCost(draft, 'did:btco', 10);
335
+ * console.log(`Estimated cost: ${cost.totalSats} sats`);
336
+ * ```
337
+ */
338
+ estimateCost(asset: OriginalsAsset, targetLayer: LayerType, feeRate?: number): Promise<CostEstimate>;
339
+ /**
340
+ * Validate whether an asset can be migrated to a target layer
341
+ *
342
+ * Performs comprehensive pre-flight checks including:
343
+ * - Valid layer transition
344
+ * - Resource integrity
345
+ * - Credential validity
346
+ * - DID document structure
347
+ * - Bitcoin readiness (for did:btco)
348
+ *
349
+ * @param asset - The asset to validate
350
+ * @param targetLayer - The target layer for migration
351
+ * @returns Detailed validation result
352
+ *
353
+ * @example
354
+ * ```typescript
355
+ * const validation = await sdk.lifecycle.validateMigration(draft, 'did:webvh');
356
+ * if (!validation.valid) {
357
+ * console.error('Cannot migrate:', validation.errors);
358
+ * }
359
+ * ```
360
+ */
361
+ validateMigration(asset: OriginalsAsset, targetLayer: LayerType): Promise<MigrationValidation>;
362
+ }