@originals/sdk 1.4.3 → 1.5.0

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 (222) hide show
  1. package/dist/adapters/FeeOracleMock.d.ts +6 -0
  2. package/dist/adapters/FeeOracleMock.js +8 -0
  3. package/dist/adapters/index.d.ts +4 -0
  4. package/dist/adapters/index.js +4 -0
  5. package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
  6. package/dist/adapters/providers/OrdHttpProvider.js +110 -0
  7. package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
  8. package/dist/adapters/providers/OrdMockProvider.js +75 -0
  9. package/dist/adapters/types.d.ts +71 -0
  10. package/dist/adapters/types.js +1 -0
  11. package/dist/bitcoin/BitcoinManager.d.ts +15 -0
  12. package/dist/bitcoin/BitcoinManager.js +262 -0
  13. package/dist/bitcoin/BroadcastClient.d.ts +30 -0
  14. package/dist/bitcoin/BroadcastClient.js +35 -0
  15. package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
  16. package/dist/bitcoin/OrdinalsClient.js +105 -0
  17. package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
  18. package/dist/bitcoin/PSBTBuilder.js +80 -0
  19. package/dist/bitcoin/fee-calculation.d.ts +14 -0
  20. package/dist/bitcoin/fee-calculation.js +31 -0
  21. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
  22. package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
  23. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
  24. package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
  25. package/dist/bitcoin/providers/types.d.ts +63 -0
  26. package/dist/bitcoin/providers/types.js +1 -0
  27. package/dist/bitcoin/transactions/commit.d.ts +89 -0
  28. package/dist/bitcoin/transactions/commit.js +311 -0
  29. package/dist/bitcoin/transactions/index.d.ts +7 -0
  30. package/dist/bitcoin/transactions/index.js +8 -0
  31. package/dist/bitcoin/transfer.d.ts +9 -0
  32. package/dist/bitcoin/transfer.js +26 -0
  33. package/dist/bitcoin/utxo-selection.d.ts +78 -0
  34. package/dist/bitcoin/utxo-selection.js +237 -0
  35. package/dist/bitcoin/utxo.d.ts +26 -0
  36. package/dist/bitcoin/utxo.js +78 -0
  37. package/dist/contexts/credentials-v1.json +195 -0
  38. package/dist/contexts/credentials-v2-examples.json +5 -0
  39. package/dist/contexts/credentials-v2.json +301 -0
  40. package/dist/contexts/credentials.json +195 -0
  41. package/dist/contexts/data-integrity-v2.json +81 -0
  42. package/dist/contexts/dids.json +57 -0
  43. package/dist/contexts/ed255192020.json +93 -0
  44. package/dist/contexts/ordinals-plus.json +23 -0
  45. package/dist/contexts/originals.json +22 -0
  46. package/dist/core/OriginalsSDK.d.ts +158 -0
  47. package/dist/core/OriginalsSDK.js +274 -0
  48. package/dist/crypto/Multikey.d.ts +30 -0
  49. package/dist/crypto/Multikey.js +149 -0
  50. package/dist/crypto/Signer.d.ts +21 -0
  51. package/dist/crypto/Signer.js +196 -0
  52. package/dist/crypto/noble-init.d.ts +18 -0
  53. package/dist/crypto/noble-init.js +106 -0
  54. package/dist/did/BtcoDidResolver.d.ts +57 -0
  55. package/dist/did/BtcoDidResolver.js +166 -0
  56. package/dist/did/DIDManager.d.ts +101 -0
  57. package/dist/did/DIDManager.js +493 -0
  58. package/dist/did/Ed25519Verifier.d.ts +30 -0
  59. package/dist/did/Ed25519Verifier.js +59 -0
  60. package/dist/did/KeyManager.d.ts +17 -0
  61. package/dist/did/KeyManager.js +207 -0
  62. package/dist/did/WebVHManager.d.ts +100 -0
  63. package/dist/did/WebVHManager.js +312 -0
  64. package/dist/did/createBtcoDidDocument.d.ts +10 -0
  65. package/dist/did/createBtcoDidDocument.js +42 -0
  66. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
  67. package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
  68. package/dist/events/EventEmitter.d.ts +115 -0
  69. package/dist/events/EventEmitter.js +198 -0
  70. package/dist/events/index.d.ts +7 -0
  71. package/dist/events/index.js +6 -0
  72. package/dist/events/types.d.ts +286 -0
  73. package/dist/events/types.js +9 -0
  74. package/dist/examples/basic-usage.d.ts +3 -0
  75. package/dist/examples/basic-usage.js +62 -0
  76. package/dist/examples/create-module-original.d.ts +32 -0
  77. package/dist/examples/create-module-original.js +376 -0
  78. package/dist/examples/full-lifecycle-flow.d.ts +56 -0
  79. package/dist/examples/full-lifecycle-flow.js +419 -0
  80. package/dist/examples/run.d.ts +12 -0
  81. package/dist/examples/run.js +51 -0
  82. package/dist/index.d.ts +43 -0
  83. package/dist/index.js +52 -0
  84. package/dist/kinds/KindRegistry.d.ts +76 -0
  85. package/dist/kinds/KindRegistry.js +216 -0
  86. package/dist/kinds/index.d.ts +33 -0
  87. package/dist/kinds/index.js +36 -0
  88. package/dist/kinds/types.d.ts +363 -0
  89. package/dist/kinds/types.js +25 -0
  90. package/dist/kinds/validators/AgentValidator.d.ts +14 -0
  91. package/dist/kinds/validators/AgentValidator.js +155 -0
  92. package/dist/kinds/validators/AppValidator.d.ts +14 -0
  93. package/dist/kinds/validators/AppValidator.js +135 -0
  94. package/dist/kinds/validators/DatasetValidator.d.ts +14 -0
  95. package/dist/kinds/validators/DatasetValidator.js +148 -0
  96. package/dist/kinds/validators/DocumentValidator.d.ts +14 -0
  97. package/dist/kinds/validators/DocumentValidator.js +180 -0
  98. package/dist/kinds/validators/MediaValidator.d.ts +14 -0
  99. package/dist/kinds/validators/MediaValidator.js +172 -0
  100. package/dist/kinds/validators/ModuleValidator.d.ts +14 -0
  101. package/dist/kinds/validators/ModuleValidator.js +140 -0
  102. package/dist/kinds/validators/base.d.ts +96 -0
  103. package/dist/kinds/validators/base.js +218 -0
  104. package/dist/kinds/validators/index.d.ts +10 -0
  105. package/dist/kinds/validators/index.js +10 -0
  106. package/dist/lifecycle/BatchOperations.d.ts +147 -0
  107. package/dist/lifecycle/BatchOperations.js +251 -0
  108. package/dist/lifecycle/LifecycleManager.d.ts +362 -0
  109. package/dist/lifecycle/LifecycleManager.js +1692 -0
  110. package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
  111. package/dist/lifecycle/OriginalsAsset.js +380 -0
  112. package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
  113. package/dist/lifecycle/ProvenanceQuery.js +220 -0
  114. package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
  115. package/dist/lifecycle/ResourceVersioning.js +127 -0
  116. package/dist/migration/MigrationManager.d.ts +86 -0
  117. package/dist/migration/MigrationManager.js +412 -0
  118. package/dist/migration/audit/AuditLogger.d.ts +51 -0
  119. package/dist/migration/audit/AuditLogger.js +156 -0
  120. package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
  121. package/dist/migration/checkpoint/CheckpointManager.js +96 -0
  122. package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
  123. package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
  124. package/dist/migration/index.d.ts +22 -0
  125. package/dist/migration/index.js +27 -0
  126. package/dist/migration/operations/BaseMigration.d.ts +48 -0
  127. package/dist/migration/operations/BaseMigration.js +83 -0
  128. package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
  129. package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
  130. package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
  131. package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
  132. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
  133. package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
  134. package/dist/migration/rollback/RollbackManager.d.ts +29 -0
  135. package/dist/migration/rollback/RollbackManager.js +146 -0
  136. package/dist/migration/state/StateMachine.d.ts +25 -0
  137. package/dist/migration/state/StateMachine.js +76 -0
  138. package/dist/migration/state/StateTracker.d.ts +36 -0
  139. package/dist/migration/state/StateTracker.js +123 -0
  140. package/dist/migration/types.d.ts +306 -0
  141. package/dist/migration/types.js +33 -0
  142. package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
  143. package/dist/migration/validation/BitcoinValidator.js +83 -0
  144. package/dist/migration/validation/CredentialValidator.d.ts +13 -0
  145. package/dist/migration/validation/CredentialValidator.js +46 -0
  146. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
  147. package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
  148. package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
  149. package/dist/migration/validation/LifecycleValidator.js +52 -0
  150. package/dist/migration/validation/StorageValidator.d.ts +10 -0
  151. package/dist/migration/validation/StorageValidator.js +65 -0
  152. package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
  153. package/dist/migration/validation/ValidationPipeline.js +180 -0
  154. package/dist/resources/ResourceManager.d.ts +231 -0
  155. package/dist/resources/ResourceManager.js +573 -0
  156. package/dist/resources/index.d.ts +11 -0
  157. package/dist/resources/index.js +10 -0
  158. package/dist/resources/types.d.ts +93 -0
  159. package/dist/resources/types.js +80 -0
  160. package/dist/storage/LocalStorageAdapter.d.ts +11 -0
  161. package/dist/storage/LocalStorageAdapter.js +53 -0
  162. package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
  163. package/dist/storage/MemoryStorageAdapter.js +21 -0
  164. package/dist/storage/StorageAdapter.d.ts +16 -0
  165. package/dist/storage/StorageAdapter.js +1 -0
  166. package/dist/storage/index.d.ts +2 -0
  167. package/dist/storage/index.js +2 -0
  168. package/dist/types/bitcoin.d.ts +84 -0
  169. package/dist/types/bitcoin.js +1 -0
  170. package/dist/types/common.d.ts +82 -0
  171. package/dist/types/common.js +1 -0
  172. package/dist/types/credentials.d.ts +75 -0
  173. package/dist/types/credentials.js +1 -0
  174. package/dist/types/did.d.ts +26 -0
  175. package/dist/types/did.js +1 -0
  176. package/dist/types/index.d.ts +5 -0
  177. package/dist/types/index.js +5 -0
  178. package/dist/types/network.d.ts +78 -0
  179. package/dist/types/network.js +145 -0
  180. package/dist/utils/EventLogger.d.ts +71 -0
  181. package/dist/utils/EventLogger.js +232 -0
  182. package/dist/utils/Logger.d.ts +106 -0
  183. package/dist/utils/Logger.js +257 -0
  184. package/dist/utils/MetricsCollector.d.ts +110 -0
  185. package/dist/utils/MetricsCollector.js +264 -0
  186. package/dist/utils/bitcoin-address.d.ts +38 -0
  187. package/dist/utils/bitcoin-address.js +113 -0
  188. package/dist/utils/cbor.d.ts +2 -0
  189. package/dist/utils/cbor.js +9 -0
  190. package/dist/utils/encoding.d.ts +37 -0
  191. package/dist/utils/encoding.js +120 -0
  192. package/dist/utils/hash.d.ts +1 -0
  193. package/dist/utils/hash.js +5 -0
  194. package/dist/utils/retry.d.ts +10 -0
  195. package/dist/utils/retry.js +35 -0
  196. package/dist/utils/satoshi-validation.d.ts +60 -0
  197. package/dist/utils/satoshi-validation.js +156 -0
  198. package/dist/utils/serialization.d.ts +14 -0
  199. package/dist/utils/serialization.js +76 -0
  200. package/dist/utils/telemetry.d.ts +17 -0
  201. package/dist/utils/telemetry.js +24 -0
  202. package/dist/utils/validation.d.ts +5 -0
  203. package/dist/utils/validation.js +98 -0
  204. package/dist/vc/CredentialManager.d.ts +329 -0
  205. package/dist/vc/CredentialManager.js +615 -0
  206. package/dist/vc/Issuer.d.ts +27 -0
  207. package/dist/vc/Issuer.js +70 -0
  208. package/dist/vc/Verifier.d.ts +16 -0
  209. package/dist/vc/Verifier.js +50 -0
  210. package/dist/vc/cryptosuites/bbs.d.ts +44 -0
  211. package/dist/vc/cryptosuites/bbs.js +213 -0
  212. package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
  213. package/dist/vc/cryptosuites/bbsSimple.js +12 -0
  214. package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
  215. package/dist/vc/cryptosuites/eddsa.js +81 -0
  216. package/dist/vc/documentLoader.d.ts +16 -0
  217. package/dist/vc/documentLoader.js +59 -0
  218. package/dist/vc/proofs/data-integrity.d.ts +21 -0
  219. package/dist/vc/proofs/data-integrity.js +15 -0
  220. package/dist/vc/utils/jsonld.d.ts +2 -0
  221. package/dist/vc/utils/jsonld.js +15 -0
  222. package/package.json +2 -1
@@ -0,0 +1,96 @@
1
+ /**
2
+ * CheckpointManager - Creates and manages migration checkpoints for rollback
3
+ */
4
+ import { v4 as uuidv4 } from 'uuid';
5
+ import { CheckpointStorage } from './CheckpointStorage';
6
+ export class CheckpointManager {
7
+ constructor(config, didManager, credentialManager) {
8
+ this.config = config;
9
+ this.didManager = didManager;
10
+ this.credentialManager = credentialManager;
11
+ this.storage = new CheckpointStorage(config);
12
+ }
13
+ /**
14
+ * Create a checkpoint before migration
15
+ */
16
+ async createCheckpoint(migrationId, options) {
17
+ try {
18
+ const checkpointId = `chk_${uuidv4()}`;
19
+ // Resolve source DID document
20
+ const didDocument = await this.didManager.resolveDID(options.sourceDid);
21
+ if (!didDocument) {
22
+ throw new Error(`Could not resolve source DID: ${options.sourceDid}`);
23
+ }
24
+ // Extract source layer
25
+ const sourceLayer = this.extractLayer(options.sourceDid);
26
+ if (!sourceLayer) {
27
+ throw new Error(`Invalid source DID format: ${options.sourceDid}`);
28
+ }
29
+ // Create checkpoint
30
+ const checkpoint = {
31
+ checkpointId,
32
+ migrationId,
33
+ timestamp: Date.now(),
34
+ sourceDid: options.sourceDid,
35
+ sourceLayer,
36
+ didDocument,
37
+ credentials: [], // Would be populated by querying credential store
38
+ storageReferences: {}, // Would be populated by querying storage adapter
39
+ lifecycleState: {}, // Would be populated by querying lifecycle manager
40
+ ownershipProofs: [], // Would be populated if available
41
+ metadata: options.metadata || {}
42
+ };
43
+ // Store checkpoint
44
+ await this.storage.save(checkpoint);
45
+ return checkpoint;
46
+ }
47
+ catch (error) {
48
+ throw new Error(`Failed to create checkpoint: ${error instanceof Error ? error.message : String(error)}`);
49
+ }
50
+ }
51
+ /**
52
+ * Retrieve a checkpoint by ID
53
+ */
54
+ async getCheckpoint(checkpointId) {
55
+ try {
56
+ return await this.storage.get(checkpointId);
57
+ }
58
+ catch (error) {
59
+ console.error(`Error retrieving checkpoint ${checkpointId}:`, error);
60
+ return null;
61
+ }
62
+ }
63
+ /**
64
+ * Delete a checkpoint (after successful migration or cleanup)
65
+ */
66
+ async deleteCheckpoint(checkpointId) {
67
+ try {
68
+ await this.storage.delete(checkpointId);
69
+ }
70
+ catch (error) {
71
+ console.error(`Error deleting checkpoint ${checkpointId}:`, error);
72
+ // Don't throw - deletion failures shouldn't break migrations
73
+ }
74
+ }
75
+ /**
76
+ * Clean up old checkpoints (older than 24 hours for successful migrations)
77
+ */
78
+ async cleanupOldCheckpoints() {
79
+ try {
80
+ const cutoffTime = Date.now() - (24 * 60 * 60 * 1000); // 24 hours
81
+ await this.storage.deleteOlderThan(cutoffTime);
82
+ }
83
+ catch (error) {
84
+ console.error('Error cleaning up old checkpoints:', error);
85
+ }
86
+ }
87
+ extractLayer(did) {
88
+ if (did.startsWith('did:peer:'))
89
+ return 'peer';
90
+ if (did.startsWith('did:webvh:'))
91
+ return 'webvh';
92
+ if (did.startsWith('did:btco:'))
93
+ return 'btco';
94
+ return null;
95
+ }
96
+ }
@@ -0,0 +1,26 @@
1
+ /**
2
+ * CheckpointStorage - Persists checkpoints to storage
3
+ */
4
+ import { MigrationCheckpoint } from '../types';
5
+ import { OriginalsConfig } from '../../types';
6
+ export declare class CheckpointStorage {
7
+ private config;
8
+ private checkpoints;
9
+ constructor(config: OriginalsConfig);
10
+ /**
11
+ * Save a checkpoint
12
+ */
13
+ save(checkpoint: MigrationCheckpoint): Promise<void>;
14
+ /**
15
+ * Retrieve a checkpoint
16
+ */
17
+ get(checkpointId: string): Promise<MigrationCheckpoint | null>;
18
+ /**
19
+ * Delete a checkpoint
20
+ */
21
+ delete(checkpointId: string): Promise<void>;
22
+ /**
23
+ * Delete checkpoints older than specified timestamp
24
+ */
25
+ deleteOlderThan(cutoffTime: number): Promise<void>;
26
+ }
@@ -0,0 +1,89 @@
1
+ /**
2
+ * CheckpointStorage - Persists checkpoints to storage
3
+ */
4
+ export class CheckpointStorage {
5
+ constructor(config) {
6
+ this.config = config;
7
+ this.checkpoints = new Map();
8
+ }
9
+ /**
10
+ * Save a checkpoint
11
+ */
12
+ async save(checkpoint) {
13
+ if (!checkpoint.checkpointId) {
14
+ throw new Error('Checkpoint must have an ID');
15
+ }
16
+ this.checkpoints.set(checkpoint.checkpointId, checkpoint);
17
+ // Optionally persist to configured storage adapter
18
+ const storageAdapter = this.config.storageAdapter;
19
+ if (storageAdapter && typeof storageAdapter.put === 'function') {
20
+ try {
21
+ const data = JSON.stringify(checkpoint);
22
+ const key = `checkpoints/${checkpoint.checkpointId}.json`;
23
+ await storageAdapter.put(key, Buffer.from(data), { contentType: 'application/json' });
24
+ }
25
+ catch (error) {
26
+ console.error('Failed to persist checkpoint to storage:', error);
27
+ // Continue - in-memory checkpoint is still available
28
+ }
29
+ }
30
+ }
31
+ /**
32
+ * Retrieve a checkpoint
33
+ */
34
+ async get(checkpointId) {
35
+ // Try in-memory first
36
+ const memoryCheckpoint = this.checkpoints.get(checkpointId);
37
+ if (memoryCheckpoint) {
38
+ return memoryCheckpoint;
39
+ }
40
+ // Try loading from storage adapter
41
+ const storageAdapter = this.config.storageAdapter;
42
+ if (storageAdapter && typeof storageAdapter.get === 'function') {
43
+ try {
44
+ const key = `checkpoints/${checkpointId}.json`;
45
+ const data = await storageAdapter.get(key);
46
+ if (data) {
47
+ const checkpoint = JSON.parse(data.toString());
48
+ this.checkpoints.set(checkpointId, checkpoint);
49
+ return checkpoint;
50
+ }
51
+ }
52
+ catch (error) {
53
+ // Checkpoint not found in storage
54
+ }
55
+ }
56
+ return null;
57
+ }
58
+ /**
59
+ * Delete a checkpoint
60
+ */
61
+ async delete(checkpointId) {
62
+ this.checkpoints.delete(checkpointId);
63
+ // Also delete from storage adapter
64
+ const storageAdapter = this.config.storageAdapter;
65
+ if (storageAdapter && typeof storageAdapter.delete === 'function') {
66
+ try {
67
+ const key = `checkpoints/${checkpointId}.json`;
68
+ await storageAdapter.delete(key);
69
+ }
70
+ catch (error) {
71
+ // Ignore deletion errors
72
+ }
73
+ }
74
+ }
75
+ /**
76
+ * Delete checkpoints older than specified timestamp
77
+ */
78
+ async deleteOlderThan(cutoffTime) {
79
+ const toDelete = [];
80
+ for (const [id, checkpoint] of this.checkpoints.entries()) {
81
+ if (checkpoint.timestamp < cutoffTime) {
82
+ toDelete.push(id);
83
+ }
84
+ }
85
+ for (const id of toDelete) {
86
+ await this.delete(id);
87
+ }
88
+ }
89
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Migration module exports
3
+ * Provides DID layer migration capabilities with validation, checkpoints, and rollbacks
4
+ */
5
+ export { MigrationManager } from './MigrationManager';
6
+ export * from './types';
7
+ export { ValidationPipeline } from './validation/ValidationPipeline';
8
+ export { DIDCompatibilityValidator } from './validation/DIDCompatibilityValidator';
9
+ export { CredentialValidator } from './validation/CredentialValidator';
10
+ export { StorageValidator } from './validation/StorageValidator';
11
+ export { LifecycleValidator } from './validation/LifecycleValidator';
12
+ export { BitcoinValidator } from './validation/BitcoinValidator';
13
+ export { CheckpointManager } from './checkpoint/CheckpointManager';
14
+ export { CheckpointStorage } from './checkpoint/CheckpointStorage';
15
+ export { RollbackManager } from './rollback/RollbackManager';
16
+ export { StateTracker } from './state/StateTracker';
17
+ export { StateMachine } from './state/StateMachine';
18
+ export { AuditLogger } from './audit/AuditLogger';
19
+ export { BaseMigration } from './operations/BaseMigration';
20
+ export { PeerToWebvhMigration } from './operations/PeerToWebvhMigration';
21
+ export { WebvhToBtcoMigration } from './operations/WebvhToBtcoMigration';
22
+ export { PeerToBtcoMigration } from './operations/PeerToBtcoMigration';
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Migration module exports
3
+ * Provides DID layer migration capabilities with validation, checkpoints, and rollbacks
4
+ */
5
+ export { MigrationManager } from './MigrationManager';
6
+ export * from './types';
7
+ // Validators
8
+ export { ValidationPipeline } from './validation/ValidationPipeline';
9
+ export { DIDCompatibilityValidator } from './validation/DIDCompatibilityValidator';
10
+ export { CredentialValidator } from './validation/CredentialValidator';
11
+ export { StorageValidator } from './validation/StorageValidator';
12
+ export { LifecycleValidator } from './validation/LifecycleValidator';
13
+ export { BitcoinValidator } from './validation/BitcoinValidator';
14
+ // Checkpoint and Rollback
15
+ export { CheckpointManager } from './checkpoint/CheckpointManager';
16
+ export { CheckpointStorage } from './checkpoint/CheckpointStorage';
17
+ export { RollbackManager } from './rollback/RollbackManager';
18
+ // State Management
19
+ export { StateTracker } from './state/StateTracker';
20
+ export { StateMachine } from './state/StateMachine';
21
+ // Audit
22
+ export { AuditLogger } from './audit/AuditLogger';
23
+ // Operations
24
+ export { BaseMigration } from './operations/BaseMigration';
25
+ export { PeerToWebvhMigration } from './operations/PeerToWebvhMigration';
26
+ export { WebvhToBtcoMigration } from './operations/WebvhToBtcoMigration';
27
+ export { PeerToBtcoMigration } from './operations/PeerToBtcoMigration';
@@ -0,0 +1,48 @@
1
+ /**
2
+ * BaseMigration - Base class for all migration operations
3
+ */
4
+ import { MigrationOptions, MigrationError, MigrationErrorType, CostEstimate } from '../types';
5
+ import { OriginalsConfig, DIDDocument } from '../../types';
6
+ import { DIDManager } from '../../did/DIDManager';
7
+ import { CredentialManager } from '../../vc/CredentialManager';
8
+ import { StateTracker } from '../state/StateTracker';
9
+ import { EventEmitter } from '../../events/EventEmitter';
10
+ export declare abstract class BaseMigration {
11
+ protected config: OriginalsConfig;
12
+ protected didManager: DIDManager;
13
+ protected credentialManager: CredentialManager;
14
+ protected stateTracker: StateTracker;
15
+ protected eventEmitter: EventEmitter;
16
+ constructor(config: OriginalsConfig, didManager: DIDManager, credentialManager: CredentialManager, stateTracker: StateTracker);
17
+ /**
18
+ * Execute the migration (to be implemented by subclasses)
19
+ */
20
+ abstract executeMigration(options: MigrationOptions, migrationId: string): Promise<{
21
+ targetDid: string;
22
+ didDocument: DIDDocument;
23
+ }>;
24
+ /**
25
+ * Get estimated cost (to be implemented by subclasses)
26
+ */
27
+ abstract estimateCost(options: MigrationOptions): Promise<CostEstimate>;
28
+ /**
29
+ * Emit migration event
30
+ */
31
+ protected emitEvent(type: string, data: any): Promise<void>;
32
+ /**
33
+ * Create migration error
34
+ */
35
+ protected createError(type: MigrationErrorType, code: string, message: string, migrationId?: string, details?: any): MigrationError;
36
+ /**
37
+ * Update migration state with error handling
38
+ */
39
+ protected updateStateWithRetry(migrationId: string, updates: any, maxRetries?: number): Promise<void>;
40
+ /**
41
+ * Resolve source DID document
42
+ */
43
+ protected resolveSourceDid(sourceDid: string): Promise<DIDDocument>;
44
+ /**
45
+ * Extract layer from DID
46
+ */
47
+ protected extractLayer(did: string): 'peer' | 'webvh' | 'btco';
48
+ }
@@ -0,0 +1,83 @@
1
+ /**
2
+ * BaseMigration - Base class for all migration operations
3
+ */
4
+ import { EventEmitter } from '../../events/EventEmitter';
5
+ export class BaseMigration {
6
+ constructor(config, didManager, credentialManager, stateTracker) {
7
+ this.config = config;
8
+ this.didManager = didManager;
9
+ this.credentialManager = credentialManager;
10
+ this.stateTracker = stateTracker;
11
+ this.eventEmitter = new EventEmitter();
12
+ }
13
+ /**
14
+ * Emit migration event
15
+ */
16
+ async emitEvent(type, data) {
17
+ try {
18
+ await this.eventEmitter.emit({
19
+ type,
20
+ timestamp: new Date().toISOString(),
21
+ ...data
22
+ });
23
+ }
24
+ catch (error) {
25
+ console.error(`Error emitting event ${type}:`, error);
26
+ }
27
+ }
28
+ /**
29
+ * Create migration error
30
+ */
31
+ createError(type, code, message, migrationId, details) {
32
+ return {
33
+ type,
34
+ code,
35
+ message,
36
+ technicalDetails: details ? JSON.stringify(details) : undefined,
37
+ migrationId,
38
+ timestamp: Date.now()
39
+ };
40
+ }
41
+ /**
42
+ * Update migration state with error handling
43
+ */
44
+ async updateStateWithRetry(migrationId, updates, maxRetries = 3) {
45
+ let lastError = null;
46
+ for (let attempt = 0; attempt < maxRetries; attempt++) {
47
+ try {
48
+ await this.stateTracker.updateState(migrationId, updates);
49
+ return;
50
+ }
51
+ catch (error) {
52
+ lastError = error instanceof Error ? error : new Error(String(error));
53
+ if (attempt < maxRetries - 1) {
54
+ // Exponential backoff: 100ms, 200ms, 400ms
55
+ await new Promise(resolve => setTimeout(resolve, 100 * Math.pow(2, attempt)));
56
+ }
57
+ }
58
+ }
59
+ throw lastError || new Error('Failed to update state after retries');
60
+ }
61
+ /**
62
+ * Resolve source DID document
63
+ */
64
+ async resolveSourceDid(sourceDid) {
65
+ const didDocument = await this.didManager.resolveDID(sourceDid);
66
+ if (!didDocument) {
67
+ throw new Error(`Could not resolve source DID: ${sourceDid}`);
68
+ }
69
+ return didDocument;
70
+ }
71
+ /**
72
+ * Extract layer from DID
73
+ */
74
+ extractLayer(did) {
75
+ if (did.startsWith('did:peer:'))
76
+ return 'peer';
77
+ if (did.startsWith('did:webvh:'))
78
+ return 'webvh';
79
+ if (did.startsWith('did:btco:'))
80
+ return 'btco';
81
+ throw new Error(`Unsupported DID method: ${did}`);
82
+ }
83
+ }
@@ -0,0 +1,25 @@
1
+ /**
2
+ * PeerToBtcoMigration - Handles direct migration from did:peer to did:btco
3
+ */
4
+ import { MigrationOptions, CostEstimate } from '../types';
5
+ import { DIDDocument, OriginalsConfig } from '../../types';
6
+ import { BaseMigration } from './BaseMigration';
7
+ import { BitcoinManager } from '../../bitcoin/BitcoinManager';
8
+ import { DIDManager } from '../../did/DIDManager';
9
+ import { CredentialManager } from '../../vc/CredentialManager';
10
+ import { StateTracker } from '../state/StateTracker';
11
+ export declare class PeerToBtcoMigration extends BaseMigration {
12
+ private bitcoinManager;
13
+ constructor(config: OriginalsConfig, didManager: DIDManager, credentialManager: CredentialManager, stateTracker: StateTracker, bitcoinManager: BitcoinManager);
14
+ /**
15
+ * Execute peer → btco migration (direct, skipping webvh layer)
16
+ */
17
+ executeMigration(options: MigrationOptions, migrationId: string): Promise<{
18
+ targetDid: string;
19
+ didDocument: DIDDocument;
20
+ }>;
21
+ /**
22
+ * Estimate cost for peer → btco migration
23
+ */
24
+ estimateCost(options: MigrationOptions): Promise<CostEstimate>;
25
+ }
@@ -0,0 +1,67 @@
1
+ /**
2
+ * PeerToBtcoMigration - Handles direct migration from did:peer to did:btco
3
+ */
4
+ import { MigrationStateEnum } from '../types';
5
+ import { BaseMigration } from './BaseMigration';
6
+ export class PeerToBtcoMigration extends BaseMigration {
7
+ constructor(config, didManager, credentialManager, stateTracker, bitcoinManager) {
8
+ super(config, didManager, credentialManager, stateTracker);
9
+ this.bitcoinManager = bitcoinManager;
10
+ }
11
+ /**
12
+ * Execute peer → btco migration (direct, skipping webvh layer)
13
+ */
14
+ async executeMigration(options, migrationId) {
15
+ // Resolve source DID
16
+ const sourceDid = await this.resolveSourceDid(options.sourceDid);
17
+ await this.updateStateWithRetry(migrationId, {
18
+ state: MigrationStateEnum.IN_PROGRESS,
19
+ currentOperation: 'Creating Bitcoin inscription',
20
+ progress: 30
21
+ });
22
+ // Create Bitcoin inscription with DID document
23
+ const manifest = {
24
+ didDocument: sourceDid,
25
+ migrationId,
26
+ timestamp: new Date().toISOString()
27
+ };
28
+ const payload = Buffer.from(JSON.stringify(manifest));
29
+ await this.updateStateWithRetry(migrationId, {
30
+ state: MigrationStateEnum.ANCHORING,
31
+ currentOperation: 'Anchoring to Bitcoin',
32
+ progress: 50
33
+ });
34
+ const inscription = await this.bitcoinManager.inscribeData(payload, 'application/json', options.feeRate);
35
+ // Use satoshi identifier or inscription ID
36
+ const satoshiId = inscription.satoshi || inscription.inscriptionId.split('i')[0];
37
+ await this.updateStateWithRetry(migrationId, {
38
+ currentOperation: 'Creating btco DID document',
39
+ progress: 80
40
+ });
41
+ // Migrate DID document to btco
42
+ const migratedDoc = await this.didManager.migrateToDIDBTCO(sourceDid, satoshiId);
43
+ await this.updateStateWithRetry(migrationId, {
44
+ currentOperation: 'Migration completed',
45
+ progress: 100,
46
+ targetDid: migratedDoc.id
47
+ });
48
+ return {
49
+ targetDid: migratedDoc.id,
50
+ didDocument: migratedDoc
51
+ };
52
+ }
53
+ /**
54
+ * Estimate cost for peer → btco migration
55
+ */
56
+ async estimateCost(options) {
57
+ const feeRate = options.feeRate || 10; // default 10 sat/vB
58
+ const estimatedSize = 1024; // ~1KB for typical DID document
59
+ const networkFees = estimatedSize * feeRate;
60
+ return {
61
+ storageCost: 0,
62
+ networkFees,
63
+ totalCost: networkFees,
64
+ currency: 'sats'
65
+ };
66
+ }
67
+ }
@@ -0,0 +1,19 @@
1
+ /**
2
+ * PeerToWebvhMigration - Handles migration from did:peer to did:webvh
3
+ */
4
+ import { MigrationOptions, CostEstimate } from '../types';
5
+ import { DIDDocument } from '../../types';
6
+ import { BaseMigration } from './BaseMigration';
7
+ export declare class PeerToWebvhMigration extends BaseMigration {
8
+ /**
9
+ * Execute peer → webvh migration
10
+ */
11
+ executeMigration(options: MigrationOptions, migrationId: string): Promise<{
12
+ targetDid: string;
13
+ didDocument: DIDDocument;
14
+ }>;
15
+ /**
16
+ * Estimate cost for peer → webvh migration
17
+ */
18
+ estimateCost(options: MigrationOptions): Promise<CostEstimate>;
19
+ }
@@ -0,0 +1,46 @@
1
+ /**
2
+ * PeerToWebvhMigration - Handles migration from did:peer to did:webvh
3
+ */
4
+ import { MigrationStateEnum } from '../types';
5
+ import { BaseMigration } from './BaseMigration';
6
+ export class PeerToWebvhMigration extends BaseMigration {
7
+ /**
8
+ * Execute peer → webvh migration
9
+ */
10
+ async executeMigration(options, migrationId) {
11
+ // Resolve source DID
12
+ const sourceDid = await this.resolveSourceDid(options.sourceDid);
13
+ // Validate domain is provided
14
+ if (!options.domain) {
15
+ throw new Error('Domain is required for webvh migrations');
16
+ }
17
+ await this.updateStateWithRetry(migrationId, {
18
+ state: MigrationStateEnum.IN_PROGRESS,
19
+ currentOperation: 'Creating webvh DID document',
20
+ progress: 30
21
+ });
22
+ // Migrate DID document to webvh
23
+ const migratedDoc = await this.didManager.migrateToDIDWebVH(sourceDid, options.domain);
24
+ await this.updateStateWithRetry(migrationId, {
25
+ currentOperation: 'Migration completed',
26
+ progress: 100,
27
+ targetDid: migratedDoc.id
28
+ });
29
+ return {
30
+ targetDid: migratedDoc.id,
31
+ didDocument: migratedDoc
32
+ };
33
+ }
34
+ /**
35
+ * Estimate cost for peer → webvh migration
36
+ */
37
+ async estimateCost(options) {
38
+ // Web hosting is typically negligible cost
39
+ return {
40
+ storageCost: 0,
41
+ networkFees: 0,
42
+ totalCost: 0,
43
+ currency: 'sats'
44
+ };
45
+ }
46
+ }
@@ -0,0 +1,25 @@
1
+ /**
2
+ * WebvhToBtcoMigration - Handles migration from did:webvh to did:btco
3
+ */
4
+ import { MigrationOptions, CostEstimate } from '../types';
5
+ import { DIDDocument, OriginalsConfig } from '../../types';
6
+ import { BaseMigration } from './BaseMigration';
7
+ import { BitcoinManager } from '../../bitcoin/BitcoinManager';
8
+ import { DIDManager } from '../../did/DIDManager';
9
+ import { CredentialManager } from '../../vc/CredentialManager';
10
+ import { StateTracker } from '../state/StateTracker';
11
+ export declare class WebvhToBtcoMigration extends BaseMigration {
12
+ private bitcoinManager;
13
+ constructor(config: OriginalsConfig, didManager: DIDManager, credentialManager: CredentialManager, stateTracker: StateTracker, bitcoinManager: BitcoinManager);
14
+ /**
15
+ * Execute webvh → btco migration
16
+ */
17
+ executeMigration(options: MigrationOptions, migrationId: string): Promise<{
18
+ targetDid: string;
19
+ didDocument: DIDDocument;
20
+ }>;
21
+ /**
22
+ * Estimate cost for webvh → btco migration
23
+ */
24
+ estimateCost(options: MigrationOptions): Promise<CostEstimate>;
25
+ }
@@ -0,0 +1,67 @@
1
+ /**
2
+ * WebvhToBtcoMigration - Handles migration from did:webvh to did:btco
3
+ */
4
+ import { MigrationStateEnum } from '../types';
5
+ import { BaseMigration } from './BaseMigration';
6
+ export class WebvhToBtcoMigration extends BaseMigration {
7
+ constructor(config, didManager, credentialManager, stateTracker, bitcoinManager) {
8
+ super(config, didManager, credentialManager, stateTracker);
9
+ this.bitcoinManager = bitcoinManager;
10
+ }
11
+ /**
12
+ * Execute webvh → btco migration
13
+ */
14
+ async executeMigration(options, migrationId) {
15
+ // Resolve source DID
16
+ const sourceDid = await this.resolveSourceDid(options.sourceDid);
17
+ await this.updateStateWithRetry(migrationId, {
18
+ state: MigrationStateEnum.IN_PROGRESS,
19
+ currentOperation: 'Creating Bitcoin inscription',
20
+ progress: 30
21
+ });
22
+ // Create Bitcoin inscription with DID document
23
+ const manifest = {
24
+ didDocument: sourceDid,
25
+ migrationId,
26
+ timestamp: new Date().toISOString()
27
+ };
28
+ const payload = Buffer.from(JSON.stringify(manifest));
29
+ await this.updateStateWithRetry(migrationId, {
30
+ state: MigrationStateEnum.ANCHORING,
31
+ currentOperation: 'Anchoring to Bitcoin',
32
+ progress: 50
33
+ });
34
+ const inscription = await this.bitcoinManager.inscribeData(payload, 'application/json', options.feeRate);
35
+ // Use satoshi identifier or inscription ID
36
+ const satoshiId = inscription.satoshi || inscription.inscriptionId.split('i')[0];
37
+ await this.updateStateWithRetry(migrationId, {
38
+ currentOperation: 'Creating btco DID document',
39
+ progress: 80
40
+ });
41
+ // Migrate DID document to btco
42
+ const migratedDoc = await this.didManager.migrateToDIDBTCO(sourceDid, satoshiId);
43
+ await this.updateStateWithRetry(migrationId, {
44
+ currentOperation: 'Migration completed',
45
+ progress: 100,
46
+ targetDid: migratedDoc.id
47
+ });
48
+ return {
49
+ targetDid: migratedDoc.id,
50
+ didDocument: migratedDoc
51
+ };
52
+ }
53
+ /**
54
+ * Estimate cost for webvh → btco migration
55
+ */
56
+ async estimateCost(options) {
57
+ const feeRate = options.feeRate || 10; // default 10 sat/vB
58
+ const estimatedSize = 1024; // ~1KB for typical DID document
59
+ const networkFees = estimatedSize * feeRate;
60
+ return {
61
+ storageCost: 0,
62
+ networkFees,
63
+ totalCost: networkFees,
64
+ currency: 'sats'
65
+ };
66
+ }
67
+ }