@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.
- package/dist/adapters/FeeOracleMock.d.ts +6 -0
- package/dist/adapters/FeeOracleMock.js +8 -0
- package/dist/adapters/index.d.ts +4 -0
- package/dist/adapters/index.js +4 -0
- package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
- package/dist/adapters/providers/OrdHttpProvider.js +110 -0
- package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
- package/dist/adapters/providers/OrdMockProvider.js +75 -0
- package/dist/adapters/types.d.ts +71 -0
- package/dist/adapters/types.js +1 -0
- package/dist/bitcoin/BitcoinManager.d.ts +15 -0
- package/dist/bitcoin/BitcoinManager.js +262 -0
- package/dist/bitcoin/BroadcastClient.d.ts +30 -0
- package/dist/bitcoin/BroadcastClient.js +35 -0
- package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
- package/dist/bitcoin/OrdinalsClient.js +105 -0
- package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
- package/dist/bitcoin/PSBTBuilder.js +80 -0
- package/dist/bitcoin/fee-calculation.d.ts +14 -0
- package/dist/bitcoin/fee-calculation.js +31 -0
- package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
- package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
- package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
- package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
- package/dist/bitcoin/providers/types.d.ts +63 -0
- package/dist/bitcoin/providers/types.js +1 -0
- package/dist/bitcoin/transactions/commit.d.ts +89 -0
- package/dist/bitcoin/transactions/commit.js +311 -0
- package/dist/bitcoin/transactions/index.d.ts +7 -0
- package/dist/bitcoin/transactions/index.js +8 -0
- package/dist/bitcoin/transfer.d.ts +9 -0
- package/dist/bitcoin/transfer.js +26 -0
- package/dist/bitcoin/utxo-selection.d.ts +78 -0
- package/dist/bitcoin/utxo-selection.js +237 -0
- package/dist/bitcoin/utxo.d.ts +26 -0
- package/dist/bitcoin/utxo.js +78 -0
- package/dist/contexts/credentials-v1.json +195 -0
- package/dist/contexts/credentials-v2-examples.json +5 -0
- package/dist/contexts/credentials-v2.json +301 -0
- package/dist/contexts/credentials.json +195 -0
- package/dist/contexts/data-integrity-v2.json +81 -0
- package/dist/contexts/dids.json +57 -0
- package/dist/contexts/ed255192020.json +93 -0
- package/dist/contexts/ordinals-plus.json +23 -0
- package/dist/contexts/originals.json +22 -0
- package/dist/core/OriginalsSDK.d.ts +158 -0
- package/dist/core/OriginalsSDK.js +274 -0
- package/dist/crypto/Multikey.d.ts +30 -0
- package/dist/crypto/Multikey.js +149 -0
- package/dist/crypto/Signer.d.ts +21 -0
- package/dist/crypto/Signer.js +196 -0
- package/dist/crypto/noble-init.d.ts +18 -0
- package/dist/crypto/noble-init.js +106 -0
- package/dist/did/BtcoDidResolver.d.ts +57 -0
- package/dist/did/BtcoDidResolver.js +166 -0
- package/dist/did/DIDManager.d.ts +101 -0
- package/dist/did/DIDManager.js +493 -0
- package/dist/did/Ed25519Verifier.d.ts +30 -0
- package/dist/did/Ed25519Verifier.js +59 -0
- package/dist/did/KeyManager.d.ts +17 -0
- package/dist/did/KeyManager.js +207 -0
- package/dist/did/WebVHManager.d.ts +100 -0
- package/dist/did/WebVHManager.js +312 -0
- package/dist/did/createBtcoDidDocument.d.ts +10 -0
- package/dist/did/createBtcoDidDocument.js +42 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
- package/dist/events/EventEmitter.d.ts +115 -0
- package/dist/events/EventEmitter.js +198 -0
- package/dist/events/index.d.ts +7 -0
- package/dist/events/index.js +6 -0
- package/dist/events/types.d.ts +286 -0
- package/dist/events/types.js +9 -0
- package/dist/examples/basic-usage.d.ts +3 -0
- package/dist/examples/basic-usage.js +62 -0
- package/dist/examples/create-module-original.d.ts +32 -0
- package/dist/examples/create-module-original.js +376 -0
- package/dist/examples/full-lifecycle-flow.d.ts +56 -0
- package/dist/examples/full-lifecycle-flow.js +419 -0
- package/dist/examples/run.d.ts +12 -0
- package/dist/examples/run.js +51 -0
- package/dist/index.d.ts +43 -0
- package/dist/index.js +52 -0
- package/dist/kinds/KindRegistry.d.ts +76 -0
- package/dist/kinds/KindRegistry.js +216 -0
- package/dist/kinds/index.d.ts +33 -0
- package/dist/kinds/index.js +36 -0
- package/dist/kinds/types.d.ts +363 -0
- package/dist/kinds/types.js +25 -0
- package/dist/kinds/validators/AgentValidator.d.ts +14 -0
- package/dist/kinds/validators/AgentValidator.js +155 -0
- package/dist/kinds/validators/AppValidator.d.ts +14 -0
- package/dist/kinds/validators/AppValidator.js +135 -0
- package/dist/kinds/validators/DatasetValidator.d.ts +14 -0
- package/dist/kinds/validators/DatasetValidator.js +148 -0
- package/dist/kinds/validators/DocumentValidator.d.ts +14 -0
- package/dist/kinds/validators/DocumentValidator.js +180 -0
- package/dist/kinds/validators/MediaValidator.d.ts +14 -0
- package/dist/kinds/validators/MediaValidator.js +172 -0
- package/dist/kinds/validators/ModuleValidator.d.ts +14 -0
- package/dist/kinds/validators/ModuleValidator.js +140 -0
- package/dist/kinds/validators/base.d.ts +96 -0
- package/dist/kinds/validators/base.js +218 -0
- package/dist/kinds/validators/index.d.ts +10 -0
- package/dist/kinds/validators/index.js +10 -0
- package/dist/lifecycle/BatchOperations.d.ts +147 -0
- package/dist/lifecycle/BatchOperations.js +251 -0
- package/dist/lifecycle/LifecycleManager.d.ts +362 -0
- package/dist/lifecycle/LifecycleManager.js +1692 -0
- package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
- package/dist/lifecycle/OriginalsAsset.js +380 -0
- package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
- package/dist/lifecycle/ProvenanceQuery.js +220 -0
- package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
- package/dist/lifecycle/ResourceVersioning.js +127 -0
- package/dist/migration/MigrationManager.d.ts +86 -0
- package/dist/migration/MigrationManager.js +412 -0
- package/dist/migration/audit/AuditLogger.d.ts +51 -0
- package/dist/migration/audit/AuditLogger.js +156 -0
- package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
- package/dist/migration/checkpoint/CheckpointManager.js +96 -0
- package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
- package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
- package/dist/migration/index.d.ts +22 -0
- package/dist/migration/index.js +27 -0
- package/dist/migration/operations/BaseMigration.d.ts +48 -0
- package/dist/migration/operations/BaseMigration.js +83 -0
- package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
- package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
- package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
- package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
- package/dist/migration/rollback/RollbackManager.d.ts +29 -0
- package/dist/migration/rollback/RollbackManager.js +146 -0
- package/dist/migration/state/StateMachine.d.ts +25 -0
- package/dist/migration/state/StateMachine.js +76 -0
- package/dist/migration/state/StateTracker.d.ts +36 -0
- package/dist/migration/state/StateTracker.js +123 -0
- package/dist/migration/types.d.ts +306 -0
- package/dist/migration/types.js +33 -0
- package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
- package/dist/migration/validation/BitcoinValidator.js +83 -0
- package/dist/migration/validation/CredentialValidator.d.ts +13 -0
- package/dist/migration/validation/CredentialValidator.js +46 -0
- package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
- package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
- package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
- package/dist/migration/validation/LifecycleValidator.js +52 -0
- package/dist/migration/validation/StorageValidator.d.ts +10 -0
- package/dist/migration/validation/StorageValidator.js +65 -0
- package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
- package/dist/migration/validation/ValidationPipeline.js +180 -0
- package/dist/resources/ResourceManager.d.ts +231 -0
- package/dist/resources/ResourceManager.js +573 -0
- package/dist/resources/index.d.ts +11 -0
- package/dist/resources/index.js +10 -0
- package/dist/resources/types.d.ts +93 -0
- package/dist/resources/types.js +80 -0
- package/dist/storage/LocalStorageAdapter.d.ts +11 -0
- package/dist/storage/LocalStorageAdapter.js +53 -0
- package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
- package/dist/storage/MemoryStorageAdapter.js +21 -0
- package/dist/storage/StorageAdapter.d.ts +16 -0
- package/dist/storage/StorageAdapter.js +1 -0
- package/dist/storage/index.d.ts +2 -0
- package/dist/storage/index.js +2 -0
- package/dist/types/bitcoin.d.ts +84 -0
- package/dist/types/bitcoin.js +1 -0
- package/dist/types/common.d.ts +82 -0
- package/dist/types/common.js +1 -0
- package/dist/types/credentials.d.ts +75 -0
- package/dist/types/credentials.js +1 -0
- package/dist/types/did.d.ts +26 -0
- package/dist/types/did.js +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.js +5 -0
- package/dist/types/network.d.ts +78 -0
- package/dist/types/network.js +145 -0
- package/dist/utils/EventLogger.d.ts +71 -0
- package/dist/utils/EventLogger.js +232 -0
- package/dist/utils/Logger.d.ts +106 -0
- package/dist/utils/Logger.js +257 -0
- package/dist/utils/MetricsCollector.d.ts +110 -0
- package/dist/utils/MetricsCollector.js +264 -0
- package/dist/utils/bitcoin-address.d.ts +38 -0
- package/dist/utils/bitcoin-address.js +113 -0
- package/dist/utils/cbor.d.ts +2 -0
- package/dist/utils/cbor.js +9 -0
- package/dist/utils/encoding.d.ts +37 -0
- package/dist/utils/encoding.js +120 -0
- package/dist/utils/hash.d.ts +1 -0
- package/dist/utils/hash.js +5 -0
- package/dist/utils/retry.d.ts +10 -0
- package/dist/utils/retry.js +35 -0
- package/dist/utils/satoshi-validation.d.ts +60 -0
- package/dist/utils/satoshi-validation.js +156 -0
- package/dist/utils/serialization.d.ts +14 -0
- package/dist/utils/serialization.js +76 -0
- package/dist/utils/telemetry.d.ts +17 -0
- package/dist/utils/telemetry.js +24 -0
- package/dist/utils/validation.d.ts +5 -0
- package/dist/utils/validation.js +98 -0
- package/dist/vc/CredentialManager.d.ts +329 -0
- package/dist/vc/CredentialManager.js +615 -0
- package/dist/vc/Issuer.d.ts +27 -0
- package/dist/vc/Issuer.js +70 -0
- package/dist/vc/Verifier.d.ts +16 -0
- package/dist/vc/Verifier.js +50 -0
- package/dist/vc/cryptosuites/bbs.d.ts +44 -0
- package/dist/vc/cryptosuites/bbs.js +213 -0
- package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
- package/dist/vc/cryptosuites/bbsSimple.js +12 -0
- package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
- package/dist/vc/cryptosuites/eddsa.js +81 -0
- package/dist/vc/documentLoader.d.ts +16 -0
- package/dist/vc/documentLoader.js +59 -0
- package/dist/vc/proofs/data-integrity.d.ts +21 -0
- package/dist/vc/proofs/data-integrity.js +15 -0
- package/dist/vc/utils/jsonld.d.ts +2 -0
- package/dist/vc/utils/jsonld.js +15 -0
- 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
|
+
}
|