@originals/sdk 1.8.2 → 1.8.3

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 (144) hide show
  1. package/package.json +5 -6
  2. package/src/adapters/FeeOracleMock.ts +0 -9
  3. package/src/adapters/index.ts +0 -5
  4. package/src/adapters/providers/OrdHttpProvider.ts +0 -126
  5. package/src/adapters/providers/OrdMockProvider.ts +0 -101
  6. package/src/adapters/types.ts +0 -66
  7. package/src/bitcoin/BitcoinManager.ts +0 -329
  8. package/src/bitcoin/BroadcastClient.ts +0 -54
  9. package/src/bitcoin/OrdinalsClient.ts +0 -120
  10. package/src/bitcoin/PSBTBuilder.ts +0 -106
  11. package/src/bitcoin/fee-calculation.ts +0 -38
  12. package/src/bitcoin/providers/OrdNodeProvider.ts +0 -92
  13. package/src/bitcoin/providers/OrdinalsProvider.ts +0 -56
  14. package/src/bitcoin/providers/types.ts +0 -59
  15. package/src/bitcoin/transactions/commit.ts +0 -465
  16. package/src/bitcoin/transactions/index.ts +0 -13
  17. package/src/bitcoin/transfer.ts +0 -43
  18. package/src/bitcoin/utxo-selection.ts +0 -322
  19. package/src/bitcoin/utxo.ts +0 -113
  20. package/src/cel/ExternalReferenceManager.ts +0 -87
  21. package/src/cel/OriginalsCel.ts +0 -460
  22. package/src/cel/algorithms/createEventLog.ts +0 -68
  23. package/src/cel/algorithms/deactivateEventLog.ts +0 -109
  24. package/src/cel/algorithms/index.ts +0 -11
  25. package/src/cel/algorithms/updateEventLog.ts +0 -99
  26. package/src/cel/algorithms/verifyEventLog.ts +0 -306
  27. package/src/cel/algorithms/witnessEvent.ts +0 -87
  28. package/src/cel/cli/create.ts +0 -330
  29. package/src/cel/cli/index.ts +0 -383
  30. package/src/cel/cli/inspect.ts +0 -549
  31. package/src/cel/cli/migrate.ts +0 -473
  32. package/src/cel/cli/verify.ts +0 -249
  33. package/src/cel/hash.ts +0 -71
  34. package/src/cel/index.ts +0 -16
  35. package/src/cel/layers/BtcoCelManager.ts +0 -408
  36. package/src/cel/layers/PeerCelManager.ts +0 -371
  37. package/src/cel/layers/WebVHCelManager.ts +0 -361
  38. package/src/cel/layers/index.ts +0 -27
  39. package/src/cel/serialization/cbor.ts +0 -189
  40. package/src/cel/serialization/index.ts +0 -10
  41. package/src/cel/serialization/json.ts +0 -209
  42. package/src/cel/types.ts +0 -160
  43. package/src/cel/witnesses/BitcoinWitness.ts +0 -184
  44. package/src/cel/witnesses/HttpWitness.ts +0 -241
  45. package/src/cel/witnesses/WitnessService.ts +0 -51
  46. package/src/cel/witnesses/index.ts +0 -11
  47. package/src/contexts/credentials-v1.json +0 -237
  48. package/src/contexts/credentials-v2-examples.json +0 -5
  49. package/src/contexts/credentials-v2.json +0 -340
  50. package/src/contexts/credentials.json +0 -237
  51. package/src/contexts/data-integrity-v2.json +0 -81
  52. package/src/contexts/dids.json +0 -58
  53. package/src/contexts/ed255192020.json +0 -93
  54. package/src/contexts/ordinals-plus.json +0 -23
  55. package/src/contexts/originals.json +0 -22
  56. package/src/core/OriginalsSDK.ts +0 -420
  57. package/src/crypto/Multikey.ts +0 -194
  58. package/src/crypto/Signer.ts +0 -262
  59. package/src/crypto/noble-init.ts +0 -138
  60. package/src/did/BtcoDidResolver.ts +0 -231
  61. package/src/did/DIDManager.ts +0 -705
  62. package/src/did/Ed25519Verifier.ts +0 -68
  63. package/src/did/KeyManager.ts +0 -239
  64. package/src/did/WebVHManager.ts +0 -499
  65. package/src/did/createBtcoDidDocument.ts +0 -60
  66. package/src/did/providers/OrdinalsClientProviderAdapter.ts +0 -68
  67. package/src/events/EventEmitter.ts +0 -222
  68. package/src/events/index.ts +0 -19
  69. package/src/events/types.ts +0 -331
  70. package/src/examples/basic-usage.ts +0 -78
  71. package/src/examples/create-module-original.ts +0 -435
  72. package/src/examples/full-lifecycle-flow.ts +0 -514
  73. package/src/examples/run.ts +0 -60
  74. package/src/index.ts +0 -204
  75. package/src/kinds/KindRegistry.ts +0 -320
  76. package/src/kinds/index.ts +0 -74
  77. package/src/kinds/types.ts +0 -470
  78. package/src/kinds/validators/AgentValidator.ts +0 -257
  79. package/src/kinds/validators/AppValidator.ts +0 -211
  80. package/src/kinds/validators/DatasetValidator.ts +0 -242
  81. package/src/kinds/validators/DocumentValidator.ts +0 -311
  82. package/src/kinds/validators/MediaValidator.ts +0 -269
  83. package/src/kinds/validators/ModuleValidator.ts +0 -225
  84. package/src/kinds/validators/base.ts +0 -276
  85. package/src/kinds/validators/index.ts +0 -12
  86. package/src/lifecycle/BatchOperations.ts +0 -381
  87. package/src/lifecycle/LifecycleManager.ts +0 -2156
  88. package/src/lifecycle/OriginalsAsset.ts +0 -524
  89. package/src/lifecycle/ProvenanceQuery.ts +0 -280
  90. package/src/lifecycle/ResourceVersioning.ts +0 -163
  91. package/src/migration/MigrationManager.ts +0 -587
  92. package/src/migration/audit/AuditLogger.ts +0 -176
  93. package/src/migration/checkpoint/CheckpointManager.ts +0 -112
  94. package/src/migration/checkpoint/CheckpointStorage.ts +0 -101
  95. package/src/migration/index.ts +0 -33
  96. package/src/migration/operations/BaseMigration.ts +0 -126
  97. package/src/migration/operations/PeerToBtcoMigration.ts +0 -105
  98. package/src/migration/operations/PeerToWebvhMigration.ts +0 -62
  99. package/src/migration/operations/WebvhToBtcoMigration.ts +0 -105
  100. package/src/migration/rollback/RollbackManager.ts +0 -170
  101. package/src/migration/state/StateMachine.ts +0 -92
  102. package/src/migration/state/StateTracker.ts +0 -156
  103. package/src/migration/types.ts +0 -356
  104. package/src/migration/validation/BitcoinValidator.ts +0 -107
  105. package/src/migration/validation/CredentialValidator.ts +0 -62
  106. package/src/migration/validation/DIDCompatibilityValidator.ts +0 -151
  107. package/src/migration/validation/LifecycleValidator.ts +0 -64
  108. package/src/migration/validation/StorageValidator.ts +0 -79
  109. package/src/migration/validation/ValidationPipeline.ts +0 -213
  110. package/src/resources/ResourceManager.ts +0 -655
  111. package/src/resources/index.ts +0 -21
  112. package/src/resources/types.ts +0 -202
  113. package/src/storage/LocalStorageAdapter.ts +0 -64
  114. package/src/storage/MemoryStorageAdapter.ts +0 -29
  115. package/src/storage/StorageAdapter.ts +0 -25
  116. package/src/storage/index.ts +0 -3
  117. package/src/types/bitcoin.ts +0 -98
  118. package/src/types/common.ts +0 -92
  119. package/src/types/credentials.ts +0 -89
  120. package/src/types/did.ts +0 -31
  121. package/src/types/external-shims.d.ts +0 -53
  122. package/src/types/index.ts +0 -7
  123. package/src/types/network.ts +0 -178
  124. package/src/utils/EventLogger.ts +0 -298
  125. package/src/utils/Logger.ts +0 -324
  126. package/src/utils/MetricsCollector.ts +0 -358
  127. package/src/utils/bitcoin-address.ts +0 -132
  128. package/src/utils/cbor.ts +0 -31
  129. package/src/utils/encoding.ts +0 -135
  130. package/src/utils/hash.ts +0 -12
  131. package/src/utils/retry.ts +0 -46
  132. package/src/utils/satoshi-validation.ts +0 -196
  133. package/src/utils/serialization.ts +0 -102
  134. package/src/utils/telemetry.ts +0 -44
  135. package/src/utils/validation.ts +0 -123
  136. package/src/vc/CredentialManager.ts +0 -955
  137. package/src/vc/Issuer.ts +0 -105
  138. package/src/vc/Verifier.ts +0 -54
  139. package/src/vc/cryptosuites/bbs.ts +0 -253
  140. package/src/vc/cryptosuites/bbsSimple.ts +0 -21
  141. package/src/vc/cryptosuites/eddsa.ts +0 -99
  142. package/src/vc/documentLoader.ts +0 -81
  143. package/src/vc/proofs/data-integrity.ts +0 -33
  144. package/src/vc/utils/jsonld.ts +0 -18
@@ -1,222 +0,0 @@
1
- /**
2
- * Type-safe EventEmitter for Originals SDK
3
- *
4
- * Features:
5
- * - Type-safe event emission and subscription
6
- * - Support for both sync and async handlers
7
- * - Error isolation (one failing handler doesn't affect others)
8
- * - Event namespacing
9
- * - Performance optimized (<1ms overhead per event)
10
- */
11
-
12
- import type { OriginalsEvent, EventHandler, EventTypeMap } from './types';
13
-
14
- /**
15
- * EventEmitter class for managing event subscriptions and emissions
16
- */
17
- export class EventEmitter {
18
- private handlers: Map<string, Set<EventHandler>> = new Map();
19
- private onceHandlers: Map<string, Set<EventHandler>> = new Map();
20
-
21
- /**
22
- * Subscribe to an event
23
- *
24
- * @param eventType - The type of event to listen for
25
- * @param handler - The handler function to call when the event is emitted
26
- * @returns A function to unsubscribe the handler
27
- *
28
- * @example
29
- * ```typescript
30
- * const unsubscribe = emitter.on('asset:created', (event) => {
31
- * console.log('Asset created:', event.asset.id);
32
- * });
33
- *
34
- * // Later, to unsubscribe:
35
- * unsubscribe();
36
- * ```
37
- */
38
- on<K extends keyof EventTypeMap>(
39
- eventType: K,
40
- handler: EventHandler<EventTypeMap[K]>
41
- ): () => void {
42
- if (!this.handlers.has(eventType)) {
43
- this.handlers.set(eventType, new Set());
44
- }
45
-
46
- this.handlers.get(eventType)!.add(handler as EventHandler);
47
-
48
- // Return unsubscribe function
49
- return () => this.off(eventType, handler);
50
- }
51
-
52
- /**
53
- * Subscribe to an event for a single emission
54
- *
55
- * @param eventType - The type of event to listen for
56
- * @param handler - The handler function to call when the event is emitted (only once)
57
- * @returns A function to unsubscribe the handler
58
- *
59
- * @example
60
- * ```typescript
61
- * emitter.once('asset:migrated', (event) => {
62
- * console.log('Asset migrated once:', event.asset.id);
63
- * });
64
- * ```
65
- */
66
- once<K extends keyof EventTypeMap>(
67
- eventType: K,
68
- handler: EventHandler<EventTypeMap[K]>
69
- ): () => void {
70
- if (!this.onceHandlers.has(eventType)) {
71
- this.onceHandlers.set(eventType, new Set());
72
- }
73
-
74
- this.onceHandlers.get(eventType)!.add(handler as EventHandler);
75
-
76
- // Return unsubscribe function
77
- return () => {
78
- const handlers = this.onceHandlers.get(eventType);
79
- if (handlers) {
80
- handlers.delete(handler as EventHandler);
81
- }
82
- };
83
- }
84
-
85
- /**
86
- * Unsubscribe from an event
87
- *
88
- * @param eventType - The type of event to stop listening for
89
- * @param handler - The handler function to remove
90
- *
91
- * @example
92
- * ```typescript
93
- * const handler = (event) => console.log(event);
94
- * emitter.on('asset:created', handler);
95
- * emitter.off('asset:created', handler);
96
- * ```
97
- */
98
- off<K extends keyof EventTypeMap>(
99
- eventType: K,
100
- handler: EventHandler<EventTypeMap[K]>
101
- ): void {
102
- const handlers = this.handlers.get(eventType);
103
- if (handlers) {
104
- handlers.delete(handler as EventHandler);
105
- }
106
-
107
- const onceHandlers = this.onceHandlers.get(eventType);
108
- if (onceHandlers) {
109
- onceHandlers.delete(handler as EventHandler);
110
- }
111
- }
112
-
113
- /**
114
- * Emit an event to all subscribed handlers
115
- *
116
- * @param event - The event to emit
117
- *
118
- * Features:
119
- * - Handlers are called in subscription order
120
- * - Async handlers are awaited
121
- * - Errors in handlers are isolated (logged but don't affect other handlers)
122
- * - Once handlers are automatically removed after execution
123
- *
124
- * @example
125
- * ```typescript
126
- * emitter.emit({
127
- * type: 'asset:created',
128
- * timestamp: new Date().toISOString(),
129
- * asset: { id: 'did:peer:123', layer: 'did:peer', resourceCount: 1 }
130
- * });
131
- * ```
132
- */
133
- async emit<K extends keyof EventTypeMap>(event: EventTypeMap[K]): Promise<void> {
134
- const eventType = event.type as K;
135
-
136
- // Get regular handlers
137
- const handlers = this.handlers.get(eventType);
138
- if (handlers && handlers.size > 0) {
139
- // Create array to avoid modification during iteration
140
- const handlerArray = Array.from(handlers);
141
-
142
- for (const handler of handlerArray) {
143
- try {
144
- await handler(event as OriginalsEvent);
145
- } catch (error) {
146
- // Error isolation: log but don't throw
147
- // This ensures one failing handler doesn't affect others
148
- if (typeof console !== 'undefined' && console.error) {
149
- console.error(`Event handler error for ${eventType}:`, error);
150
- }
151
- }
152
- }
153
- }
154
-
155
- // Get and execute once handlers
156
- const onceHandlers = this.onceHandlers.get(eventType);
157
- if (onceHandlers && onceHandlers.size > 0) {
158
- // Create array to avoid modification during iteration
159
- const onceHandlerArray = Array.from(onceHandlers);
160
-
161
- // Clear once handlers before execution
162
- this.onceHandlers.delete(eventType);
163
-
164
- for (const handler of onceHandlerArray) {
165
- try {
166
- await handler(event as OriginalsEvent);
167
- } catch (error) {
168
- // Error isolation: log but don't throw
169
- if (typeof console !== 'undefined' && console.error) {
170
- console.error(`Event handler error (once) for ${eventType}:`, error);
171
- }
172
- }
173
- }
174
- }
175
- }
176
-
177
- /**
178
- * Remove all handlers for a specific event type, or all handlers if no type specified
179
- *
180
- * @param eventType - Optional event type to clear handlers for
181
- *
182
- * @example
183
- * ```typescript
184
- * // Remove all handlers for 'asset:created'
185
- * emitter.removeAllListeners('asset:created');
186
- *
187
- * // Remove all handlers for all events
188
- * emitter.removeAllListeners();
189
- * ```
190
- */
191
- removeAllListeners<K extends keyof EventTypeMap>(eventType?: K): void {
192
- if (eventType) {
193
- this.handlers.delete(eventType);
194
- this.onceHandlers.delete(eventType);
195
- } else {
196
- this.handlers.clear();
197
- this.onceHandlers.clear();
198
- }
199
- }
200
-
201
- /**
202
- * Get the number of handlers for a specific event type
203
- *
204
- * @param eventType - The event type to check
205
- * @returns The number of handlers subscribed to this event type
206
- */
207
- listenerCount<K extends keyof EventTypeMap>(eventType: K): number {
208
- const handlers = this.handlers.get(eventType);
209
- const onceHandlers = this.onceHandlers.get(eventType);
210
- return (handlers?.size || 0) + (onceHandlers?.size || 0);
211
- }
212
-
213
- /**
214
- * Check if there are any handlers for a specific event type
215
- *
216
- * @param eventType - The event type to check
217
- * @returns True if there are any handlers subscribed
218
- */
219
- hasListeners<K extends keyof EventTypeMap>(eventType: K): boolean {
220
- return this.listenerCount(eventType) > 0;
221
- }
222
- }
@@ -1,19 +0,0 @@
1
- /**
2
- * Events module for the Originals SDK
3
- *
4
- * Provides a type-safe event system for tracking asset lifecycle operations
5
- */
6
-
7
- export { EventEmitter } from './EventEmitter';
8
- export type {
9
- BaseEvent,
10
- AssetCreatedEvent,
11
- AssetMigratedEvent,
12
- AssetTransferredEvent,
13
- ResourcePublishedEvent,
14
- CredentialIssuedEvent,
15
- VerificationCompletedEvent,
16
- OriginalsEvent,
17
- EventHandler,
18
- EventTypeMap
19
- } from './types';
@@ -1,331 +0,0 @@
1
- /**
2
- * Event types for the Originals SDK asset lifecycle operations
3
- *
4
- * All events follow a consistent structure:
5
- * - type: Namespaced event name (e.g., 'asset:created')
6
- * - timestamp: ISO 8601 timestamp of when the event occurred
7
- * - Specific payload data relevant to the event
8
- */
9
-
10
- import { LayerType } from '../types';
11
-
12
- /**
13
- * Base event interface that all events extend
14
- */
15
- export interface BaseEvent {
16
- type: string;
17
- timestamp: string;
18
- }
19
-
20
- /**
21
- * Emitted when a new asset is created
22
- */
23
- export interface AssetCreatedEvent extends BaseEvent {
24
- type: 'asset:created';
25
- asset: {
26
- id: string;
27
- layer: LayerType;
28
- resourceCount: number;
29
- createdAt: string;
30
- };
31
- }
32
-
33
- /**
34
- * Emitted when an asset migrates between layers
35
- *
36
- * Note: The `details` field is populated differently based on the target layer:
37
- * - For did:webvh migrations: `details` is undefined (web publishing has no transaction details)
38
- * - For did:btco migrations: `details` includes Bitcoin transaction information
39
- * (transactionId, inscriptionId, satoshi, commitTxId, revealTxId, feeRate)
40
- */
41
- export interface AssetMigratedEvent extends BaseEvent {
42
- type: 'asset:migrated';
43
- asset: {
44
- id: string;
45
- fromLayer: LayerType;
46
- toLayer: LayerType;
47
- };
48
- details?: {
49
- transactionId?: string;
50
- inscriptionId?: string;
51
- satoshi?: string;
52
- commitTxId?: string;
53
- revealTxId?: string;
54
- feeRate?: number;
55
- };
56
- }
57
-
58
- /**
59
- * Emitted when an asset's ownership is transferred
60
- */
61
- export interface AssetTransferredEvent extends BaseEvent {
62
- type: 'asset:transferred';
63
- asset: {
64
- id: string;
65
- layer: LayerType;
66
- };
67
- from: string;
68
- to: string;
69
- transactionId: string;
70
- }
71
-
72
- /**
73
- * Emitted when a resource is published to web storage
74
- */
75
- export interface ResourcePublishedEvent extends BaseEvent {
76
- type: 'resource:published';
77
- asset: {
78
- id: string;
79
- };
80
- resource: {
81
- id: string;
82
- url: string;
83
- contentType: string;
84
- hash: string;
85
- };
86
- publisherDid: string;
87
- }
88
-
89
- /**
90
- * Emitted when a verifiable credential is issued for an asset
91
- */
92
- export interface CredentialIssuedEvent extends BaseEvent {
93
- type: 'credential:issued';
94
- asset: {
95
- id: string;
96
- };
97
- credential: {
98
- type: string[];
99
- issuer: string;
100
- };
101
- }
102
-
103
- /**
104
- * Emitted when a new resource version is created
105
- */
106
- export interface ResourceVersionCreatedEvent extends BaseEvent {
107
- type: 'resource:version:created';
108
- asset: {
109
- id: string;
110
- };
111
- resource: {
112
- id: string;
113
- fromVersion: number;
114
- toVersion: number;
115
- fromHash: string;
116
- toHash: string;
117
- };
118
- changes?: string;
119
- }
120
-
121
- /**
122
- * Emitted when asset verification is completed
123
- */
124
- export interface VerificationCompletedEvent extends BaseEvent {
125
- type: 'verification:completed';
126
- asset: {
127
- id: string;
128
- };
129
- result: boolean;
130
- checks?: {
131
- didDocument: boolean;
132
- resources: boolean;
133
- credentials: boolean;
134
- };
135
- }
136
-
137
- /**
138
- * Emitted when a batch operation starts
139
- */
140
- export interface BatchStartedEvent extends BaseEvent {
141
- type: 'batch:started';
142
- operation: 'create' | 'publish' | 'inscribe' | 'transfer';
143
- batchId: string;
144
- itemCount: number;
145
- }
146
-
147
- /**
148
- * Emitted when a batch operation completes successfully
149
- */
150
- export interface BatchCompletedEvent extends BaseEvent {
151
- type: 'batch:completed';
152
- batchId: string;
153
- operation: string;
154
- results: {
155
- successful: number;
156
- failed: number;
157
- totalDuration: number;
158
- costSavings?: {
159
- amount: number;
160
- percentage: number;
161
- };
162
- };
163
- }
164
-
165
- /**
166
- * Emitted when a batch operation fails
167
- */
168
- export interface BatchFailedEvent extends BaseEvent {
169
- type: 'batch:failed';
170
- batchId: string;
171
- operation: string;
172
- error: string;
173
- partialResults?: {
174
- successful: number;
175
- failed: number;
176
- };
177
- }
178
-
179
- /**
180
- * Emitted when a migration starts
181
- */
182
- export interface MigrationStartedEvent extends BaseEvent {
183
- type: 'migration:started';
184
- migrationId: string;
185
- sourceDid: string;
186
- targetLayer: string;
187
- }
188
-
189
- /**
190
- * Emitted when migration validation completes
191
- */
192
- export interface MigrationValidatedEvent extends BaseEvent {
193
- type: 'migration:validated';
194
- migrationId: string;
195
- valid: boolean;
196
- }
197
-
198
- /**
199
- * Emitted when migration checkpoint is created
200
- */
201
- export interface MigrationCheckpointedEvent extends BaseEvent {
202
- type: 'migration:checkpointed';
203
- migrationId: string;
204
- checkpointId: string;
205
- }
206
-
207
- /**
208
- * Emitted when migration enters in-progress state
209
- */
210
- export interface MigrationInProgressEvent extends BaseEvent {
211
- type: 'migration:in_progress';
212
- migrationId: string;
213
- currentOperation: string;
214
- progress: number;
215
- }
216
-
217
- /**
218
- * Emitted when migration enters anchoring state (Bitcoin)
219
- */
220
- export interface MigrationAnchoringEvent extends BaseEvent {
221
- type: 'migration:anchoring';
222
- migrationId: string;
223
- transactionId?: string;
224
- }
225
-
226
- /**
227
- * Emitted when migration completes successfully
228
- */
229
- export interface MigrationCompletedEvent extends BaseEvent {
230
- type: 'migration:completed';
231
- migrationId: string;
232
- sourceDid: string;
233
- targetDid: string;
234
- }
235
-
236
- /**
237
- * Emitted when migration fails
238
- */
239
- export interface MigrationFailedEvent extends BaseEvent {
240
- type: 'migration:failed';
241
- migrationId: string;
242
- error: Error | { message: string; code?: string };
243
- }
244
-
245
- /**
246
- * Emitted when migration is rolled back
247
- */
248
- export interface MigrationRolledbackEvent extends BaseEvent {
249
- type: 'migration:rolledback';
250
- migrationId: string;
251
- checkpointId: string;
252
- }
253
-
254
- /**
255
- * Emitted when migration enters quarantine state
256
- */
257
- export interface MigrationQuarantineEvent extends BaseEvent {
258
- type: 'migration:quarantine';
259
- migrationId: string;
260
- checkpointId: string;
261
- reason: string;
262
- }
263
-
264
- /**
265
- * Emitted during batch operations to report progress
266
- */
267
- export interface BatchProgressEvent extends BaseEvent {
268
- type: 'batch:progress';
269
- batchId: string;
270
- operation: string;
271
- progress: number;
272
- completed: number;
273
- failed: number;
274
- total: number;
275
- }
276
-
277
- /**
278
- * Union type of all possible events
279
- */
280
- export type OriginalsEvent =
281
- | AssetCreatedEvent
282
- | AssetMigratedEvent
283
- | AssetTransferredEvent
284
- | ResourcePublishedEvent
285
- | CredentialIssuedEvent
286
- | VerificationCompletedEvent
287
- | BatchStartedEvent
288
- | BatchCompletedEvent
289
- | BatchFailedEvent
290
- | BatchProgressEvent
291
- | ResourceVersionCreatedEvent
292
- | MigrationStartedEvent
293
- | MigrationValidatedEvent
294
- | MigrationCheckpointedEvent
295
- | MigrationInProgressEvent
296
- | MigrationAnchoringEvent
297
- | MigrationCompletedEvent
298
- | MigrationFailedEvent
299
- | MigrationRolledbackEvent
300
- | MigrationQuarantineEvent;
301
-
302
- /**
303
- * Event handler function type
304
- */
305
- export type EventHandler<T extends OriginalsEvent = OriginalsEvent> = (event: T) => void | Promise<void>;
306
-
307
- /**
308
- * Map of event types to their specific event interfaces
309
- */
310
- export interface EventTypeMap {
311
- 'asset:created': AssetCreatedEvent;
312
- 'asset:migrated': AssetMigratedEvent;
313
- 'asset:transferred': AssetTransferredEvent;
314
- 'resource:published': ResourcePublishedEvent;
315
- 'credential:issued': CredentialIssuedEvent;
316
- 'verification:completed': VerificationCompletedEvent;
317
- 'batch:started': BatchStartedEvent;
318
- 'batch:completed': BatchCompletedEvent;
319
- 'batch:failed': BatchFailedEvent;
320
- 'batch:progress': BatchProgressEvent;
321
- 'resource:version:created': ResourceVersionCreatedEvent;
322
- 'migration:started': MigrationStartedEvent;
323
- 'migration:validated': MigrationValidatedEvent;
324
- 'migration:checkpointed': MigrationCheckpointedEvent;
325
- 'migration:in_progress': MigrationInProgressEvent;
326
- 'migration:anchoring': MigrationAnchoringEvent;
327
- 'migration:completed': MigrationCompletedEvent;
328
- 'migration:failed': MigrationFailedEvent;
329
- 'migration:rolledback': MigrationRolledbackEvent;
330
- 'migration:quarantine': MigrationQuarantineEvent;
331
- }
@@ -1,78 +0,0 @@
1
- import { OriginalsSDK } from '../index';
2
-
3
- async function basicExample() {
4
- const sdk = OriginalsSDK.create({
5
- network: 'regtest',
6
- enableLogging: true,
7
- // Example uses defaults; provide adapters in your app or tests
8
- telemetry: {
9
- onEvent: (e) => console.log('[telemetry]', e.name, e.attributes || {}),
10
- onError: (err) => console.warn('[error]', err.code, err.message)
11
- }
12
- });
13
-
14
- // Create new digital asset
15
- const resources = [{
16
- id: 'image-1',
17
- type: 'image',
18
- content: 'base64-encoded-image-data',
19
- contentType: 'image/png',
20
- hash: 'sha256-hash'
21
- }];
22
-
23
- try {
24
- // Create asset in did:peer layer (private, offline)
25
- const asset = await sdk.lifecycle.createAsset(resources);
26
- console.log('Created asset:', asset.id);
27
- console.log('Current layer:', asset.currentLayer); // 'did:peer'
28
-
29
- // Publish to web for discovery (did:webvh layer)
30
- await sdk.lifecycle.publishToWeb(asset, 'example.com');
31
- console.log('Published to web, current layer:', asset.currentLayer); // 'did:webvh'
32
-
33
- // Inscribe on Bitcoin for permanent ownership (did:btco layer)
34
- await sdk.lifecycle.inscribeOnBitcoin(asset);
35
- console.log('Inscribed on Bitcoin, current layer:', asset.currentLayer); // 'did:btco'
36
-
37
- // Get full provenance chain
38
- const provenance = asset.getProvenance();
39
- console.log('Provenance:', provenance);
40
-
41
- // Verify asset integrity
42
- const isValid = await asset.verify();
43
- console.log('Asset is valid:', isValid);
44
-
45
- } catch (error) {
46
- console.error('Error:', error);
47
- }
48
- }
49
-
50
- async function digitalArtExample() {
51
- const sdk = OriginalsSDK.create();
52
-
53
- // Artist creates digital artwork
54
- const artwork = [{
55
- id: 'artwork-001',
56
- type: 'image',
57
- url: 'https://artist-site.com/my-artwork.jpg',
58
- contentType: 'image/jpeg',
59
- hash: 'abcd1234...' // SHA-256 hash of image
60
- }];
61
-
62
- // Create private version for experimentation
63
- const asset = await sdk.lifecycle.createAsset(artwork);
64
-
65
- // Make discoverable when ready
66
- await sdk.lifecycle.publishToWeb(asset, 'artist-gallery.com');
67
-
68
- // Inscribe on Bitcoin when sold
69
- await sdk.lifecycle.inscribeOnBitcoin(asset);
70
-
71
- // Transfer to buyer
72
- await sdk.lifecycle.transferOwnership(asset, 'buyer-address');
73
- }
74
-
75
- // Export examples
76
- export { basicExample, digitalArtExample };
77
-
78
-