@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,312 +0,0 @@
1
- import { expect, describe, test, beforeEach, afterEach } from 'bun:test';
2
- import { LifecycleManager } from '../../../src/lifecycle/LifecycleManager';
3
- import { DIDManager } from '../../../src/did/DIDManager';
4
- import { CredentialManager } from '../../../src/vc/CredentialManager';
5
- import { KeyManager } from '../../../src/did/KeyManager';
6
- import { MockKeyStore } from '../../mocks/MockKeyStore';
7
- import { OriginalsConfig } from '../../../src/types';
8
- import * as fs from 'fs';
9
- import * as path from 'path';
10
- import { tmpdir } from 'os';
11
-
12
- const resources = [
13
- {
14
- id: 'res1',
15
- type: 'text',
16
- content: 'hello world',
17
- contentType: 'text/plain',
18
- hash: 'deadbeef'
19
- }
20
- ];
21
-
22
- const config: OriginalsConfig = {
23
- network: 'regtest',
24
- defaultKeyType: 'Ed25519', // Use Ed25519 for did:webvh compatibility
25
- enableLogging: true
26
- };
27
-
28
- describe('LifecycleManager Key Management', () => {
29
- let lifecycleManager: LifecycleManager;
30
- let didManager: DIDManager;
31
- let credentialManager: CredentialManager;
32
- let keyStore: MockKeyStore;
33
- let publisherDid: string;
34
- let tempDir: string;
35
- let publisherKeyPair: any;
36
-
37
- beforeEach(async () => {
38
- didManager = new DIDManager(config);
39
- credentialManager = new CredentialManager(config, didManager);
40
- keyStore = new MockKeyStore();
41
- lifecycleManager = new LifecycleManager(config, didManager, credentialManager, undefined, keyStore);
42
-
43
- // Create a simple mock publisher DID instead of creating a full did:webvh
44
- // This avoids the overhead of DID creation for every test
45
- publisherDid = 'did:webvh:example.com:user';
46
-
47
- // Create a key pair for the publisher
48
- const keyManager = new KeyManager();
49
- publisherKeyPair = await keyManager.generateKeyPair('Ed25519');
50
-
51
- // Register the publisher's key in keyStore with common VM ID pattern
52
- await keyStore.setPrivateKey(`${publisherDid}#key-0`, publisherKeyPair.privateKey);
53
- });
54
-
55
- afterEach(async () => {
56
- // Clean up temp directory
57
- if (tempDir) {
58
- try {
59
- await fs.promises.rm(tempDir, { recursive: true, force: true });
60
- } catch (err) {
61
- // Ignore cleanup errors
62
- }
63
- }
64
- });
65
-
66
- describe('registerKey', () => {
67
- test('should register a valid private key', async () => {
68
- const keyManager = new KeyManager();
69
- const keyPair = await keyManager.generateKeyPair('ES256K');
70
- const vmId = 'did:peer:test#keys-1';
71
-
72
- await lifecycleManager.registerKey(vmId, keyPair.privateKey);
73
-
74
- const retrievedKey = await keyStore.getPrivateKey(vmId);
75
- expect(retrievedKey).toBe(keyPair.privateKey);
76
- });
77
-
78
- test('should throw error when keyStore not configured', async () => {
79
- const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
80
- const keyManager = new KeyManager();
81
- const keyPair = await keyManager.generateKeyPair('ES256K');
82
-
83
- await expect(
84
- lifecycleWithoutKeyStore.registerKey('did:peer:test#keys-1', keyPair.privateKey)
85
- ).rejects.toThrow('KeyStore not configured');
86
- });
87
-
88
- test('should throw error for invalid verification method ID', async () => {
89
- const keyManager = new KeyManager();
90
- const keyPair = await keyManager.generateKeyPair('ES256K');
91
-
92
- await expect(
93
- lifecycleManager.registerKey('', keyPair.privateKey)
94
- ).rejects.toThrow('Invalid verificationMethodId');
95
- });
96
-
97
- test('should throw error for invalid private key format', async () => {
98
- await expect(
99
- lifecycleManager.registerKey('did:peer:test#keys-1', 'invalid-key')
100
- ).rejects.toThrow('Invalid privateKey format');
101
- });
102
-
103
- test('should throw error for empty private key', async () => {
104
- await expect(
105
- lifecycleManager.registerKey('did:peer:test#keys-1', '')
106
- ).rejects.toThrow('Invalid privateKey');
107
- });
108
- });
109
-
110
- describe('createAsset with keyStore', () => {
111
- test('should automatically register key when keyStore is provided', async () => {
112
- const asset = await lifecycleManager.createAsset(resources);
113
-
114
- expect(asset.currentLayer).toBe('did:peer');
115
- expect(asset.did.verificationMethod).toBeDefined();
116
- expect(asset.did.verificationMethod!.length).toBeGreaterThan(0);
117
-
118
- let vmId = asset.did.verificationMethod![0].id;
119
- // Ensure VM ID is absolute
120
- if (vmId.startsWith('#')) {
121
- vmId = `${asset.did.id}${vmId}`;
122
- }
123
-
124
- const privateKey = await keyStore.getPrivateKey(vmId);
125
- expect(privateKey).not.toBeNull();
126
- expect(typeof privateKey).toBe('string');
127
- });
128
-
129
- test('should create asset without keyStore gracefully', async () => {
130
- const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
131
- const asset = await lifecycleWithoutKeyStore.createAsset(resources);
132
-
133
- expect(asset.currentLayer).toBe('did:peer');
134
- expect(asset.did.verificationMethod).toBeDefined();
135
- });
136
- });
137
-
138
- describe('publishToWeb with DID keys', () => {
139
- test('should sign credential with DID document key from keyStore', async () => {
140
- const asset = await lifecycleManager.createAsset(resources);
141
-
142
- // Verify key was stored
143
- let vmId = asset.did.verificationMethod![0].id;
144
- if (vmId.startsWith('#')) {
145
- vmId = `${asset.did.id}${vmId}`;
146
- }
147
- const storedKey = await keyStore.getPrivateKey(vmId);
148
- expect(storedKey).not.toBeNull();
149
-
150
- const published = await lifecycleManager.publishToWeb(asset, publisherDid);
151
-
152
- expect(published.currentLayer).toBe('did:webvh');
153
- expect(published.credentials.length).toBeGreaterThan(0);
154
-
155
- const credential = published.credentials[0];
156
- expect(credential.proof).toBeDefined();
157
- expect(credential.type).toContain('ResourceMigrated');
158
- expect(credential.issuer).toBe(publisherDid); // Publisher DID is the issuer
159
-
160
- const proof = credential.proof as any;
161
- // Verification method should be from the publisher DID, not the asset
162
- expect(proof.verificationMethod).toContain(publisherDid);
163
- });
164
-
165
- test('should not add credential when keyStore not provided', async () => {
166
- const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
167
- const asset = await lifecycleWithoutKeyStore.createAsset(resources);
168
-
169
- // Publishing should succeed but no credential should be added (best-effort)
170
- const published = await lifecycleWithoutKeyStore.publishToWeb(asset, publisherDid);
171
-
172
- expect(published.currentLayer).toBe('did:webvh');
173
- // No credential should be added due to missing keyStore
174
- expect(published.credentials.length).toBe(0);
175
- });
176
-
177
- test('should not add credential when private key not found in keyStore', async () => {
178
- // Create asset without keyStore
179
- const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
180
- const asset = await lifecycleWithoutKeyStore.createAsset(resources);
181
-
182
- // Try to publish with a different lifecycle manager that has keyStore but no keys
183
- const emptyKeyStore = new MockKeyStore();
184
- const lifecycleWithEmptyKeyStore = new LifecycleManager(
185
- config,
186
- didManager,
187
- credentialManager,
188
- undefined,
189
- emptyKeyStore
190
- );
191
-
192
- // Publishing should succeed but no credential should be added (best-effort)
193
- const published = await lifecycleWithEmptyKeyStore.publishToWeb(asset, publisherDid);
194
-
195
- expect(published.currentLayer).toBe('did:webvh');
196
- // No credential should be added due to missing private key
197
- expect(published.credentials.length).toBe(0);
198
- });
199
-
200
- test('should use keys from keyStore not ephemeral keys', async () => {
201
- const asset = await lifecycleManager.createAsset(resources);
202
-
203
- // Get the stored key
204
- let vmId = asset.did.verificationMethod![0].id;
205
- if (vmId.startsWith('#')) {
206
- vmId = `${asset.did.id}${vmId}`;
207
- }
208
- const storedKeyBefore = await keyStore.getPrivateKey(vmId);
209
-
210
- const published = await lifecycleManager.publishToWeb(asset, publisherDid);
211
-
212
- // Verify the same key is still there (not replaced)
213
- const storedKeyAfter = await keyStore.getPrivateKey(vmId);
214
- expect(storedKeyAfter).toBe(storedKeyBefore);
215
-
216
- // Verify credential was created
217
- expect(published.credentials.length).toBe(1);
218
- const credential = published.credentials[0];
219
- const proof = credential.proof as any;
220
- // Verification method should be from the publisher DID
221
- expect(proof.verificationMethod).toContain(publisherDid);
222
- });
223
-
224
- test('should use correct verification method from DID document', async () => {
225
- const asset = await lifecycleManager.createAsset(resources);
226
- let vmId = asset.did.verificationMethod![0].id;
227
- const publicKey = asset.did.verificationMethod![0].publicKeyMultibase;
228
-
229
- // Ensure VM ID is absolute
230
- if (vmId.startsWith('#')) {
231
- vmId = `${asset.did.id}${vmId}`;
232
- }
233
-
234
- const published = await lifecycleManager.publishToWeb(asset, publisherDid);
235
- const credential = published.credentials[0];
236
- const proof = credential.proof as any;
237
-
238
- // Verify the VM ID references the publisher DID document
239
- expect(proof.verificationMethod).toContain(publisherDid);
240
- expect(vmId).toContain(asset.id); // Asset's VM ID contains asset ID
241
- expect(credential.issuer).toBe(publisherDid); // Publisher is the issuer
242
- });
243
- });
244
-
245
- describe('Key rotation scenario', () => {
246
- test('should allow registering multiple keys for different verification methods', async () => {
247
- const keyManager = new KeyManager();
248
- const keyPair1 = await keyManager.generateKeyPair('ES256K');
249
- const keyPair2 = await keyManager.generateKeyPair('ES256K');
250
-
251
- await lifecycleManager.registerKey('did:peer:test#keys-1', keyPair1.privateKey);
252
- await lifecycleManager.registerKey('did:peer:test#keys-2', keyPair2.privateKey);
253
-
254
- const key1 = await keyStore.getPrivateKey('did:peer:test#keys-1');
255
- const key2 = await keyStore.getPrivateKey('did:peer:test#keys-2');
256
-
257
- expect(key1).toBe(keyPair1.privateKey);
258
- expect(key2).toBe(keyPair2.privateKey);
259
- expect(key1).not.toBe(key2);
260
- });
261
- });
262
-
263
- describe('End-to-end credential management', () => {
264
- test('should create signed credentials throughout asset lifecycle', async () => {
265
- // Create asset with automatic key registration
266
- const asset = await lifecycleManager.createAsset(resources);
267
- expect(asset.did.verificationMethod).toBeDefined();
268
-
269
- // Publish to web - should create signed credential
270
- const published = await lifecycleManager.publishToWeb(asset, publisherDid);
271
- expect(published.credentials.length).toBe(1);
272
-
273
- // Check credential structure
274
- const credential = published.credentials[0];
275
- expect(credential.issuer).toBe(publisherDid); // Publisher is the issuer
276
- expect(credential.type).toContain('ResourceMigrated');
277
- expect((credential.credentialSubject as any).fromLayer).toBe('did:peer');
278
- expect((credential.credentialSubject as any).toLayer).toBe('did:webvh');
279
-
280
- // Verify proof is present with publisher's VM
281
- expect(credential.proof).toBeDefined();
282
- const proof = credential.proof as any;
283
- // Verification method should be from publisher DID
284
- expect(proof.verificationMethod).toContain(publisherDid);
285
- });
286
- });
287
-
288
- describe('Error handling', () => {
289
- test('should handle missing verification method in DID document gracefully', async () => {
290
- const lifecycleWithoutKeyStore = new LifecycleManager(config, didManager, credentialManager);
291
- const asset = await lifecycleWithoutKeyStore.createAsset(resources);
292
-
293
- // Manually remove verification methods to simulate error case
294
- (asset.did as any).verificationMethod = [];
295
-
296
- const lifecycleWithKeyStore = new LifecycleManager(
297
- config,
298
- didManager,
299
- credentialManager,
300
- undefined,
301
- keyStore
302
- );
303
-
304
- // Should not throw - credentials can be issued using publisher's keys from keyStore
305
- const published = await lifecycleWithKeyStore.publishToWeb(asset, publisherDid);
306
-
307
- expect(published.currentLayer).toBe('did:webvh');
308
- // Credential should be added using publisher's verification method from keyStore
309
- expect(published.credentials.length).toBeGreaterThanOrEqual(0); // Best effort - may or may not issue
310
- });
311
- });
312
- });
@@ -1,18 +0,0 @@
1
- import { describe, test, expect } from 'bun:test';
2
- import { OriginalsSDK } from '../../../src';
3
- import { MockOrdinalsProvider } from '../../mocks/adapters';
4
-
5
- describe('LifecycleManager provenance fallback', () => {
6
- test('inscribeOnBitcoin initializes provenance when missing', async () => {
7
- const provider = new MockOrdinalsProvider();
8
- const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
9
- const asset = await sdk.lifecycle.createAsset([{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }]);
10
- // ensure provenance exists but is empty (migrations/transfers arrays present)
11
- (asset as any).provenance = { createdAt: new Date().toISOString(), creator: asset.id, migrations: [], transfers: [] };
12
- const updated = await sdk.lifecycle.inscribeOnBitcoin(asset);
13
- const prov = (updated as any).getProvenance();
14
- const latest = prov.migrations[prov.migrations.length - 1];
15
- expect(latest.transactionId).toBeDefined();
16
- expect(latest.feeRate as number).toBeGreaterThan(0);
17
- });
18
- });
@@ -1,213 +0,0 @@
1
- import { describe, test, expect } from 'bun:test';
2
- import { OriginalsSDK, OriginalsAsset } from '../../../src';
3
- import { MockOrdinalsProvider } from '../../mocks/adapters';
4
-
5
- const resources = [
6
- {
7
- id: 'res1',
8
- type: 'text',
9
- content: 'hello world',
10
- contentType: 'text/plain',
11
- hash: 'deadbeef'
12
- }
13
- ];
14
-
15
- describe('LifecycleManager', () => {
16
- test('createAsset creates a peer-layer asset', async () => {
17
- const sdk = OriginalsSDK.create({ network: 'regtest' });
18
- const asset = await sdk.lifecycle.createAsset(resources);
19
- expect(asset.currentLayer).toBe('did:peer');
20
- expect(asset.id.startsWith('did:peer:')).toBe(true);
21
- });
22
-
23
- test('publishToWeb migrates and records binding', async () => {
24
- const sdk = OriginalsSDK.create({ network: 'regtest' });
25
- const asset = await sdk.lifecycle.createAsset(resources);
26
- const published = await sdk.lifecycle.publishToWeb(asset, 'example.com');
27
- expect(published.currentLayer).toBe('did:webvh');
28
- expect(published.bindings?.['did:webvh']).toContain('example.com');
29
- });
30
-
31
- test('inscribeOnBitcoin uses provider details for provenance', async () => {
32
- const provider = new MockOrdinalsProvider();
33
- const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
34
- const asset = await sdk.lifecycle.createAsset(resources);
35
- await sdk.lifecycle.publishToWeb(asset, 'example.com');
36
- const btco = await sdk.lifecycle.inscribeOnBitcoin(asset, 9);
37
- expect(btco.currentLayer).toBe('did:btco');
38
- const provenance = btco.getProvenance();
39
- const latest = provenance.migrations[provenance.migrations.length - 1];
40
- expect(latest.inscriptionId).toBe('insc-mock');
41
- expect(latest.satoshi).toBe('123');
42
- expect(latest.transactionId).toBe('tx-reveal-mock');
43
- expect(latest.feeRate).toBe(9);
44
- expect(btco.bindings?.['did:btco']).toBe('did:btco:123');
45
- });
46
-
47
- test('inscribeOnBitcoin without provider throws error', async () => {
48
- const sdk = OriginalsSDK.create({ network: 'regtest' });
49
- const asset = await sdk.lifecycle.createAsset(resources);
50
- await expect(sdk.lifecycle.inscribeOnBitcoin(asset, 5)).rejects.toThrow('Ordinals provider must be configured');
51
- });
52
-
53
- test('inscribeOnBitcoin enforces migration guard', async () => {
54
- const sdk = OriginalsSDK.create({ network: 'regtest' });
55
- const fakeAsset = { currentLayer: 'did:webvh', migrate: undefined } as unknown as OriginalsAsset;
56
- await expect(sdk.lifecycle.inscribeOnBitcoin(fakeAsset, 5)).rejects.toThrow('Not implemented');
57
- });
58
-
59
- test('publishToWeb throws Not implemented (coverage for throw)', async () => {
60
- const sdk = OriginalsSDK.create({ network: 'regtest' });
61
- const fakeAsset: any = { currentLayer: 'did:peer' };
62
- await expect(
63
- sdk.lifecycle.publishToWeb(fakeAsset, 'example.com')
64
- ).rejects.toThrow();
65
- });
66
-
67
- test('inscribeOnBitcoin throws Not implemented (coverage for throw)', async () => {
68
- const sdk = OriginalsSDK.create({ network: 'regtest' });
69
- const fakeAsset: any = { currentLayer: 'did:webvh' };
70
- await expect(
71
- sdk.lifecycle.inscribeOnBitcoin(fakeAsset, 10)
72
- ).rejects.toThrow('Not implemented');
73
- });
74
-
75
- test('transferOwnership succeeds when on btco (returns tx)', async () => {
76
- const provider = new MockOrdinalsProvider();
77
- const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
78
- const asset = await sdk.lifecycle.createAsset([
79
- { id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }
80
- ]);
81
- await asset.migrate('did:btco');
82
- const tx = await sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
83
- expect(typeof tx.txid).toBe('string');
84
- });
85
-
86
- test('transferOwnership errors if not on btco layer', async () => {
87
- const sdk = OriginalsSDK.create({ network: 'regtest' });
88
- // This one should pass given current guard
89
- const asset = await (async () => {
90
- try {
91
- return await sdk.lifecycle.createAsset(resources);
92
- } catch (e) {
93
- // Fallback mock minimal object to hit the guard branch
94
- return { currentLayer: 'did:webvh' } as any;
95
- }
96
- })();
97
- await expect(
98
- sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx')
99
- ).rejects.toThrow('Asset must be inscribed on Bitcoin before transfer');
100
- });
101
- });
102
-
103
- /** Inlined from LifecycleManager.btco.psbt.part.ts */
104
- import { BroadcastClient } from '../../../src/bitcoin/BroadcastClient';
105
- import { PSBTBuilder } from '../../../src/bitcoin/PSBTBuilder';
106
-
107
- describe('Bitcoin inscription MVP - dry run', () => {
108
- test('dry-run using mocked provider and broadcaster', async () => {
109
- const provider = new MockOrdinalsProvider();
110
- const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
111
-
112
- // Inject mocked dependencies
113
- const mockBroadcast = new BroadcastClient(async (_hex) => 'tx-dryrun', async (_txid) => ({ confirmed: true, confirmations: 1 }));
114
- const mockPsbt = new PSBTBuilder();
115
-
116
- // @ts-ignore access internals for test injection
117
- sdk.lifecycle = new (sdk.lifecycle.constructor as any)(
118
- (sdk as any).lifecycle['config'],
119
- (sdk as any).lifecycle['didManager'],
120
- (sdk as any).lifecycle['credentialManager'],
121
- { broadcastClient: mockBroadcast, psbtBuilder: mockPsbt }
122
- );
123
-
124
- const asset = await sdk.lifecycle.createAsset([
125
- { id: 'r1', type: 'text', contentType: 'text/plain', hash: 'aa' }
126
- ]);
127
-
128
- const before = asset.currentLayer;
129
- const feeRate = 7;
130
- const result = await sdk.lifecycle.inscribeOnBitcoin(asset, feeRate);
131
-
132
- expect(result.currentLayer).toBe('did:btco');
133
- const prov = (result as any).getProvenance();
134
- const latest = prov.migrations[prov.migrations.length - 1];
135
- expect(latest.feeRate).toBe(feeRate);
136
- expect(latest.transactionId).toEqual(expect.any(String));
137
- expect(before).toBe('did:peer');
138
- });
139
- });
140
-
141
-
142
-
143
-
144
- /** Inlined from LifecycleManager.coverage-branches.part.ts */
145
- import { LifecycleManager } from '../../../src/lifecycle/LifecycleManager';
146
- import { DIDManager } from '../../../src/did/DIDManager';
147
- import { CredentialManager } from '../../../src/vc/CredentialManager';
148
-
149
- describe('LifecycleManager additional branch coverage', () => {
150
- const lm = new LifecycleManager({ network: 'mainnet' } as any, new DIDManager({} as any), new CredentialManager({} as any));
151
-
152
- test('publishToWeb throws when migrate not a function', async () => {
153
- const asset: any = {
154
- currentLayer: 'did:peer',
155
- id: 'did:peer:test',
156
- resources: [{ id: 'r1', type: 'data', contentType: 'text/plain', hash: 'deadbeef', content: 'test' }],
157
- migrate: undefined // This should cause an error when called
158
- };
159
- await expect(lm.publishToWeb(asset, 'example.com')).rejects.toThrow();
160
- });
161
- });
162
-
163
-
164
-
165
-
166
- /** Inlined from LifecycleManager.more.part.ts */
167
-
168
- const dummyConfig: any = {};
169
- const didManager = new DIDManager(dummyConfig as any);
170
- const credentialManager = new CredentialManager(dummyConfig as any);
171
- const lm = new LifecycleManager(dummyConfig as any, didManager, credentialManager);
172
-
173
- describe('LifecycleManager additional branches', () => {
174
- test('publishToWeb throws when currentLayer is not did:peer', async () => {
175
- const asset: any = { currentLayer: 'did:webvh', migrate: async () => { } };
176
- await expect(lm.publishToWeb(asset, 'example.com')).rejects.toThrow();
177
- });
178
-
179
- test('inscribeOnBitcoin throws for invalid layer', async () => {
180
- const asset: any = { currentLayer: 'did:wrong', migrate: async () => { } };
181
- await expect(lm.inscribeOnBitcoin(asset)).rejects.toThrow('Not implemented');
182
- });
183
- });
184
-
185
-
186
-
187
-
188
- /** Inlined from LifecycleManager.no-feeRate.part.ts */
189
-
190
- describe('LifecycleManager.inscribeOnBitcoin without explicit feeRate', () => {
191
- test('uses provider.estimateFee when feeRate not provided', async () => {
192
- const provider = new MockOrdinalsProvider();
193
- const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
194
- const asset = await sdk.lifecycle.createAsset([{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'aa' }]);
195
- const result = await sdk.lifecycle.inscribeOnBitcoin(asset);
196
- expect(result.currentLayer).toBe('did:btco');
197
- const prov = (result as any).getProvenance();
198
- const latest = prov.migrations[prov.migrations.length - 1];
199
- expect(latest.feeRate as number).toBeGreaterThan(0);
200
- })
201
-
202
- test('transferOwnership uses provenance inscription data', async () => {
203
- const provider = new MockOrdinalsProvider();
204
- const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
205
- const asset = await sdk.lifecycle.createAsset(resources);
206
- await sdk.lifecycle.publishToWeb(asset, 'example.com');
207
- await sdk.lifecycle.inscribeOnBitcoin(asset, 8);
208
- const tx = await sdk.lifecycle.transferOwnership(asset, 'tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7');
209
- expect(tx.txid).toBe('tx-transfer-mock');
210
- const provenance = asset.getProvenance();
211
- expect(provenance.transfers[provenance.transfers.length - 1].transactionId).toBe('tx-transfer-mock');
212
- });
213
- });
@@ -1,30 +0,0 @@
1
- /* istanbul ignore file */
2
- import { describe, test, expect } from 'bun:test';
3
- import { OriginalsSDK, OriginalsAsset } from '../../../src';
4
- import { MockOrdinalsProvider } from '../../mocks/adapters';
5
-
6
- describe('LifecycleManager.transferOwnership unit edge cases', () => {
7
- const provider = new MockOrdinalsProvider();
8
- const sdk = OriginalsSDK.create({ network: 'regtest', ordinalsProvider: provider } as any);
9
-
10
- test('throws if not on btco layer', async () => {
11
- const asset = new OriginalsAsset(
12
- [{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'h' }],
13
- { '@context': ['https://www.w3.org/ns/did/v1'], id: 'did:webvh:domain:1' } as any,
14
- []
15
- );
16
- await expect(sdk.lifecycle.transferOwnership(asset as any, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx')).rejects.toThrow('Asset must be inscribed on Bitcoin before transfer');
17
- });
18
-
19
- test('succeeds and updates provenance when on btco', async () => {
20
- const asset = new OriginalsAsset(
21
- [{ id: 'r', type: 'text', contentType: 'text/plain', hash: 'h' }],
22
- { '@context': ['https://www.w3.org/ns/did/v1'], id: 'did:btco:42' } as any,
23
- []
24
- );
25
- const tx = await sdk.lifecycle.transferOwnership(asset, 'tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7');
26
- expect(typeof tx.txid).toBe('string');
27
- expect(asset.getProvenance().transfers.length).toBe(1);
28
- });
29
- });
30
-