@originals/sdk 1.4.3 → 1.4.5

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,29 @@
1
+ /**
2
+ * RollbackManager - Handles migration rollbacks
3
+ */
4
+ import { RollbackResult, IRollbackManager } from '../types';
5
+ import { OriginalsConfig } from '../../types';
6
+ import { CheckpointManager } from '../checkpoint/CheckpointManager';
7
+ import { DIDManager } from '../../did/DIDManager';
8
+ export declare class RollbackManager implements IRollbackManager {
9
+ private config;
10
+ private checkpointManager;
11
+ private didManager;
12
+ constructor(config: OriginalsConfig, checkpointManager: CheckpointManager, didManager: DIDManager);
13
+ /**
14
+ * Rollback a migration to its checkpoint state
15
+ */
16
+ rollback(migrationId: string, checkpointId: string): Promise<RollbackResult>;
17
+ /**
18
+ * Perform layer-specific rollback operations
19
+ */
20
+ private performLayerSpecificRollback;
21
+ /**
22
+ * Clean up migration artifacts
23
+ */
24
+ private cleanupMigrationArtifacts;
25
+ /**
26
+ * Check if a rollback is possible
27
+ */
28
+ canRollback(migrationId: string, checkpointId: string): Promise<boolean>;
29
+ }
@@ -0,0 +1,146 @@
1
+ /**
2
+ * RollbackManager - Handles migration rollbacks
3
+ */
4
+ import { MigrationStateEnum, MigrationErrorType } from '../types';
5
+ export class RollbackManager {
6
+ constructor(config, checkpointManager, didManager) {
7
+ this.config = config;
8
+ this.checkpointManager = checkpointManager;
9
+ this.didManager = didManager;
10
+ }
11
+ /**
12
+ * Rollback a migration to its checkpoint state
13
+ */
14
+ async rollback(migrationId, checkpointId) {
15
+ const startTime = Date.now();
16
+ const errors = [];
17
+ try {
18
+ // Retrieve checkpoint
19
+ const checkpoint = await this.checkpointManager.getCheckpoint(checkpointId);
20
+ if (!checkpoint) {
21
+ const error = {
22
+ type: MigrationErrorType.ROLLBACK_ERROR,
23
+ code: 'CHECKPOINT_NOT_FOUND',
24
+ message: `Checkpoint ${checkpointId} not found`,
25
+ migrationId,
26
+ timestamp: Date.now()
27
+ };
28
+ errors.push(error);
29
+ return {
30
+ success: false,
31
+ migrationId,
32
+ checkpointId,
33
+ restoredState: MigrationStateEnum.QUARANTINED,
34
+ duration: Date.now() - startTime,
35
+ errors
36
+ };
37
+ }
38
+ // Verify checkpoint belongs to this migration
39
+ if (checkpoint.migrationId !== migrationId) {
40
+ const error = {
41
+ type: MigrationErrorType.ROLLBACK_ERROR,
42
+ code: 'CHECKPOINT_MISMATCH',
43
+ message: `Checkpoint ${checkpointId} does not belong to migration ${migrationId}`,
44
+ migrationId,
45
+ timestamp: Date.now()
46
+ };
47
+ errors.push(error);
48
+ return {
49
+ success: false,
50
+ migrationId,
51
+ checkpointId,
52
+ restoredState: MigrationStateEnum.QUARANTINED,
53
+ duration: Date.now() - startTime,
54
+ errors
55
+ };
56
+ }
57
+ // Perform rollback based on source layer
58
+ await this.performLayerSpecificRollback(checkpoint);
59
+ // Clean up any partial migration artifacts
60
+ await this.cleanupMigrationArtifacts(migrationId);
61
+ const duration = Date.now() - startTime;
62
+ // Verify rollback success
63
+ if (errors.length === 0) {
64
+ return {
65
+ success: true,
66
+ migrationId,
67
+ checkpointId,
68
+ restoredState: MigrationStateEnum.ROLLED_BACK,
69
+ duration,
70
+ errors: []
71
+ };
72
+ }
73
+ else {
74
+ return {
75
+ success: false,
76
+ migrationId,
77
+ checkpointId,
78
+ restoredState: MigrationStateEnum.QUARANTINED,
79
+ duration,
80
+ errors
81
+ };
82
+ }
83
+ }
84
+ catch (error) {
85
+ const rollbackError = {
86
+ type: MigrationErrorType.ROLLBACK_ERROR,
87
+ code: 'ROLLBACK_FAILED',
88
+ message: 'Rollback operation failed',
89
+ technicalDetails: error instanceof Error ? error.message : String(error),
90
+ migrationId,
91
+ timestamp: Date.now()
92
+ };
93
+ errors.push(rollbackError);
94
+ return {
95
+ success: false,
96
+ migrationId,
97
+ checkpointId,
98
+ restoredState: MigrationStateEnum.QUARANTINED,
99
+ duration: Date.now() - startTime,
100
+ errors
101
+ };
102
+ }
103
+ }
104
+ /**
105
+ * Perform layer-specific rollback operations
106
+ */
107
+ async performLayerSpecificRollback(checkpoint) {
108
+ // For now, rollback mainly involves:
109
+ // 1. Ensuring source DID is still valid (it should be, as we don't delete it)
110
+ // 2. Cleaning up any partial artifacts on target layer
111
+ // 3. Restoring any modified state
112
+ // Verify source DID still resolves
113
+ const sourceDid = await this.didManager.resolveDID(checkpoint.sourceDid);
114
+ if (!sourceDid) {
115
+ throw new Error(`Source DID ${checkpoint.sourceDid} could not be resolved during rollback`);
116
+ }
117
+ // Layer-specific cleanup would go here
118
+ // For peer → webvh: Remove any published resources
119
+ // For webvh → btco: Nothing to do (Bitcoin tx cannot be reversed)
120
+ // For peer → btco: Nothing to do (Bitcoin tx cannot be reversed)
121
+ }
122
+ /**
123
+ * Clean up migration artifacts
124
+ */
125
+ async cleanupMigrationArtifacts(migrationId) {
126
+ // Clean up any temporary files, partial uploads, etc.
127
+ // This is a placeholder for actual cleanup logic
128
+ }
129
+ /**
130
+ * Check if a rollback is possible
131
+ */
132
+ async canRollback(migrationId, checkpointId) {
133
+ try {
134
+ const checkpoint = await this.checkpointManager.getCheckpoint(checkpointId);
135
+ if (!checkpoint || checkpoint.migrationId !== migrationId) {
136
+ return false;
137
+ }
138
+ // Bitcoin transactions cannot be rolled back
139
+ // But we can still restore the source DID to working state
140
+ return true;
141
+ }
142
+ catch (error) {
143
+ return false;
144
+ }
145
+ }
146
+ }
@@ -0,0 +1,25 @@
1
+ /**
2
+ * StateMachine - Defines valid migration state transitions
3
+ */
4
+ import { MigrationStateEnum } from '../types';
5
+ export declare class StateMachine {
6
+ private transitions;
7
+ constructor();
8
+ /**
9
+ * Initialize valid state transitions
10
+ */
11
+ private initializeTransitions;
12
+ /**
13
+ * Check if a state transition is valid
14
+ */
15
+ canTransition(fromState: MigrationStateEnum, toState: MigrationStateEnum): boolean;
16
+ /**
17
+ * Get all valid transitions from a given state
18
+ * Returns a copy to prevent external mutation of the transition table
19
+ */
20
+ getValidTransitions(fromState: MigrationStateEnum): MigrationStateEnum[];
21
+ /**
22
+ * Check if a state is terminal (no further transitions)
23
+ */
24
+ isTerminalState(state: MigrationStateEnum): boolean;
25
+ }
@@ -0,0 +1,76 @@
1
+ /**
2
+ * StateMachine - Defines valid migration state transitions
3
+ */
4
+ import { MigrationStateEnum } from '../types';
5
+ export class StateMachine {
6
+ constructor() {
7
+ this.transitions = this.initializeTransitions();
8
+ }
9
+ /**
10
+ * Initialize valid state transitions
11
+ */
12
+ initializeTransitions() {
13
+ const transitions = new Map();
14
+ // PENDING can transition to VALIDATING or FAILED
15
+ transitions.set(MigrationStateEnum.PENDING, [
16
+ MigrationStateEnum.VALIDATING,
17
+ MigrationStateEnum.FAILED
18
+ ]);
19
+ // VALIDATING can transition to CHECKPOINTED or FAILED
20
+ transitions.set(MigrationStateEnum.VALIDATING, [
21
+ MigrationStateEnum.CHECKPOINTED,
22
+ MigrationStateEnum.FAILED
23
+ ]);
24
+ // CHECKPOINTED can transition to IN_PROGRESS or FAILED
25
+ transitions.set(MigrationStateEnum.CHECKPOINTED, [
26
+ MigrationStateEnum.IN_PROGRESS,
27
+ MigrationStateEnum.FAILED
28
+ ]);
29
+ // IN_PROGRESS can transition to ANCHORING (for btco), COMPLETED, or FAILED
30
+ transitions.set(MigrationStateEnum.IN_PROGRESS, [
31
+ MigrationStateEnum.ANCHORING,
32
+ MigrationStateEnum.COMPLETED,
33
+ MigrationStateEnum.FAILED
34
+ ]);
35
+ // ANCHORING can transition to COMPLETED or FAILED
36
+ transitions.set(MigrationStateEnum.ANCHORING, [
37
+ MigrationStateEnum.COMPLETED,
38
+ MigrationStateEnum.FAILED
39
+ ]);
40
+ // FAILED can transition to ROLLED_BACK or QUARANTINED
41
+ transitions.set(MigrationStateEnum.FAILED, [
42
+ MigrationStateEnum.ROLLED_BACK,
43
+ MigrationStateEnum.QUARANTINED
44
+ ]);
45
+ // COMPLETED, ROLLED_BACK, and QUARANTINED are terminal states
46
+ transitions.set(MigrationStateEnum.COMPLETED, []);
47
+ transitions.set(MigrationStateEnum.ROLLED_BACK, []);
48
+ transitions.set(MigrationStateEnum.QUARANTINED, []);
49
+ return transitions;
50
+ }
51
+ /**
52
+ * Check if a state transition is valid
53
+ */
54
+ canTransition(fromState, toState) {
55
+ const validTransitions = this.transitions.get(fromState);
56
+ if (!validTransitions) {
57
+ return false;
58
+ }
59
+ return validTransitions.includes(toState);
60
+ }
61
+ /**
62
+ * Get all valid transitions from a given state
63
+ * Returns a copy to prevent external mutation of the transition table
64
+ */
65
+ getValidTransitions(fromState) {
66
+ const transitions = this.transitions.get(fromState);
67
+ return transitions ? [...transitions] : [];
68
+ }
69
+ /**
70
+ * Check if a state is terminal (no further transitions)
71
+ */
72
+ isTerminalState(state) {
73
+ const validTransitions = this.transitions.get(state);
74
+ return !validTransitions || validTransitions.length === 0;
75
+ }
76
+ }
@@ -0,0 +1,36 @@
1
+ /**
2
+ * StateTracker - Tracks migration state throughout the migration lifecycle
3
+ */
4
+ import { MigrationOptions, MigrationState, IStateTracker } from '../types';
5
+ import { OriginalsConfig } from '../../types';
6
+ export declare class StateTracker implements IStateTracker {
7
+ private config;
8
+ private states;
9
+ private stateMachine;
10
+ constructor(config: OriginalsConfig);
11
+ /**
12
+ * Create a new migration state
13
+ */
14
+ createMigration(options: MigrationOptions): Promise<MigrationState>;
15
+ /**
16
+ * Update migration state
17
+ */
18
+ updateState(migrationId: string, updates: Partial<MigrationState>): Promise<void>;
19
+ /**
20
+ * Get migration state
21
+ */
22
+ getState(migrationId: string): Promise<MigrationState | null>;
23
+ /**
24
+ * Query migration states by filters
25
+ */
26
+ queryStates(filters: Partial<MigrationState>): Promise<MigrationState[]>;
27
+ /**
28
+ * Get all active migrations
29
+ */
30
+ getActiveMigrations(): Promise<MigrationState[]>;
31
+ /**
32
+ * Clean up old completed migrations
33
+ */
34
+ cleanupOldStates(olderThanMs?: number): Promise<void>;
35
+ private extractLayer;
36
+ }
@@ -0,0 +1,123 @@
1
+ /**
2
+ * StateTracker - Tracks migration state throughout the migration lifecycle
3
+ */
4
+ import { v4 as uuidv4 } from 'uuid';
5
+ import { MigrationStateEnum } from '../types';
6
+ import { StateMachine } from './StateMachine';
7
+ export class StateTracker {
8
+ constructor(config) {
9
+ this.config = config;
10
+ this.states = new Map();
11
+ this.stateMachine = new StateMachine();
12
+ }
13
+ /**
14
+ * Create a new migration state
15
+ */
16
+ async createMigration(options) {
17
+ const migrationId = `mig_${uuidv4()}`;
18
+ const sourceLayer = this.extractLayer(options.sourceDid);
19
+ if (!sourceLayer) {
20
+ throw new Error(`Invalid source DID format: ${options.sourceDid}`);
21
+ }
22
+ const state = {
23
+ migrationId,
24
+ state: MigrationStateEnum.PENDING,
25
+ sourceDid: options.sourceDid,
26
+ sourceLayer,
27
+ targetLayer: options.targetLayer,
28
+ progress: 0,
29
+ currentOperation: 'Initializing migration',
30
+ startTime: Date.now()
31
+ };
32
+ this.states.set(migrationId, state);
33
+ return state;
34
+ }
35
+ /**
36
+ * Update migration state
37
+ */
38
+ async updateState(migrationId, updates) {
39
+ const currentState = this.states.get(migrationId);
40
+ if (!currentState) {
41
+ throw new Error(`Migration ${migrationId} not found`);
42
+ }
43
+ // Validate state transition if state is being updated
44
+ if (updates.state && updates.state !== currentState.state) {
45
+ if (!this.stateMachine.canTransition(currentState.state, updates.state)) {
46
+ throw new Error(`Invalid state transition from ${currentState.state} to ${updates.state}`);
47
+ }
48
+ }
49
+ // Update the state
50
+ const updatedState = {
51
+ ...currentState,
52
+ ...updates
53
+ };
54
+ // Set end time if migration is completed, failed, or rolled back
55
+ if (updatedState.state === MigrationStateEnum.COMPLETED ||
56
+ updatedState.state === MigrationStateEnum.FAILED ||
57
+ updatedState.state === MigrationStateEnum.ROLLED_BACK ||
58
+ updatedState.state === MigrationStateEnum.QUARANTINED) {
59
+ updatedState.endTime = Date.now();
60
+ }
61
+ this.states.set(migrationId, updatedState);
62
+ }
63
+ /**
64
+ * Get migration state
65
+ */
66
+ async getState(migrationId) {
67
+ return this.states.get(migrationId) || null;
68
+ }
69
+ /**
70
+ * Query migration states by filters
71
+ */
72
+ async queryStates(filters) {
73
+ const results = [];
74
+ for (const state of this.states.values()) {
75
+ let matches = true;
76
+ for (const [key, value] of Object.entries(filters)) {
77
+ if (state[key] !== value) {
78
+ matches = false;
79
+ break;
80
+ }
81
+ }
82
+ if (matches) {
83
+ results.push(state);
84
+ }
85
+ }
86
+ return results;
87
+ }
88
+ /**
89
+ * Get all active migrations
90
+ */
91
+ async getActiveMigrations() {
92
+ return this.queryStates({
93
+ state: MigrationStateEnum.IN_PROGRESS
94
+ });
95
+ }
96
+ /**
97
+ * Clean up old completed migrations
98
+ */
99
+ async cleanupOldStates(olderThanMs = 7 * 24 * 60 * 60 * 1000) {
100
+ const cutoffTime = Date.now() - olderThanMs;
101
+ const toDelete = [];
102
+ for (const [id, state] of this.states.entries()) {
103
+ if (state.endTime &&
104
+ state.endTime < cutoffTime &&
105
+ (state.state === MigrationStateEnum.COMPLETED ||
106
+ state.state === MigrationStateEnum.ROLLED_BACK)) {
107
+ toDelete.push(id);
108
+ }
109
+ }
110
+ for (const id of toDelete) {
111
+ this.states.delete(id);
112
+ }
113
+ }
114
+ extractLayer(did) {
115
+ if (did.startsWith('did:peer:'))
116
+ return 'peer';
117
+ if (did.startsWith('did:webvh:'))
118
+ return 'webvh';
119
+ if (did.startsWith('did:btco:'))
120
+ return 'btco';
121
+ return null;
122
+ }
123
+ }