@originals/sdk 1.4.2 → 1.4.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 (212) hide show
  1. package/package.json +4 -1
  2. package/.eslintrc.json +0 -33
  3. package/src/adapters/FeeOracleMock.ts +0 -9
  4. package/src/adapters/index.ts +0 -5
  5. package/src/adapters/providers/OrdHttpProvider.ts +0 -126
  6. package/src/adapters/providers/OrdMockProvider.ts +0 -101
  7. package/src/adapters/types.ts +0 -66
  8. package/src/bitcoin/BitcoinManager.ts +0 -330
  9. package/src/bitcoin/BroadcastClient.ts +0 -54
  10. package/src/bitcoin/OrdinalsClient.ts +0 -119
  11. package/src/bitcoin/PSBTBuilder.ts +0 -106
  12. package/src/bitcoin/fee-calculation.ts +0 -38
  13. package/src/bitcoin/providers/OrdNodeProvider.ts +0 -92
  14. package/src/bitcoin/providers/OrdinalsProvider.ts +0 -56
  15. package/src/bitcoin/providers/types.ts +0 -59
  16. package/src/bitcoin/transactions/commit.ts +0 -465
  17. package/src/bitcoin/transactions/index.ts +0 -13
  18. package/src/bitcoin/transfer.ts +0 -43
  19. package/src/bitcoin/utxo-selection.ts +0 -322
  20. package/src/bitcoin/utxo.ts +0 -113
  21. package/src/contexts/credentials-v1.json +0 -237
  22. package/src/contexts/credentials-v2-examples.json +0 -5
  23. package/src/contexts/credentials-v2.json +0 -340
  24. package/src/contexts/credentials.json +0 -237
  25. package/src/contexts/data-integrity-v2.json +0 -81
  26. package/src/contexts/dids.json +0 -58
  27. package/src/contexts/ed255192020.json +0 -93
  28. package/src/contexts/ordinals-plus.json +0 -23
  29. package/src/contexts/originals.json +0 -22
  30. package/src/core/OriginalsSDK.ts +0 -416
  31. package/src/crypto/Multikey.ts +0 -194
  32. package/src/crypto/Signer.ts +0 -254
  33. package/src/crypto/noble-init.ts +0 -121
  34. package/src/did/BtcoDidResolver.ts +0 -227
  35. package/src/did/DIDManager.ts +0 -694
  36. package/src/did/Ed25519Verifier.ts +0 -68
  37. package/src/did/KeyManager.ts +0 -236
  38. package/src/did/WebVHManager.ts +0 -498
  39. package/src/did/createBtcoDidDocument.ts +0 -59
  40. package/src/did/providers/OrdinalsClientProviderAdapter.ts +0 -68
  41. package/src/events/EventEmitter.ts +0 -222
  42. package/src/events/index.ts +0 -19
  43. package/src/events/types.ts +0 -331
  44. package/src/examples/basic-usage.ts +0 -78
  45. package/src/examples/create-module-original.ts +0 -435
  46. package/src/examples/full-lifecycle-flow.ts +0 -514
  47. package/src/examples/run.ts +0 -60
  48. package/src/index.ts +0 -150
  49. package/src/kinds/KindRegistry.ts +0 -290
  50. package/src/kinds/index.ts +0 -74
  51. package/src/kinds/types.ts +0 -470
  52. package/src/kinds/validators/AgentValidator.ts +0 -257
  53. package/src/kinds/validators/AppValidator.ts +0 -211
  54. package/src/kinds/validators/DatasetValidator.ts +0 -242
  55. package/src/kinds/validators/DocumentValidator.ts +0 -311
  56. package/src/kinds/validators/MediaValidator.ts +0 -269
  57. package/src/kinds/validators/ModuleValidator.ts +0 -225
  58. package/src/kinds/validators/base.ts +0 -276
  59. package/src/kinds/validators/index.ts +0 -12
  60. package/src/lifecycle/BatchOperations.ts +0 -373
  61. package/src/lifecycle/LifecycleManager.ts +0 -2126
  62. package/src/lifecycle/OriginalsAsset.ts +0 -524
  63. package/src/lifecycle/ProvenanceQuery.ts +0 -280
  64. package/src/lifecycle/ResourceVersioning.ts +0 -163
  65. package/src/migration/MigrationManager.ts +0 -527
  66. package/src/migration/audit/AuditLogger.ts +0 -176
  67. package/src/migration/checkpoint/CheckpointManager.ts +0 -112
  68. package/src/migration/checkpoint/CheckpointStorage.ts +0 -101
  69. package/src/migration/index.ts +0 -33
  70. package/src/migration/operations/BaseMigration.ts +0 -126
  71. package/src/migration/operations/PeerToBtcoMigration.ts +0 -105
  72. package/src/migration/operations/PeerToWebvhMigration.ts +0 -62
  73. package/src/migration/operations/WebvhToBtcoMigration.ts +0 -105
  74. package/src/migration/rollback/RollbackManager.ts +0 -170
  75. package/src/migration/state/StateMachine.ts +0 -92
  76. package/src/migration/state/StateTracker.ts +0 -156
  77. package/src/migration/types.ts +0 -344
  78. package/src/migration/validation/BitcoinValidator.ts +0 -107
  79. package/src/migration/validation/CredentialValidator.ts +0 -62
  80. package/src/migration/validation/DIDCompatibilityValidator.ts +0 -151
  81. package/src/migration/validation/LifecycleValidator.ts +0 -64
  82. package/src/migration/validation/StorageValidator.ts +0 -79
  83. package/src/migration/validation/ValidationPipeline.ts +0 -213
  84. package/src/resources/ResourceManager.ts +0 -655
  85. package/src/resources/index.ts +0 -21
  86. package/src/resources/types.ts +0 -202
  87. package/src/storage/LocalStorageAdapter.ts +0 -61
  88. package/src/storage/MemoryStorageAdapter.ts +0 -29
  89. package/src/storage/StorageAdapter.ts +0 -25
  90. package/src/storage/index.ts +0 -3
  91. package/src/types/bitcoin.ts +0 -98
  92. package/src/types/common.ts +0 -92
  93. package/src/types/credentials.ts +0 -88
  94. package/src/types/did.ts +0 -31
  95. package/src/types/external-shims.d.ts +0 -53
  96. package/src/types/index.ts +0 -7
  97. package/src/types/network.ts +0 -175
  98. package/src/utils/EventLogger.ts +0 -298
  99. package/src/utils/Logger.ts +0 -322
  100. package/src/utils/MetricsCollector.ts +0 -358
  101. package/src/utils/bitcoin-address.ts +0 -130
  102. package/src/utils/cbor.ts +0 -12
  103. package/src/utils/encoding.ts +0 -127
  104. package/src/utils/hash.ts +0 -6
  105. package/src/utils/retry.ts +0 -46
  106. package/src/utils/satoshi-validation.ts +0 -196
  107. package/src/utils/serialization.ts +0 -96
  108. package/src/utils/telemetry.ts +0 -40
  109. package/src/utils/validation.ts +0 -119
  110. package/src/vc/CredentialManager.ts +0 -918
  111. package/src/vc/Issuer.ts +0 -100
  112. package/src/vc/Verifier.ts +0 -47
  113. package/src/vc/cryptosuites/bbs.ts +0 -253
  114. package/src/vc/cryptosuites/bbsSimple.ts +0 -21
  115. package/src/vc/cryptosuites/eddsa.ts +0 -99
  116. package/src/vc/documentLoader.ts +0 -67
  117. package/src/vc/proofs/data-integrity.ts +0 -33
  118. package/src/vc/utils/jsonld.ts +0 -18
  119. package/tests/__mocks__/bbs-signatures.js +0 -17
  120. package/tests/__mocks__/mf-base58.js +0 -24
  121. package/tests/fixtures/did-documents.ts +0 -247
  122. package/tests/index.test.ts +0 -21
  123. package/tests/integration/BatchOperations.test.ts +0 -531
  124. package/tests/integration/CompleteLifecycle.e2e.test.ts +0 -735
  125. package/tests/integration/CredentialManager.test.ts +0 -42
  126. package/tests/integration/DIDManager.test.ts +0 -41
  127. package/tests/integration/DidPeerToWebVhFlow.test.ts +0 -351
  128. package/tests/integration/Events.test.ts +0 -435
  129. package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +0 -25
  130. package/tests/integration/LifecycleManager.test.ts +0 -21
  131. package/tests/integration/MultikeyFlow.test.ts +0 -52
  132. package/tests/integration/TelemetryIntegration.test.ts +0 -395
  133. package/tests/integration/WebVhPublish.test.ts +0 -48
  134. package/tests/integration/createTypedOriginal.test.ts +0 -379
  135. package/tests/integration/migration/peer-to-webvh.test.ts +0 -172
  136. package/tests/manual/test-commit-creation.ts +0 -323
  137. package/tests/mocks/MockKeyStore.ts +0 -38
  138. package/tests/mocks/adapters/MemoryStorageAdapter.ts +0 -24
  139. package/tests/mocks/adapters/MockFeeOracle.ts +0 -11
  140. package/tests/mocks/adapters/MockOrdinalsProvider.ts +0 -76
  141. package/tests/mocks/adapters/OrdMockProvider.test.ts +0 -176
  142. package/tests/mocks/adapters/index.ts +0 -6
  143. package/tests/performance/BatchOperations.perf.test.ts +0 -403
  144. package/tests/performance/logging.perf.test.ts +0 -336
  145. package/tests/sdk.test.ts +0 -43
  146. package/tests/security/bitcoin-penetration-tests.test.ts +0 -622
  147. package/tests/setup.bun.ts +0 -69
  148. package/tests/setup.jest.ts +0 -23
  149. package/tests/stress/batch-operations-stress.test.ts +0 -571
  150. package/tests/unit/adapters/FeeOracleMock.test.ts +0 -40
  151. package/tests/unit/bitcoin/BitcoinManager.test.ts +0 -293
  152. package/tests/unit/bitcoin/BroadcastClient.test.ts +0 -52
  153. package/tests/unit/bitcoin/OrdNodeProvider.test.ts +0 -53
  154. package/tests/unit/bitcoin/OrdinalsClient.test.ts +0 -381
  155. package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +0 -102
  156. package/tests/unit/bitcoin/PSBTBuilder.test.ts +0 -84
  157. package/tests/unit/bitcoin/fee-calculation.test.ts +0 -261
  158. package/tests/unit/bitcoin/transactions/commit.test.ts +0 -649
  159. package/tests/unit/bitcoin/transfer.test.ts +0 -31
  160. package/tests/unit/bitcoin/utxo-selection-new.test.ts +0 -502
  161. package/tests/unit/bitcoin/utxo.more.test.ts +0 -39
  162. package/tests/unit/bitcoin/utxo.selection.test.ts +0 -38
  163. package/tests/unit/core/OriginalsSDK.test.ts +0 -152
  164. package/tests/unit/crypto/Multikey.test.ts +0 -206
  165. package/tests/unit/crypto/Signer.test.ts +0 -408
  166. package/tests/unit/did/BtcoDidResolver.test.ts +0 -611
  167. package/tests/unit/did/DIDManager.more.test.ts +0 -43
  168. package/tests/unit/did/DIDManager.test.ts +0 -185
  169. package/tests/unit/did/Ed25519Verifier.test.ts +0 -160
  170. package/tests/unit/did/KeyManager.test.ts +0 -452
  171. package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +0 -45
  172. package/tests/unit/did/WebVHManager.test.ts +0 -435
  173. package/tests/unit/did/createBtcoDidDocument.test.ts +0 -67
  174. package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +0 -159
  175. package/tests/unit/events/EventEmitter.test.ts +0 -407
  176. package/tests/unit/kinds/KindRegistry.test.ts +0 -329
  177. package/tests/unit/kinds/types.test.ts +0 -409
  178. package/tests/unit/kinds/validators.test.ts +0 -651
  179. package/tests/unit/lifecycle/BatchOperations.test.ts +0 -527
  180. package/tests/unit/lifecycle/LifecycleManager.cleanapi.test.ts +0 -441
  181. package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +0 -312
  182. package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +0 -18
  183. package/tests/unit/lifecycle/LifecycleManager.test.ts +0 -213
  184. package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +0 -30
  185. package/tests/unit/lifecycle/OriginalsAsset.test.ts +0 -176
  186. package/tests/unit/lifecycle/ProvenanceQuery.test.ts +0 -577
  187. package/tests/unit/lifecycle/ResourceVersioning.test.ts +0 -651
  188. package/tests/unit/resources/ResourceManager.test.ts +0 -740
  189. package/tests/unit/storage/MemoryStorageAdapter.test.ts +0 -93
  190. package/tests/unit/types/network.test.ts +0 -255
  191. package/tests/unit/utils/EventIntegration.test.ts +0 -384
  192. package/tests/unit/utils/Logger.test.ts +0 -473
  193. package/tests/unit/utils/MetricsCollector.test.ts +0 -358
  194. package/tests/unit/utils/bitcoin-address.test.ts +0 -250
  195. package/tests/unit/utils/cbor.test.ts +0 -35
  196. package/tests/unit/utils/encoding.test.ts +0 -318
  197. package/tests/unit/utils/hash.test.ts +0 -12
  198. package/tests/unit/utils/retry.test.ts +0 -100
  199. package/tests/unit/utils/satoshi-validation.test.ts +0 -354
  200. package/tests/unit/utils/serialization.test.ts +0 -124
  201. package/tests/unit/utils/telemetry.test.ts +0 -52
  202. package/tests/unit/utils/validation.test.ts +0 -141
  203. package/tests/unit/vc/CredentialManager.helpers.test.ts +0 -527
  204. package/tests/unit/vc/CredentialManager.test.ts +0 -487
  205. package/tests/unit/vc/Issuer.test.ts +0 -107
  206. package/tests/unit/vc/Verifier.test.ts +0 -525
  207. package/tests/unit/vc/bbs.test.ts +0 -282
  208. package/tests/unit/vc/cryptosuites/eddsa.test.ts +0 -398
  209. package/tests/unit/vc/documentLoader.test.ts +0 -121
  210. package/tests/unit/vc/proofs/data-integrity.test.ts +0 -24
  211. package/tsconfig.json +0 -31
  212. package/tsconfig.test.json +0 -15
@@ -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: any;
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
-