@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,112 +0,0 @@
1
- /**
2
- * CheckpointManager - Creates and manages migration checkpoints for rollback
3
- */
4
-
5
- import { v4 as uuidv4 } from 'uuid';
6
- import {
7
- MigrationOptions,
8
- MigrationCheckpoint,
9
- ICheckpointManager
10
- } from '../types';
11
- import { OriginalsConfig } from '../../types';
12
- import { DIDManager } from '../../did/DIDManager';
13
- import { CredentialManager } from '../../vc/CredentialManager';
14
- import { CheckpointStorage } from './CheckpointStorage';
15
-
16
- export class CheckpointManager implements ICheckpointManager {
17
- private storage: CheckpointStorage;
18
-
19
- constructor(
20
- private config: OriginalsConfig,
21
- private didManager: DIDManager,
22
- private credentialManager: CredentialManager
23
- ) {
24
- this.storage = new CheckpointStorage(config);
25
- }
26
-
27
- /**
28
- * Create a checkpoint before migration
29
- */
30
- async createCheckpoint(migrationId: string, options: MigrationOptions): Promise<MigrationCheckpoint> {
31
- try {
32
- const checkpointId = `chk_${uuidv4()}`;
33
-
34
- // Resolve source DID document
35
- const didDocument = await this.didManager.resolveDID(options.sourceDid);
36
- if (!didDocument) {
37
- throw new Error(`Could not resolve source DID: ${options.sourceDid}`);
38
- }
39
-
40
- // Extract source layer
41
- const sourceLayer = this.extractLayer(options.sourceDid);
42
- if (!sourceLayer) {
43
- throw new Error(`Invalid source DID format: ${options.sourceDid}`);
44
- }
45
-
46
- // Create checkpoint
47
- const checkpoint: MigrationCheckpoint = {
48
- checkpointId,
49
- migrationId,
50
- timestamp: Date.now(),
51
- sourceDid: options.sourceDid,
52
- sourceLayer,
53
- didDocument,
54
- credentials: [], // Would be populated by querying credential store
55
- storageReferences: {}, // Would be populated by querying storage adapter
56
- lifecycleState: {}, // Would be populated by querying lifecycle manager
57
- ownershipProofs: [], // Would be populated if available
58
- metadata: options.metadata || {}
59
- };
60
-
61
- // Store checkpoint
62
- await this.storage.save(checkpoint);
63
-
64
- return checkpoint;
65
- } catch (error) {
66
- throw new Error(`Failed to create checkpoint: ${error instanceof Error ? error.message : String(error)}`);
67
- }
68
- }
69
-
70
- /**
71
- * Retrieve a checkpoint by ID
72
- */
73
- async getCheckpoint(checkpointId: string): Promise<MigrationCheckpoint | null> {
74
- try {
75
- return await this.storage.get(checkpointId);
76
- } catch (error) {
77
- console.error(`Error retrieving checkpoint ${checkpointId}:`, error);
78
- return null;
79
- }
80
- }
81
-
82
- /**
83
- * Delete a checkpoint (after successful migration or cleanup)
84
- */
85
- async deleteCheckpoint(checkpointId: string): Promise<void> {
86
- try {
87
- await this.storage.delete(checkpointId);
88
- } catch (error) {
89
- console.error(`Error deleting checkpoint ${checkpointId}:`, error);
90
- // Don't throw - deletion failures shouldn't break migrations
91
- }
92
- }
93
-
94
- /**
95
- * Clean up old checkpoints (older than 24 hours for successful migrations)
96
- */
97
- async cleanupOldCheckpoints(): Promise<void> {
98
- try {
99
- const cutoffTime = Date.now() - (24 * 60 * 60 * 1000); // 24 hours
100
- await this.storage.deleteOlderThan(cutoffTime);
101
- } catch (error) {
102
- console.error('Error cleaning up old checkpoints:', error);
103
- }
104
- }
105
-
106
- private extractLayer(did: string): 'peer' | 'webvh' | 'btco' | null {
107
- if (did.startsWith('did:peer:')) return 'peer';
108
- if (did.startsWith('did:webvh:')) return 'webvh';
109
- if (did.startsWith('did:btco:')) return 'btco';
110
- return null;
111
- }
112
- }
@@ -1,101 +0,0 @@
1
- /**
2
- * CheckpointStorage - Persists checkpoints to storage
3
- */
4
-
5
- import { MigrationCheckpoint } from '../types';
6
- import { OriginalsConfig } from '../../types';
7
-
8
- export class CheckpointStorage {
9
- private checkpoints: Map<string, MigrationCheckpoint>;
10
-
11
- constructor(private config: OriginalsConfig) {
12
- this.checkpoints = new Map();
13
- }
14
-
15
- /**
16
- * Save a checkpoint
17
- */
18
- async save(checkpoint: MigrationCheckpoint): Promise<void> {
19
- if (!checkpoint.checkpointId) {
20
- throw new Error('Checkpoint must have an ID');
21
- }
22
- this.checkpoints.set(checkpoint.checkpointId, checkpoint);
23
-
24
- // Optionally persist to configured storage adapter
25
- const storageAdapter = (this.config as any).storageAdapter;
26
- if (storageAdapter && typeof storageAdapter.put === 'function') {
27
- try {
28
- const data = JSON.stringify(checkpoint);
29
- const key = `checkpoints/${checkpoint.checkpointId}.json`;
30
- await storageAdapter.put(key, Buffer.from(data), { contentType: 'application/json' });
31
- } catch (error) {
32
- console.error('Failed to persist checkpoint to storage:', error);
33
- // Continue - in-memory checkpoint is still available
34
- }
35
- }
36
- }
37
-
38
- /**
39
- * Retrieve a checkpoint
40
- */
41
- async get(checkpointId: string): Promise<MigrationCheckpoint | null> {
42
- // Try in-memory first
43
- const memoryCheckpoint = this.checkpoints.get(checkpointId);
44
- if (memoryCheckpoint) {
45
- return memoryCheckpoint;
46
- }
47
-
48
- // Try loading from storage adapter
49
- const storageAdapter = (this.config as any).storageAdapter;
50
- if (storageAdapter && typeof storageAdapter.get === 'function') {
51
- try {
52
- const key = `checkpoints/${checkpointId}.json`;
53
- const data = await storageAdapter.get(key);
54
- if (data) {
55
- const checkpoint = JSON.parse(data.toString());
56
- this.checkpoints.set(checkpointId, checkpoint);
57
- return checkpoint;
58
- }
59
- } catch (error) {
60
- // Checkpoint not found in storage
61
- }
62
- }
63
-
64
- return null;
65
- }
66
-
67
- /**
68
- * Delete a checkpoint
69
- */
70
- async delete(checkpointId: string): Promise<void> {
71
- this.checkpoints.delete(checkpointId);
72
-
73
- // Also delete from storage adapter
74
- const storageAdapter = (this.config as any).storageAdapter;
75
- if (storageAdapter && typeof storageAdapter.delete === 'function') {
76
- try {
77
- const key = `checkpoints/${checkpointId}.json`;
78
- await storageAdapter.delete(key);
79
- } catch (error) {
80
- // Ignore deletion errors
81
- }
82
- }
83
- }
84
-
85
- /**
86
- * Delete checkpoints older than specified timestamp
87
- */
88
- async deleteOlderThan(cutoffTime: number): Promise<void> {
89
- const toDelete: string[] = [];
90
-
91
- for (const [id, checkpoint] of this.checkpoints.entries()) {
92
- if (checkpoint.timestamp < cutoffTime) {
93
- toDelete.push(id);
94
- }
95
- }
96
-
97
- for (const id of toDelete) {
98
- await this.delete(id);
99
- }
100
- }
101
- }
@@ -1,33 +0,0 @@
1
- /**
2
- * Migration module exports
3
- * Provides DID layer migration capabilities with validation, checkpoints, and rollbacks
4
- */
5
-
6
- export { MigrationManager } from './MigrationManager';
7
- export * from './types';
8
-
9
- // Validators
10
- export { ValidationPipeline } from './validation/ValidationPipeline';
11
- export { DIDCompatibilityValidator } from './validation/DIDCompatibilityValidator';
12
- export { CredentialValidator } from './validation/CredentialValidator';
13
- export { StorageValidator } from './validation/StorageValidator';
14
- export { LifecycleValidator } from './validation/LifecycleValidator';
15
- export { BitcoinValidator } from './validation/BitcoinValidator';
16
-
17
- // Checkpoint and Rollback
18
- export { CheckpointManager } from './checkpoint/CheckpointManager';
19
- export { CheckpointStorage } from './checkpoint/CheckpointStorage';
20
- export { RollbackManager } from './rollback/RollbackManager';
21
-
22
- // State Management
23
- export { StateTracker } from './state/StateTracker';
24
- export { StateMachine } from './state/StateMachine';
25
-
26
- // Audit
27
- export { AuditLogger } from './audit/AuditLogger';
28
-
29
- // Operations
30
- export { BaseMigration } from './operations/BaseMigration';
31
- export { PeerToWebvhMigration } from './operations/PeerToWebvhMigration';
32
- export { WebvhToBtcoMigration } from './operations/WebvhToBtcoMigration';
33
- export { PeerToBtcoMigration } from './operations/PeerToBtcoMigration';
@@ -1,126 +0,0 @@
1
- /**
2
- * BaseMigration - Base class for all migration operations
3
- */
4
-
5
- import {
6
- MigrationOptions,
7
- MigrationResult,
8
- MigrationError,
9
- MigrationErrorType,
10
- MigrationStateEnum,
11
- CostEstimate
12
- } from '../types';
13
- import { OriginalsConfig, DIDDocument } from '../../types';
14
- import { DIDManager } from '../../did/DIDManager';
15
- import { CredentialManager } from '../../vc/CredentialManager';
16
- import { StateTracker } from '../state/StateTracker';
17
- import { EventEmitter } from '../../events/EventEmitter';
18
-
19
- export abstract class BaseMigration {
20
- protected eventEmitter: EventEmitter;
21
-
22
- constructor(
23
- protected config: OriginalsConfig,
24
- protected didManager: DIDManager,
25
- protected credentialManager: CredentialManager,
26
- protected stateTracker: StateTracker
27
- ) {
28
- this.eventEmitter = new EventEmitter();
29
- }
30
-
31
- /**
32
- * Execute the migration (to be implemented by subclasses)
33
- */
34
- abstract executeMigration(
35
- options: MigrationOptions,
36
- migrationId: string
37
- ): Promise<{ targetDid: string; didDocument: DIDDocument }>;
38
-
39
- /**
40
- * Get estimated cost (to be implemented by subclasses)
41
- */
42
- abstract estimateCost(options: MigrationOptions): Promise<CostEstimate>;
43
-
44
- /**
45
- * Emit migration event
46
- */
47
- protected async emitEvent(type: string, data: any): Promise<void> {
48
- try {
49
- await this.eventEmitter.emit({
50
- type,
51
- timestamp: new Date().toISOString(),
52
- ...data
53
- });
54
- } catch (error) {
55
- console.error(`Error emitting event ${type}:`, error);
56
- }
57
- }
58
-
59
- /**
60
- * Create migration error
61
- */
62
- protected createError(
63
- type: MigrationErrorType,
64
- code: string,
65
- message: string,
66
- migrationId?: string,
67
- details?: any
68
- ): MigrationError {
69
- return {
70
- type,
71
- code,
72
- message,
73
- technicalDetails: details ? JSON.stringify(details) : undefined,
74
- migrationId,
75
- timestamp: Date.now()
76
- };
77
- }
78
-
79
- /**
80
- * Update migration state with error handling
81
- */
82
- protected async updateStateWithRetry(
83
- migrationId: string,
84
- updates: any,
85
- maxRetries: number = 3
86
- ): Promise<void> {
87
- let lastError: Error | null = null;
88
-
89
- for (let attempt = 0; attempt < maxRetries; attempt++) {
90
- try {
91
- await this.stateTracker.updateState(migrationId, updates);
92
- return;
93
- } catch (error) {
94
- lastError = error instanceof Error ? error : new Error(String(error));
95
-
96
- if (attempt < maxRetries - 1) {
97
- // Exponential backoff: 100ms, 200ms, 400ms
98
- await new Promise(resolve => setTimeout(resolve, 100 * Math.pow(2, attempt)));
99
- }
100
- }
101
- }
102
-
103
- throw lastError || new Error('Failed to update state after retries');
104
- }
105
-
106
- /**
107
- * Resolve source DID document
108
- */
109
- protected async resolveSourceDid(sourceDid: string): Promise<DIDDocument> {
110
- const didDocument = await this.didManager.resolveDID(sourceDid);
111
- if (!didDocument) {
112
- throw new Error(`Could not resolve source DID: ${sourceDid}`);
113
- }
114
- return didDocument;
115
- }
116
-
117
- /**
118
- * Extract layer from DID
119
- */
120
- protected extractLayer(did: string): 'peer' | 'webvh' | 'btco' {
121
- if (did.startsWith('did:peer:')) return 'peer';
122
- if (did.startsWith('did:webvh:')) return 'webvh';
123
- if (did.startsWith('did:btco:')) return 'btco';
124
- throw new Error(`Unsupported DID method: ${did}`);
125
- }
126
- }
@@ -1,105 +0,0 @@
1
- /**
2
- * PeerToBtcoMigration - Handles direct migration from did:peer to did:btco
3
- */
4
-
5
- import {
6
- MigrationOptions,
7
- CostEstimate,
8
- MigrationStateEnum
9
- } from '../types';
10
- import { DIDDocument, OriginalsConfig } from '../../types';
11
- import { BaseMigration } from './BaseMigration';
12
- import { BitcoinManager } from '../../bitcoin/BitcoinManager';
13
- import { DIDManager } from '../../did/DIDManager';
14
- import { CredentialManager } from '../../vc/CredentialManager';
15
- import { StateTracker } from '../state/StateTracker';
16
-
17
- export class PeerToBtcoMigration extends BaseMigration {
18
- private bitcoinManager: BitcoinManager;
19
-
20
- constructor(
21
- config: OriginalsConfig,
22
- didManager: DIDManager,
23
- credentialManager: CredentialManager,
24
- stateTracker: StateTracker,
25
- bitcoinManager: BitcoinManager
26
- ) {
27
- super(config, didManager, credentialManager, stateTracker);
28
- this.bitcoinManager = bitcoinManager;
29
- }
30
-
31
- /**
32
- * Execute peer → btco migration (direct, skipping webvh layer)
33
- */
34
- async executeMigration(
35
- options: MigrationOptions,
36
- migrationId: string
37
- ): Promise<{ targetDid: string; didDocument: DIDDocument }> {
38
- // Resolve source DID
39
- const sourceDid = await this.resolveSourceDid(options.sourceDid);
40
-
41
- await this.updateStateWithRetry(migrationId, {
42
- state: MigrationStateEnum.IN_PROGRESS,
43
- currentOperation: 'Creating Bitcoin inscription',
44
- progress: 30
45
- });
46
-
47
- // Create Bitcoin inscription with DID document
48
- const manifest = {
49
- didDocument: sourceDid,
50
- migrationId,
51
- timestamp: new Date().toISOString()
52
- };
53
- const payload = Buffer.from(JSON.stringify(manifest));
54
-
55
- await this.updateStateWithRetry(migrationId, {
56
- state: MigrationStateEnum.ANCHORING,
57
- currentOperation: 'Anchoring to Bitcoin',
58
- progress: 50
59
- });
60
-
61
- const inscription = await this.bitcoinManager.inscribeData(
62
- payload,
63
- 'application/json',
64
- options.feeRate
65
- );
66
-
67
- // Use satoshi identifier or inscription ID
68
- const satoshiId = inscription.satoshi || inscription.inscriptionId.split('i')[0];
69
-
70
- await this.updateStateWithRetry(migrationId, {
71
- currentOperation: 'Creating btco DID document',
72
- progress: 80
73
- });
74
-
75
- // Migrate DID document to btco
76
- const migratedDoc = await this.didManager.migrateToDIDBTCO(sourceDid, satoshiId);
77
-
78
- await this.updateStateWithRetry(migrationId, {
79
- currentOperation: 'Migration completed',
80
- progress: 100,
81
- targetDid: migratedDoc.id
82
- });
83
-
84
- return {
85
- targetDid: migratedDoc.id,
86
- didDocument: migratedDoc
87
- };
88
- }
89
-
90
- /**
91
- * Estimate cost for peer → btco migration
92
- */
93
- async estimateCost(options: MigrationOptions): Promise<CostEstimate> {
94
- const feeRate = options.feeRate || 10; // default 10 sat/vB
95
- const estimatedSize = 1024; // ~1KB for typical DID document
96
- const networkFees = estimatedSize * feeRate;
97
-
98
- return {
99
- storageCost: 0,
100
- networkFees,
101
- totalCost: networkFees,
102
- currency: 'sats'
103
- };
104
- }
105
- }
@@ -1,62 +0,0 @@
1
- /**
2
- * PeerToWebvhMigration - Handles migration from did:peer to did:webvh
3
- */
4
-
5
- import {
6
- MigrationOptions,
7
- CostEstimate,
8
- MigrationStateEnum
9
- } from '../types';
10
- import { DIDDocument } from '../../types';
11
- import { BaseMigration } from './BaseMigration';
12
-
13
- export class PeerToWebvhMigration extends BaseMigration {
14
- /**
15
- * Execute peer → webvh migration
16
- */
17
- async executeMigration(
18
- options: MigrationOptions,
19
- migrationId: string
20
- ): Promise<{ targetDid: string; didDocument: DIDDocument }> {
21
- // Resolve source DID
22
- const sourceDid = await this.resolveSourceDid(options.sourceDid);
23
-
24
- // Validate domain is provided
25
- if (!options.domain) {
26
- throw new Error('Domain is required for webvh migrations');
27
- }
28
-
29
- await this.updateStateWithRetry(migrationId, {
30
- state: MigrationStateEnum.IN_PROGRESS,
31
- currentOperation: 'Creating webvh DID document',
32
- progress: 30
33
- });
34
-
35
- // Migrate DID document to webvh
36
- const migratedDoc = await this.didManager.migrateToDIDWebVH(sourceDid, options.domain);
37
-
38
- await this.updateStateWithRetry(migrationId, {
39
- currentOperation: 'Migration completed',
40
- progress: 100,
41
- targetDid: migratedDoc.id
42
- });
43
-
44
- return {
45
- targetDid: migratedDoc.id,
46
- didDocument: migratedDoc
47
- };
48
- }
49
-
50
- /**
51
- * Estimate cost for peer → webvh migration
52
- */
53
- async estimateCost(options: MigrationOptions): Promise<CostEstimate> {
54
- // Web hosting is typically negligible cost
55
- return {
56
- storageCost: 0,
57
- networkFees: 0,
58
- totalCost: 0,
59
- currency: 'sats'
60
- };
61
- }
62
- }
@@ -1,105 +0,0 @@
1
- /**
2
- * WebvhToBtcoMigration - Handles migration from did:webvh to did:btco
3
- */
4
-
5
- import {
6
- MigrationOptions,
7
- CostEstimate,
8
- MigrationStateEnum
9
- } from '../types';
10
- import { DIDDocument, OriginalsConfig } from '../../types';
11
- import { BaseMigration } from './BaseMigration';
12
- import { BitcoinManager } from '../../bitcoin/BitcoinManager';
13
- import { DIDManager } from '../../did/DIDManager';
14
- import { CredentialManager } from '../../vc/CredentialManager';
15
- import { StateTracker } from '../state/StateTracker';
16
-
17
- export class WebvhToBtcoMigration extends BaseMigration {
18
- private bitcoinManager: BitcoinManager;
19
-
20
- constructor(
21
- config: OriginalsConfig,
22
- didManager: DIDManager,
23
- credentialManager: CredentialManager,
24
- stateTracker: StateTracker,
25
- bitcoinManager: BitcoinManager
26
- ) {
27
- super(config, didManager, credentialManager, stateTracker);
28
- this.bitcoinManager = bitcoinManager;
29
- }
30
-
31
- /**
32
- * Execute webvh → btco migration
33
- */
34
- async executeMigration(
35
- options: MigrationOptions,
36
- migrationId: string
37
- ): Promise<{ targetDid: string; didDocument: DIDDocument }> {
38
- // Resolve source DID
39
- const sourceDid = await this.resolveSourceDid(options.sourceDid);
40
-
41
- await this.updateStateWithRetry(migrationId, {
42
- state: MigrationStateEnum.IN_PROGRESS,
43
- currentOperation: 'Creating Bitcoin inscription',
44
- progress: 30
45
- });
46
-
47
- // Create Bitcoin inscription with DID document
48
- const manifest = {
49
- didDocument: sourceDid,
50
- migrationId,
51
- timestamp: new Date().toISOString()
52
- };
53
- const payload = Buffer.from(JSON.stringify(manifest));
54
-
55
- await this.updateStateWithRetry(migrationId, {
56
- state: MigrationStateEnum.ANCHORING,
57
- currentOperation: 'Anchoring to Bitcoin',
58
- progress: 50
59
- });
60
-
61
- const inscription = await this.bitcoinManager.inscribeData(
62
- payload,
63
- 'application/json',
64
- options.feeRate
65
- );
66
-
67
- // Use satoshi identifier or inscription ID
68
- const satoshiId = inscription.satoshi || inscription.inscriptionId.split('i')[0];
69
-
70
- await this.updateStateWithRetry(migrationId, {
71
- currentOperation: 'Creating btco DID document',
72
- progress: 80
73
- });
74
-
75
- // Migrate DID document to btco
76
- const migratedDoc = await this.didManager.migrateToDIDBTCO(sourceDid, satoshiId);
77
-
78
- await this.updateStateWithRetry(migrationId, {
79
- currentOperation: 'Migration completed',
80
- progress: 100,
81
- targetDid: migratedDoc.id
82
- });
83
-
84
- return {
85
- targetDid: migratedDoc.id,
86
- didDocument: migratedDoc
87
- };
88
- }
89
-
90
- /**
91
- * Estimate cost for webvh → btco migration
92
- */
93
- async estimateCost(options: MigrationOptions): Promise<CostEstimate> {
94
- const feeRate = options.feeRate || 10; // default 10 sat/vB
95
- const estimatedSize = 1024; // ~1KB for typical DID document
96
- const networkFees = estimatedSize * feeRate;
97
-
98
- return {
99
- storageCost: 0,
100
- networkFees,
101
- totalCost: networkFees,
102
- currency: 'sats'
103
- };
104
- }
105
- }