@originals/sdk 1.8.0 → 1.8.2

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 (145) hide show
  1. package/dist/utils/hash.js +1 -0
  2. package/package.json +6 -5
  3. package/src/adapters/FeeOracleMock.ts +9 -0
  4. package/src/adapters/index.ts +5 -0
  5. package/src/adapters/providers/OrdHttpProvider.ts +126 -0
  6. package/src/adapters/providers/OrdMockProvider.ts +101 -0
  7. package/src/adapters/types.ts +66 -0
  8. package/src/bitcoin/BitcoinManager.ts +329 -0
  9. package/src/bitcoin/BroadcastClient.ts +54 -0
  10. package/src/bitcoin/OrdinalsClient.ts +120 -0
  11. package/src/bitcoin/PSBTBuilder.ts +106 -0
  12. package/src/bitcoin/fee-calculation.ts +38 -0
  13. package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
  14. package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
  15. package/src/bitcoin/providers/types.ts +59 -0
  16. package/src/bitcoin/transactions/commit.ts +465 -0
  17. package/src/bitcoin/transactions/index.ts +13 -0
  18. package/src/bitcoin/transfer.ts +43 -0
  19. package/src/bitcoin/utxo-selection.ts +322 -0
  20. package/src/bitcoin/utxo.ts +113 -0
  21. package/src/cel/ExternalReferenceManager.ts +87 -0
  22. package/src/cel/OriginalsCel.ts +460 -0
  23. package/src/cel/algorithms/createEventLog.ts +68 -0
  24. package/src/cel/algorithms/deactivateEventLog.ts +109 -0
  25. package/src/cel/algorithms/index.ts +11 -0
  26. package/src/cel/algorithms/updateEventLog.ts +99 -0
  27. package/src/cel/algorithms/verifyEventLog.ts +306 -0
  28. package/src/cel/algorithms/witnessEvent.ts +87 -0
  29. package/src/cel/cli/create.ts +330 -0
  30. package/src/cel/cli/index.ts +383 -0
  31. package/src/cel/cli/inspect.ts +549 -0
  32. package/src/cel/cli/migrate.ts +473 -0
  33. package/src/cel/cli/verify.ts +249 -0
  34. package/src/cel/hash.ts +71 -0
  35. package/src/cel/index.ts +16 -0
  36. package/src/cel/layers/BtcoCelManager.ts +408 -0
  37. package/src/cel/layers/PeerCelManager.ts +371 -0
  38. package/src/cel/layers/WebVHCelManager.ts +361 -0
  39. package/src/cel/layers/index.ts +27 -0
  40. package/src/cel/serialization/cbor.ts +189 -0
  41. package/src/cel/serialization/index.ts +10 -0
  42. package/src/cel/serialization/json.ts +209 -0
  43. package/src/cel/types.ts +160 -0
  44. package/src/cel/witnesses/BitcoinWitness.ts +184 -0
  45. package/src/cel/witnesses/HttpWitness.ts +241 -0
  46. package/src/cel/witnesses/WitnessService.ts +51 -0
  47. package/src/cel/witnesses/index.ts +11 -0
  48. package/src/contexts/credentials-v1.json +237 -0
  49. package/src/contexts/credentials-v2-examples.json +5 -0
  50. package/src/contexts/credentials-v2.json +340 -0
  51. package/src/contexts/credentials.json +237 -0
  52. package/src/contexts/data-integrity-v2.json +81 -0
  53. package/src/contexts/dids.json +58 -0
  54. package/src/contexts/ed255192020.json +93 -0
  55. package/src/contexts/ordinals-plus.json +23 -0
  56. package/src/contexts/originals.json +22 -0
  57. package/src/core/OriginalsSDK.ts +420 -0
  58. package/src/crypto/Multikey.ts +194 -0
  59. package/src/crypto/Signer.ts +262 -0
  60. package/src/crypto/noble-init.ts +138 -0
  61. package/src/did/BtcoDidResolver.ts +231 -0
  62. package/src/did/DIDManager.ts +705 -0
  63. package/src/did/Ed25519Verifier.ts +68 -0
  64. package/src/did/KeyManager.ts +239 -0
  65. package/src/did/WebVHManager.ts +499 -0
  66. package/src/did/createBtcoDidDocument.ts +60 -0
  67. package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
  68. package/src/events/EventEmitter.ts +222 -0
  69. package/src/events/index.ts +19 -0
  70. package/src/events/types.ts +331 -0
  71. package/src/examples/basic-usage.ts +78 -0
  72. package/src/examples/create-module-original.ts +435 -0
  73. package/src/examples/full-lifecycle-flow.ts +514 -0
  74. package/src/examples/run.ts +60 -0
  75. package/src/index.ts +204 -0
  76. package/src/kinds/KindRegistry.ts +320 -0
  77. package/src/kinds/index.ts +74 -0
  78. package/src/kinds/types.ts +470 -0
  79. package/src/kinds/validators/AgentValidator.ts +257 -0
  80. package/src/kinds/validators/AppValidator.ts +211 -0
  81. package/src/kinds/validators/DatasetValidator.ts +242 -0
  82. package/src/kinds/validators/DocumentValidator.ts +311 -0
  83. package/src/kinds/validators/MediaValidator.ts +269 -0
  84. package/src/kinds/validators/ModuleValidator.ts +225 -0
  85. package/src/kinds/validators/base.ts +276 -0
  86. package/src/kinds/validators/index.ts +12 -0
  87. package/src/lifecycle/BatchOperations.ts +381 -0
  88. package/src/lifecycle/LifecycleManager.ts +2156 -0
  89. package/src/lifecycle/OriginalsAsset.ts +524 -0
  90. package/src/lifecycle/ProvenanceQuery.ts +280 -0
  91. package/src/lifecycle/ResourceVersioning.ts +163 -0
  92. package/src/migration/MigrationManager.ts +587 -0
  93. package/src/migration/audit/AuditLogger.ts +176 -0
  94. package/src/migration/checkpoint/CheckpointManager.ts +112 -0
  95. package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
  96. package/src/migration/index.ts +33 -0
  97. package/src/migration/operations/BaseMigration.ts +126 -0
  98. package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
  99. package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
  100. package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
  101. package/src/migration/rollback/RollbackManager.ts +170 -0
  102. package/src/migration/state/StateMachine.ts +92 -0
  103. package/src/migration/state/StateTracker.ts +156 -0
  104. package/src/migration/types.ts +356 -0
  105. package/src/migration/validation/BitcoinValidator.ts +107 -0
  106. package/src/migration/validation/CredentialValidator.ts +62 -0
  107. package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
  108. package/src/migration/validation/LifecycleValidator.ts +64 -0
  109. package/src/migration/validation/StorageValidator.ts +79 -0
  110. package/src/migration/validation/ValidationPipeline.ts +213 -0
  111. package/src/resources/ResourceManager.ts +655 -0
  112. package/src/resources/index.ts +21 -0
  113. package/src/resources/types.ts +202 -0
  114. package/src/storage/LocalStorageAdapter.ts +64 -0
  115. package/src/storage/MemoryStorageAdapter.ts +29 -0
  116. package/src/storage/StorageAdapter.ts +25 -0
  117. package/src/storage/index.ts +3 -0
  118. package/src/types/bitcoin.ts +98 -0
  119. package/src/types/common.ts +92 -0
  120. package/src/types/credentials.ts +89 -0
  121. package/src/types/did.ts +31 -0
  122. package/src/types/external-shims.d.ts +53 -0
  123. package/src/types/index.ts +7 -0
  124. package/src/types/network.ts +178 -0
  125. package/src/utils/EventLogger.ts +298 -0
  126. package/src/utils/Logger.ts +324 -0
  127. package/src/utils/MetricsCollector.ts +358 -0
  128. package/src/utils/bitcoin-address.ts +132 -0
  129. package/src/utils/cbor.ts +31 -0
  130. package/src/utils/encoding.ts +135 -0
  131. package/src/utils/hash.ts +12 -0
  132. package/src/utils/retry.ts +46 -0
  133. package/src/utils/satoshi-validation.ts +196 -0
  134. package/src/utils/serialization.ts +102 -0
  135. package/src/utils/telemetry.ts +44 -0
  136. package/src/utils/validation.ts +123 -0
  137. package/src/vc/CredentialManager.ts +955 -0
  138. package/src/vc/Issuer.ts +105 -0
  139. package/src/vc/Verifier.ts +54 -0
  140. package/src/vc/cryptosuites/bbs.ts +253 -0
  141. package/src/vc/cryptosuites/bbsSimple.ts +21 -0
  142. package/src/vc/cryptosuites/eddsa.ts +99 -0
  143. package/src/vc/documentLoader.ts +81 -0
  144. package/src/vc/proofs/data-integrity.ts +33 -0
  145. package/src/vc/utils/jsonld.ts +18 -0
@@ -0,0 +1,435 @@
1
+ /**
2
+ * Example: Creating a Module Original
3
+ *
4
+ * This example demonstrates how to create a typed Module Original using
5
+ * the Originals SDK's Kind system. Module Originals are reusable code
6
+ * packages with explicit exports, dependencies, and metadata.
7
+ */
8
+
9
+ import {
10
+ OriginalsSDK,
11
+ OriginalKind,
12
+ OrdMockProvider,
13
+ KindRegistry,
14
+ type OriginalManifest
15
+ } from '../index';
16
+ import { sha256 } from '@noble/hashes/sha2.js';
17
+
18
+ /**
19
+ * Helper to compute content hash
20
+ */
21
+ function computeHash(content: string): string {
22
+ return Buffer.from(sha256(Buffer.from(content))).toString('hex');
23
+ }
24
+
25
+ /**
26
+ * Create a simple Module Original
27
+ */
28
+ async function createSimpleModule(): Promise<void> {
29
+ console.log('=== Creating a Simple Module Original ===\n');
30
+
31
+ // Initialize SDK
32
+ const sdk = OriginalsSDK.create({
33
+ network: 'regtest',
34
+ defaultKeyType: 'Ed25519',
35
+ webvhNetwork: 'magby',
36
+ ordinalsProvider: new OrdMockProvider(),
37
+ });
38
+
39
+ // Define module source code
40
+ const moduleCode = `
41
+ /**
42
+ * A simple greeting utility module
43
+ */
44
+
45
+ /**
46
+ * Generate a personalized greeting
47
+ * @param name - The name to greet
48
+ * @returns A friendly greeting string
49
+ */
50
+ export function greet(name) {
51
+ return \`Hello, \${name}! Welcome to Originals.\`;
52
+ }
53
+
54
+ /**
55
+ * Generate a farewell message
56
+ * @param name - The name to say goodbye to
57
+ * @returns A farewell string
58
+ */
59
+ export function farewell(name) {
60
+ return \`Goodbye, \${name}! See you soon.\`;
61
+ }
62
+
63
+ /**
64
+ * Get a random greeting from a list
65
+ * @returns A random greeting string
66
+ */
67
+ export function randomGreeting() {
68
+ const greetings = ['Hey!', 'Hi there!', 'Howdy!', 'Welcome!', 'Greetings!'];
69
+ return greetings[Math.floor(Math.random() * greetings.length)];
70
+ }
71
+ `.trim();
72
+
73
+ // Define TypeScript type definitions
74
+ const typeDefs = `
75
+ /**
76
+ * Type definitions for greeting-utils module
77
+ */
78
+
79
+ /**
80
+ * Generate a personalized greeting
81
+ */
82
+ export declare function greet(name: string): string;
83
+
84
+ /**
85
+ * Generate a farewell message
86
+ */
87
+ export declare function farewell(name: string): string;
88
+
89
+ /**
90
+ * Get a random greeting from a list
91
+ */
92
+ export declare function randomGreeting(): string;
93
+ `.trim();
94
+
95
+ // Create resources
96
+ const resources = [
97
+ {
98
+ id: 'index.js',
99
+ type: 'code',
100
+ content: moduleCode,
101
+ contentType: 'application/javascript',
102
+ hash: computeHash(moduleCode),
103
+ size: moduleCode.length,
104
+ },
105
+ {
106
+ id: 'index.d.ts',
107
+ type: 'code',
108
+ content: typeDefs,
109
+ contentType: 'application/typescript',
110
+ hash: computeHash(typeDefs),
111
+ size: typeDefs.length,
112
+ },
113
+ ];
114
+
115
+ // Create typed Module Original
116
+ const moduleAsset = await sdk.lifecycle.createTypedOriginal(
117
+ OriginalKind.Module,
118
+ {
119
+ kind: OriginalKind.Module,
120
+ name: 'greeting-utils',
121
+ version: '1.0.0',
122
+ description: 'A simple greeting utility module for generating personalized messages',
123
+ resources,
124
+ tags: ['utility', 'greeting', 'message', 'text'],
125
+ author: {
126
+ name: 'Originals Developer',
127
+ email: 'dev@originals.example',
128
+ },
129
+ license: 'MIT',
130
+ homepage: 'https://github.com/originals/greeting-utils',
131
+ metadata: {
132
+ format: 'esm',
133
+ main: 'index.js',
134
+ types: 'index.d.ts',
135
+ exports: {
136
+ '.': {
137
+ import: './index.js',
138
+ types: './index.d.ts',
139
+ },
140
+ },
141
+ sideEffects: false,
142
+ },
143
+ }
144
+ );
145
+
146
+ console.log('Created Module Original:');
147
+ console.log(` ID: ${moduleAsset.id}`);
148
+ console.log(` Layer: ${moduleAsset.currentLayer}`);
149
+ console.log(` Resources: ${moduleAsset.resources.length}`);
150
+ console.log('');
151
+
152
+ // Get the manifest back
153
+ const manifest = sdk.lifecycle.getManifest(moduleAsset);
154
+ if (manifest && manifest.metadata) {
155
+ const meta = manifest.metadata as { format?: string; main?: string };
156
+ console.log('Manifest details:');
157
+ console.log(` Name: ${manifest.name}`);
158
+ console.log(` Version: ${manifest.version}`);
159
+ console.log(` Format: ${meta.format}`);
160
+ console.log(` Main: ${meta.main}`);
161
+ }
162
+ console.log('');
163
+ }
164
+
165
+ /**
166
+ * Create a Module Original with dependencies
167
+ */
168
+ async function createModuleWithDependencies(): Promise<void> {
169
+ console.log('=== Creating Module with Dependencies ===\n');
170
+
171
+ const sdk = OriginalsSDK.create({
172
+ network: 'regtest',
173
+ defaultKeyType: 'Ed25519',
174
+ ordinalsProvider: new OrdMockProvider(),
175
+ });
176
+
177
+ // Define module code that depends on another module
178
+ const moduleCode = `
179
+ /**
180
+ * Advanced formatter module that extends greeting-utils
181
+ */
182
+ import { greet, farewell } from 'greeting-utils';
183
+
184
+ /**
185
+ * Format a message with a timestamp
186
+ * @param message - The message to format
187
+ * @returns Formatted message with timestamp
188
+ */
189
+ export function withTimestamp(message) {
190
+ const now = new Date().toISOString();
191
+ return \`[\${now}] \${message}\`;
192
+ }
193
+
194
+ /**
195
+ * Create a welcome message with timestamp
196
+ * @param name - The name to welcome
197
+ * @returns Timestamped welcome message
198
+ */
199
+ export function timedGreeting(name) {
200
+ return withTimestamp(greet(name));
201
+ }
202
+
203
+ /**
204
+ * Create a farewell message with timestamp
205
+ * @param name - The name to say goodbye to
206
+ * @returns Timestamped farewell message
207
+ */
208
+ export function timedFarewell(name) {
209
+ return withTimestamp(farewell(name));
210
+ }
211
+
212
+ /**
213
+ * Format text with various styles
214
+ * @param text - Text to format
215
+ * @param style - Style option: 'upper' | 'lower' | 'title'
216
+ */
217
+ export function formatText(text, style = 'title') {
218
+ switch (style) {
219
+ case 'upper': return text.toUpperCase();
220
+ case 'lower': return text.toLowerCase();
221
+ case 'title': return text.split(' ').map(w => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase()).join(' ');
222
+ default: return text;
223
+ }
224
+ }
225
+ `.trim();
226
+
227
+ const moduleAsset = await sdk.lifecycle.createTypedOriginal(
228
+ OriginalKind.Module,
229
+ {
230
+ kind: OriginalKind.Module,
231
+ name: 'advanced-formatter',
232
+ version: '1.0.0',
233
+ description: 'Advanced text formatting utilities',
234
+ resources: [{
235
+ id: 'index.js',
236
+ type: 'code',
237
+ content: moduleCode,
238
+ contentType: 'application/javascript',
239
+ hash: computeHash(moduleCode),
240
+ size: moduleCode.length,
241
+ }],
242
+ // Declare dependency on greeting-utils
243
+ dependencies: [{
244
+ did: 'did:peer:example-greeting-utils-did',
245
+ name: 'greeting-utils',
246
+ version: '^1.0.0',
247
+ }],
248
+ tags: ['formatter', 'text', 'utility'],
249
+ license: 'MIT',
250
+ metadata: {
251
+ format: 'esm',
252
+ main: 'index.js',
253
+ peerDependencies: {
254
+ 'greeting-utils': '^1.0.0',
255
+ },
256
+ },
257
+ }
258
+ );
259
+
260
+ console.log('Created Module with dependencies:');
261
+ console.log(` ID: ${moduleAsset.id}`);
262
+ console.log(` Dependencies: ${moduleAsset.resources.length > 0 ? 'greeting-utils ^1.0.0' : 'none'}`);
263
+ console.log('');
264
+ }
265
+
266
+ /**
267
+ * Validate a module manifest before creation
268
+ */
269
+ function validateModuleManifest(): void {
270
+ console.log('=== Validating Module Manifest ===\n');
271
+
272
+ const registry = KindRegistry.getInstance();
273
+
274
+ // Valid manifest
275
+ const validManifest = {
276
+ kind: OriginalKind.Module,
277
+ name: 'my-module',
278
+ version: '1.0.0',
279
+ resources: [{
280
+ id: 'index.js',
281
+ type: 'code',
282
+ contentType: 'application/javascript',
283
+ hash: 'abc123',
284
+ }],
285
+ metadata: {
286
+ format: 'esm' as const,
287
+ main: 'index.js',
288
+ },
289
+ };
290
+
291
+ const validResult = registry.validate(validManifest);
292
+ console.log('Valid manifest result:', validResult.isValid ? 'VALID' : 'INVALID');
293
+ if (validResult.warnings.length > 0) {
294
+ console.log('Warnings:', validResult.warnings.map(w => w.message).join(', '));
295
+ }
296
+ console.log('');
297
+
298
+ // Invalid manifest (missing required field)
299
+ const invalidManifest = {
300
+ kind: OriginalKind.Module,
301
+ name: 'bad-module',
302
+ version: '1.0.0',
303
+ resources: [],
304
+ metadata: {
305
+ format: 'esm' as const,
306
+ // Missing 'main' field!
307
+ },
308
+ };
309
+
310
+ // Cast through unknown since this is intentionally invalid for testing validation
311
+ const invalidResult = registry.validate(invalidManifest as unknown as OriginalManifest<OriginalKind.Module>);
312
+ console.log('Invalid manifest result:', invalidResult.isValid ? 'VALID' : 'INVALID');
313
+ if (!invalidResult.isValid) {
314
+ console.log('Errors:');
315
+ invalidResult.errors.forEach(e => {
316
+ console.log(` - [${e.code}] ${e.message}`);
317
+ });
318
+ }
319
+ console.log('');
320
+ }
321
+
322
+ /**
323
+ * Estimate costs for module inscription
324
+ */
325
+ async function estimateModuleCosts(): Promise<void> {
326
+ console.log('=== Estimating Module Inscription Costs ===\n');
327
+
328
+ const sdk = OriginalsSDK.create({
329
+ network: 'regtest',
330
+ defaultKeyType: 'Ed25519',
331
+ ordinalsProvider: new OrdMockProvider(),
332
+ });
333
+
334
+ const moduleCode = `export const VERSION = '1.0.0';`;
335
+
336
+ const moduleAsset = await sdk.lifecycle.createTypedOriginal(
337
+ OriginalKind.Module,
338
+ {
339
+ kind: OriginalKind.Module,
340
+ name: 'tiny-module',
341
+ version: '1.0.0',
342
+ resources: [{
343
+ id: 'index.js',
344
+ type: 'code',
345
+ content: moduleCode,
346
+ contentType: 'application/javascript',
347
+ hash: computeHash(moduleCode),
348
+ size: moduleCode.length,
349
+ }],
350
+ metadata: {
351
+ format: 'esm',
352
+ main: 'index.js',
353
+ },
354
+ }
355
+ );
356
+
357
+ // Estimate costs at different fee rates
358
+ const feeRates = [1, 5, 10, 20, 50];
359
+
360
+ console.log('Cost estimates by fee rate:');
361
+ for (const feeRate of feeRates) {
362
+ const cost = await sdk.lifecycle.estimateCost(moduleAsset, 'did:btco', feeRate);
363
+ console.log(` ${feeRate} sat/vB: ${cost.totalSats} sats (~${(cost.totalSats / 100000000).toFixed(8)} BTC)`);
364
+ }
365
+ console.log('');
366
+
367
+ // Validate migration before attempting
368
+ const validation = sdk.lifecycle.validateMigration(moduleAsset, 'did:btco');
369
+ console.log('Migration validation:');
370
+ console.log(` Valid: ${validation.valid}`);
371
+ console.log(` Checks:`);
372
+ Object.entries(validation.checks).forEach(([check, passed]) => {
373
+ console.log(` - ${check}: ${passed ? '✓' : '✗'}`);
374
+ });
375
+ console.log('');
376
+ }
377
+
378
+ /**
379
+ * Create templates using KindRegistry
380
+ */
381
+ function useModuleTemplates(): void {
382
+ console.log('=== Using Module Templates ===\n');
383
+
384
+ // Create a template for a Module
385
+ const template = KindRegistry.createTemplate(OriginalKind.Module, 'my-new-module', '0.1.0');
386
+
387
+ console.log('Module template:');
388
+ console.log(JSON.stringify(template, null, 2));
389
+ console.log('');
390
+
391
+ // Parse kind from string
392
+ const kindFromShort = KindRegistry.parseKind('module');
393
+ const kindFromFull = KindRegistry.parseKind('originals:kind:module');
394
+
395
+ console.log('Kind parsing:');
396
+ console.log(` 'module' -> ${kindFromShort}`);
397
+ console.log(` 'originals:kind:module' -> ${kindFromFull}`);
398
+ console.log(` Display name: ${KindRegistry.getDisplayName(OriginalKind.Module)}`);
399
+ console.log(` Short name: ${KindRegistry.getShortName(OriginalKind.Module)}`);
400
+ console.log('');
401
+ }
402
+
403
+ /**
404
+ * Main execution
405
+ */
406
+ async function main(): Promise<void> {
407
+ try {
408
+ await createSimpleModule();
409
+ await createModuleWithDependencies();
410
+ validateModuleManifest();
411
+ await estimateModuleCosts();
412
+ useModuleTemplates();
413
+
414
+ console.log('=== All Module Examples Completed ===');
415
+ } catch (error) {
416
+ console.error('Error:', error);
417
+ process.exit(1);
418
+ }
419
+ }
420
+
421
+ // Export for use as module
422
+ export {
423
+ createSimpleModule,
424
+ createModuleWithDependencies,
425
+ validateModuleManifest,
426
+ estimateModuleCosts,
427
+ useModuleTemplates,
428
+ main
429
+ };
430
+
431
+ // Run if executed directly
432
+ if (require.main === module) {
433
+ void main();
434
+ }
435
+