@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,323 +0,0 @@
1
- /**
2
- * Manual Test: Commit Transaction Creation
3
- *
4
- * This script demonstrates and verifies commit transaction creation without broadcasting.
5
- * It uses test data (NOT real keys) to ensure the commit transaction logic works correctly.
6
- *
7
- * Expected Output:
8
- * - Valid P2TR commit address
9
- * - Valid PSBT with correct inputs and outputs
10
- * - Reveal keypair for subsequent reveal transaction
11
- * - Inscription script data (script, control block, leaf version)
12
- * - Fee calculation matching expected values
13
- *
14
- * Usage:
15
- * ```bash
16
- * bun run tests/manual/test-commit-creation.ts
17
- * ```
18
- *
19
- * IMPORTANT: This script does NOT broadcast transactions. It only creates and verifies
20
- * the PSBT structure for commit transactions.
21
- */
22
-
23
- import { createCommitTransaction } from '../../src/bitcoin/transactions/commit.js';
24
- import type { Utxo } from '../../src/types/bitcoin.js';
25
- import * as btc from '@scure/btc-signer';
26
-
27
- // ANSI color codes for output
28
- const colors = {
29
- reset: '\x1b[0m',
30
- bright: '\x1b[1m',
31
- green: '\x1b[32m',
32
- blue: '\x1b[34m',
33
- yellow: '\x1b[33m',
34
- red: '\x1b[31m'
35
- };
36
-
37
- function log(message: string, color = colors.reset) {
38
- console.log(`${color}${message}${colors.reset}`);
39
- }
40
-
41
- function logSection(title: string) {
42
- console.log('\n' + '='.repeat(80));
43
- log(title, colors.bright + colors.blue);
44
- console.log('='.repeat(80));
45
- }
46
-
47
- function logSuccess(message: string) {
48
- log(`✓ ${message}`, colors.green);
49
- }
50
-
51
- function logInfo(message: string) {
52
- log(`ℹ ${message}`, colors.blue);
53
- }
54
-
55
- function logWarning(message: string) {
56
- log(`⚠ ${message}`, colors.yellow);
57
- }
58
-
59
- function logError(message: string) {
60
- log(`✗ ${message}`, colors.red);
61
- }
62
-
63
- /**
64
- * Create mock UTXOs for testing (NOT real UTXOs)
65
- */
66
- function createMockUtxos(): Utxo[] {
67
- return [
68
- {
69
- txid: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
70
- vout: 0,
71
- value: 50000,
72
- scriptPubKey: '0014' + 'b'.repeat(40), // Mock P2WPKH scriptPubKey
73
- address: 'bc1qtest1234567890'
74
- },
75
- {
76
- txid: 'bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb',
77
- vout: 1,
78
- value: 30000,
79
- scriptPubKey: '0014' + 'c'.repeat(40),
80
- address: 'bc1qtest0987654321'
81
- }
82
- ];
83
- }
84
-
85
- /**
86
- * Verify PSBT structure without decoding (basic checks)
87
- */
88
- function verifyPsbtStructure(psbt: btc.Transaction, expectedInputCount: number): boolean {
89
- try {
90
- logInfo(`PSBT Input Count: ${psbt.inputsLength}`);
91
- logInfo(`PSBT Output Count: ${psbt.outputsLength}`);
92
-
93
- if (psbt.inputsLength !== expectedInputCount) {
94
- logError(`Expected ${expectedInputCount} inputs, got ${psbt.inputsLength}`);
95
- return false;
96
- }
97
-
98
- if (psbt.outputsLength < 1) {
99
- logError(`Expected at least 1 output, got ${psbt.outputsLength}`);
100
- return false;
101
- }
102
-
103
- logSuccess('PSBT structure is valid');
104
- return true;
105
- } catch (error) {
106
- logError(`Failed to verify PSBT: ${error instanceof Error ? error.message : 'Unknown error'}`);
107
- return false;
108
- }
109
- }
110
-
111
- /**
112
- * Main test function
113
- */
114
- async function main() {
115
- logSection('Commit Transaction Creation Test');
116
-
117
- try {
118
- // Test 1: Create simple text inscription
119
- logSection('Test 1: Simple Text Inscription');
120
-
121
- const inscription1Content = Buffer.from('Hello, Ordinals!');
122
- const mockUtxos1 = createMockUtxos();
123
-
124
- logInfo('Creating commit transaction...');
125
- logInfo(`Content: "${inscription1Content.toString()}"`);
126
- logInfo(`Content Type: text/plain`);
127
- logInfo(`Available UTXOs: ${mockUtxos1.length}`);
128
- logInfo(`Total Value: ${mockUtxos1.reduce((sum, u) => sum + u.value, 0)} sats`);
129
-
130
- const result1 = await createCommitTransaction({
131
- content: inscription1Content,
132
- contentType: 'text/plain',
133
- utxos: mockUtxos1,
134
- changeAddress: 'bc1qtest_change_address_12345',
135
- feeRate: 10,
136
- network: 'mainnet'
137
- });
138
-
139
- logSuccess('Commit transaction created successfully');
140
-
141
- // Verify commit address
142
- logInfo(`Commit Address: ${result1.commitAddress}`);
143
- if (result1.commitAddress.startsWith('bc1p')) {
144
- logSuccess('Commit address is valid P2TR (bc1p...)');
145
- } else {
146
- logWarning(`Unexpected address format: ${result1.commitAddress}`);
147
- }
148
-
149
- // Verify PSBT
150
- logInfo(`PSBT Base64 Length: ${result1.commitPsbtBase64.length} chars`);
151
- logInfo(`PSBT Base64 (first 50 chars): ${result1.commitPsbtBase64.substring(0, 50)}...`);
152
-
153
- // Verify PSBT structure
154
- const psbtValid = verifyPsbtStructure(result1.commitPsbt, 1);
155
- if (!psbtValid) {
156
- throw new Error('PSBT structure validation failed');
157
- }
158
-
159
- // Verify commit amount and fees
160
- logInfo(`Commit Amount: ${result1.commitAmount} sats`);
161
- logInfo(`Commit Fee: ${result1.fees.commit} sats`);
162
-
163
- if (result1.commitAmount < 546) {
164
- logError('Commit amount is below dust limit!');
165
- } else {
166
- logSuccess('Commit amount meets dust limit');
167
- }
168
-
169
- if (result1.fees.commit <= 0) {
170
- logError('Invalid fee amount!');
171
- } else {
172
- logSuccess(`Fee calculation: ${result1.fees.commit} sats at 10 sat/vB`);
173
- }
174
-
175
- // Verify reveal keypair
176
- logInfo(`Reveal Private Key Length: ${result1.revealPrivateKey.length} chars`);
177
- logInfo(`Reveal Public Key Length: ${result1.revealPublicKey.length} chars`);
178
-
179
- if (result1.revealPrivateKey.length === 64 && result1.revealPublicKey.length === 64) {
180
- logSuccess('Reveal keypair has correct format (32 bytes each in hex)');
181
- } else {
182
- logWarning('Unexpected reveal keypair format');
183
- }
184
-
185
- // Verify inscription script
186
- logInfo(`Inscription Script Length: ${result1.inscriptionScript.script.length} bytes`);
187
- logInfo(`Control Block Length: ${result1.inscriptionScript.controlBlock.length} bytes`);
188
- logInfo(`Leaf Version: 0x${result1.inscriptionScript.leafVersion.toString(16)}`);
189
-
190
- if (result1.inscriptionScript.leafVersion === 0xc0) {
191
- logSuccess('Leaf version is correct (0xc0)');
192
- } else {
193
- logWarning(`Unexpected leaf version: 0x${result1.inscriptionScript.leafVersion.toString(16)}`);
194
- }
195
-
196
- // Verify selected UTXOs
197
- logInfo(`Selected UTXOs: ${result1.selectedUtxos.length}`);
198
- const totalSelectedValue = result1.selectedUtxos.reduce((sum, u) => sum + u.value, 0);
199
- logInfo(`Total Selected Value: ${totalSelectedValue} sats`);
200
-
201
- const expectedMinimum = result1.commitAmount + result1.fees.commit;
202
- if (totalSelectedValue >= expectedMinimum) {
203
- logSuccess(`Selected UTXOs cover commit + fees (${totalSelectedValue} >= ${expectedMinimum})`);
204
- } else {
205
- logError(`Insufficient selected value (${totalSelectedValue} < ${expectedMinimum})`);
206
- }
207
-
208
- // Test 2: JSON content with metadata
209
- logSection('Test 2: JSON Content with Metadata');
210
-
211
- const inscription2Content = Buffer.from(JSON.stringify({
212
- message: 'Test inscription',
213
- timestamp: Date.now()
214
- }));
215
-
216
- const result2 = await createCommitTransaction({
217
- content: inscription2Content,
218
- contentType: 'application/json',
219
- utxos: createMockUtxos(),
220
- changeAddress: 'bc1qtest_change_address_12345',
221
- feeRate: 20,
222
- network: 'mainnet',
223
- metadata: {
224
- title: 'Test JSON Inscription',
225
- author: 'Manual Test Script'
226
- }
227
- });
228
-
229
- logSuccess('JSON inscription commit transaction created');
230
- logInfo(`Commit Address: ${result2.commitAddress}`);
231
- logInfo(`Fee Rate: 20 sat/vB`);
232
- logInfo(`Commit Fee: ${result2.fees.commit} sats`);
233
-
234
- // Verify fee scales with fee rate (should be ~2x the first test)
235
- const feeRatio = result2.fees.commit / result1.fees.commit;
236
- logInfo(`Fee Ratio (20 sat/vB vs 10 sat/vB): ${feeRatio.toFixed(2)}x`);
237
-
238
- if (feeRatio >= 1.8 && feeRatio <= 2.2) {
239
- logSuccess('Fee scales correctly with fee rate');
240
- } else {
241
- logWarning(`Fee ratio outside expected range: ${feeRatio.toFixed(2)}x`);
242
- }
243
-
244
- // Test 3: Large content (1KB)
245
- logSection('Test 3: Large Content (1KB)');
246
-
247
- const largeContent = Buffer.alloc(1024, 'a');
248
-
249
- const result3 = await createCommitTransaction({
250
- content: largeContent,
251
- contentType: 'text/plain',
252
- utxos: [
253
- {
254
- txid: 'c'.repeat(64),
255
- vout: 0,
256
- value: 500000, // Larger UTXO for larger content
257
- scriptPubKey: '0014' + 'd'.repeat(40),
258
- address: 'bc1qtest_large_utxo'
259
- }
260
- ],
261
- changeAddress: 'bc1qtest_change_address_12345',
262
- feeRate: 10,
263
- network: 'mainnet'
264
- });
265
-
266
- logSuccess('Large content inscription commit transaction created');
267
- logInfo(`Content Size: ${largeContent.length} bytes`);
268
- logInfo(`Inscription Script Size: ${result3.inscriptionScript.script.length} bytes`);
269
- logInfo(`Commit Fee: ${result3.fees.commit} sats`);
270
-
271
- // Test 4: Testnet address
272
- logSection('Test 4: Testnet Address Generation');
273
-
274
- const result4 = await createCommitTransaction({
275
- content: Buffer.from('Testnet inscription'),
276
- contentType: 'text/plain',
277
- utxos: createMockUtxos(),
278
- changeAddress: 'tb1qtest_testnet_change',
279
- feeRate: 5,
280
- network: 'testnet'
281
- });
282
-
283
- logInfo(`Testnet Commit Address: ${result4.commitAddress}`);
284
-
285
- if (result4.commitAddress.startsWith('tb1p')) {
286
- logSuccess('Testnet address is valid (tb1p...)');
287
- } else {
288
- logWarning(`Unexpected testnet address format: ${result4.commitAddress}`);
289
- }
290
-
291
- // Final summary
292
- logSection('Test Summary');
293
- logSuccess('All tests completed successfully!');
294
- logInfo('Commit transaction creation is working correctly');
295
- logInfo('PSBT structure is valid');
296
- logInfo('Fee calculation is accurate');
297
- logInfo('P2TR address generation is correct');
298
- logInfo('Inscription script data is properly formatted');
299
-
300
- console.log('\n' + '='.repeat(80));
301
- logSuccess('✓ Manual verification complete - commit.ts is ready for use');
302
- console.log('='.repeat(80) + '\n');
303
-
304
- // IMPORTANT REMINDER
305
- logWarning('REMINDER: This script does NOT broadcast transactions');
306
- logWarning(' It only creates and verifies PSBT structure');
307
- logWarning(' DO NOT use these test keys or addresses for real Bitcoin');
308
-
309
- } catch (error) {
310
- logSection('Test Failed');
311
- logError(`Error: ${error instanceof Error ? error.message : 'Unknown error'}`);
312
- if (error instanceof Error && error.stack) {
313
- console.error(error.stack);
314
- }
315
- process.exit(1);
316
- }
317
- }
318
-
319
- // Run the tests
320
- main().catch(error => {
321
- console.error('Unhandled error:', error);
322
- process.exit(1);
323
- });
@@ -1,38 +0,0 @@
1
- import { KeyStore } from '../../src/types';
2
-
3
- /**
4
- * MockKeyStore is a simple in-memory implementation of the KeyStore interface
5
- * for testing purposes.
6
- */
7
- export class MockKeyStore implements KeyStore {
8
- private keys: Map<string, string> = new Map();
9
-
10
- async getPrivateKey(verificationMethodId: string): Promise<string | null> {
11
- return this.keys.get(verificationMethodId) || null;
12
- }
13
-
14
- async setPrivateKey(verificationMethodId: string, privateKey: string): Promise<void> {
15
- this.keys.set(verificationMethodId, privateKey);
16
- }
17
-
18
- /**
19
- * Helper method for testing: clear all stored keys
20
- */
21
- clear(): void {
22
- this.keys.clear();
23
- }
24
-
25
- /**
26
- * Helper method for testing: get all stored keys
27
- */
28
- getAllKeys(): Map<string, string> {
29
- return new Map(this.keys);
30
- }
31
-
32
- /**
33
- * Helper method: get all verification method IDs
34
- */
35
- getAllVerificationMethodIds(): string[] {
36
- return Array.from(this.keys.keys());
37
- }
38
- }
@@ -1,24 +0,0 @@
1
- import type { StorageAdapter, StorageGetResult, StoragePutOptions } from '../../../src/adapters/types';
2
-
3
- export class MemoryStorageAdapter implements StorageAdapter {
4
- private readonly keyToObject: Map<string, { content: Buffer; contentType: string }> = new Map();
5
-
6
- async put(objectKey: string, data: Buffer | string, options: StoragePutOptions = {}): Promise<string> {
7
- const content = Buffer.isBuffer(data) ? data : Buffer.from(data);
8
- const contentType = options.contentType || 'application/octet-stream';
9
- this.keyToObject.set(objectKey, { content, contentType });
10
- return `memory://${objectKey}`;
11
- }
12
-
13
- async get(objectKey: string): Promise<StorageGetResult | null> {
14
- const entry = this.keyToObject.get(objectKey);
15
- if (!entry) return null;
16
- return { content: Buffer.from(entry.content), contentType: entry.contentType };
17
- }
18
-
19
- async delete(objectKey: string): Promise<boolean> {
20
- return this.keyToObject.delete(objectKey);
21
- }
22
- }
23
-
24
-
@@ -1,11 +0,0 @@
1
- import type { FeeOracleAdapter } from '../../../src/adapters/types';
2
-
3
- export class MockFeeOracle implements FeeOracleAdapter {
4
- constructor(private readonly defaultRate: number = 10) {}
5
- async estimateFeeRate(targetBlocks: number = 1): Promise<number> {
6
- const multiplier = Math.max(1, Math.min(6, targetBlocks));
7
- return this.defaultRate * multiplier;
8
- }
9
- }
10
-
11
-
@@ -1,76 +0,0 @@
1
- import type { OrdinalsProvider } from '../../../src/adapters/types';
2
-
3
- export class MockOrdinalsProvider implements OrdinalsProvider {
4
- async createInscription(params: { data: Buffer; contentType: string; feeRate?: number }) {
5
- return {
6
- inscriptionId: 'insc-mock',
7
- revealTxId: 'tx-reveal-mock',
8
- commitTxId: 'tx-commit-mock',
9
- satoshi: '123',
10
- txid: 'tx-mock',
11
- vout: 0,
12
- blockHeight: 1,
13
- content: params.data,
14
- contentType: params.contentType,
15
- feeRate: params.feeRate
16
- };
17
- }
18
-
19
- async getInscriptionById(id: string) {
20
- if (!id) return null;
21
- return {
22
- inscriptionId: id,
23
- content: Buffer.from(''),
24
- contentType: 'text/plain',
25
- txid: 'tx-mock',
26
- vout: 0,
27
- satoshi: '123'
28
- };
29
- }
30
-
31
- async transferInscription(
32
- inscriptionId: string,
33
- toAddress: string,
34
- options?: { feeRate?: number }
35
- ): Promise<{
36
- txid: string;
37
- vin: Array<{ txid: string; vout: number }>;
38
- vout: Array<{ value: number; scriptPubKey: string; address?: string }>;
39
- fee: number;
40
- blockHeight?: number;
41
- confirmations?: number;
42
- satoshi?: string;
43
- }> {
44
- if (!inscriptionId) {
45
- throw new Error('inscriptionId required');
46
- }
47
- return {
48
- txid: 'tx-transfer-mock',
49
- vin: [{ txid: 'tx-prev', vout: 0 }],
50
- vout: [{ value: 10_000, scriptPubKey: 'script', address: toAddress }],
51
- fee: options?.feeRate ? Math.round(options.feeRate) : 100,
52
- blockHeight: 2,
53
- confirmations: 0,
54
- satoshi: '123'
55
- };
56
- }
57
-
58
- async getInscriptionsBySatoshi(satoshi: string) {
59
- if (!satoshi) return [];
60
- return [{ inscriptionId: 'insc-mock' }];
61
- }
62
-
63
- async broadcastTransaction(_txHexOrObj: unknown): Promise<string> {
64
- return 'txid-mock';
65
- }
66
-
67
- async getTransactionStatus(_txid: string): Promise<{ confirmed: boolean; blockHeight?: number; confirmations?: number }> {
68
- return { confirmed: false };
69
- }
70
-
71
- async estimateFee(blocks: number = 1): Promise<number> {
72
- return 10 * Math.max(1, blocks);
73
- }
74
- }
75
-
76
-
@@ -1,176 +0,0 @@
1
- import { describe, test, expect } from 'bun:test';
2
- import { OrdMockProvider } from '../../../src/adapters/providers/OrdMockProvider';
3
-
4
- describe('OrdMockProvider', () => {
5
- test('createInscription and retrieval works', async () => {
6
- const prov = new OrdMockProvider();
7
- const data = Buffer.from('hello');
8
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
9
- expect(typeof res.inscriptionId).toBe('string');
10
- const fetched = await prov.getInscriptionById(res.inscriptionId);
11
- expect(fetched?.txid).toBe(res.txid);
12
- });
13
-
14
- test('broadcastTransaction returns mock txid', async () => {
15
- const prov = new OrdMockProvider();
16
- const txid = await prov.broadcastTransaction('mock-tx-hex');
17
- expect(txid).toBe('mock-broadcast-txid');
18
- });
19
-
20
- test('getTransactionStatus returns confirmed status', async () => {
21
- const prov = new OrdMockProvider();
22
- const status = await prov.getTransactionStatus('any-txid');
23
- expect(status.confirmed).toBe(true);
24
- expect(status.blockHeight).toBe(1);
25
- expect(status.confirmations).toBe(1);
26
- });
27
-
28
- test('estimateFee with default blocks', async () => {
29
- const prov = new OrdMockProvider();
30
- const fee = await prov.estimateFee();
31
- expect(fee).toBeGreaterThanOrEqual(1);
32
- });
33
-
34
- test('estimateFee with multiple blocks reduces fee', async () => {
35
- const prov = new OrdMockProvider({ feeRate: 10 });
36
- const fee1 = await prov.estimateFee(1);
37
- const fee3 = await prov.estimateFee(3);
38
- expect(fee1).toBe(10);
39
- expect(fee3).toBe(8); // 10 - (3-1) = 8
40
- });
41
-
42
- test('transferInscription throws error for non-existent inscription', async () => {
43
- const prov = new OrdMockProvider();
44
- await expect(prov.transferInscription('non-existent', 'bc1qaddress'))
45
- .rejects.toThrow('inscription not found');
46
- });
47
-
48
- test('constructor accepts custom state', async () => {
49
- const customState = new Map();
50
- customState.set('test-id', {
51
- inscriptionId: 'test-id',
52
- content: Buffer.from('test'),
53
- contentType: 'text/plain',
54
- txid: 'test-txid',
55
- vout: 0,
56
- satoshi: 'test-sat'
57
- });
58
-
59
- const prov = new OrdMockProvider({
60
- inscriptionsById: customState,
61
- feeRate: 10
62
- });
63
-
64
- const inscription = await prov.getInscriptionById('test-id');
65
- expect(inscription).toBeDefined();
66
- expect(inscription?.inscriptionId).toBe('test-id');
67
- });
68
-
69
- test('getInscriptionById returns null for non-existent id', async () => {
70
- const prov = new OrdMockProvider();
71
- const inscription = await prov.getInscriptionById('non-existent');
72
- expect(inscription).toBeNull();
73
- });
74
-
75
- test('getInscriptionsBySatoshi returns empty array for non-existent satoshi', async () => {
76
- const prov = new OrdMockProvider();
77
- const inscriptions = await prov.getInscriptionsBySatoshi('999999');
78
- expect(inscriptions).toEqual([]);
79
- });
80
-
81
- test('getInscriptionsBySatoshi returns list of inscriptions for satoshi', async () => {
82
- const prov = new OrdMockProvider();
83
- const data = Buffer.from('test data');
84
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
85
-
86
- // Get the satoshi from the created inscription
87
- const inscriptions = await prov.getInscriptionsBySatoshi(res.satoshi!);
88
- expect(inscriptions.length).toBeGreaterThan(0);
89
- expect(inscriptions[0].inscriptionId).toBe(res.inscriptionId);
90
- });
91
-
92
- test('createInscription with custom feeRate', async () => {
93
- const prov = new OrdMockProvider();
94
- const data = Buffer.from('test data');
95
- const res = await prov.createInscription({
96
- data,
97
- contentType: 'text/plain',
98
- feeRate: 15
99
- });
100
- expect(res.feeRate).toBe(15);
101
- });
102
-
103
- test('createInscription returns all expected fields', async () => {
104
- const prov = new OrdMockProvider();
105
- const data = Buffer.from('test data');
106
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
107
-
108
- expect(res.inscriptionId).toBeDefined();
109
- expect(res.revealTxId).toBeDefined();
110
- expect(res.commitTxId).toBeUndefined();
111
- expect(res.satoshi).toBeDefined();
112
- expect(res.txid).toBeDefined();
113
- expect(res.vout).toBe(0);
114
- expect(res.blockHeight).toBe(1);
115
- expect(res.content).toEqual(data);
116
- expect(res.contentType).toBe('text/plain');
117
- });
118
-
119
- test('transferInscription returns proper transaction details', async () => {
120
- const prov = new OrdMockProvider();
121
- const data = Buffer.from('test data');
122
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
123
-
124
- const transfer = await prov.transferInscription(res.inscriptionId, 'bc1qaddress', { feeRate: 10 });
125
-
126
- expect(transfer.txid).toBeDefined();
127
- expect(transfer.vin).toBeDefined();
128
- expect(transfer.vin.length).toBeGreaterThan(0);
129
- expect(transfer.vin[0].txid).toBe(res.txid);
130
- expect(transfer.vin[0].vout).toBe(res.vout);
131
- expect(transfer.vout).toBeDefined();
132
- expect(transfer.vout[0].value).toBe(546);
133
- expect(transfer.vout[0].scriptPubKey).toBe('script');
134
- expect(transfer.fee).toBe(100);
135
- expect(transfer.blockHeight).toBe(1);
136
- expect(transfer.confirmations).toBe(0);
137
- expect(transfer.satoshi).toBe(res.satoshi);
138
- });
139
-
140
- test('transferInscription without options', async () => {
141
- const prov = new OrdMockProvider();
142
- const data = Buffer.from('test data');
143
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
144
-
145
- const transfer = await prov.transferInscription(res.inscriptionId, 'bc1qaddress');
146
-
147
- expect(transfer.txid).toBeDefined();
148
- });
149
-
150
- test('constructor with partial state including inscriptionsBySatoshi', async () => {
151
- const inscriptionsBySatoshi = new Map();
152
- inscriptionsBySatoshi.set('12345', ['insc-1', 'insc-2']);
153
-
154
- const prov = new OrdMockProvider({
155
- inscriptionsBySatoshi,
156
- feeRate: 8
157
- });
158
-
159
- const inscriptions = await prov.getInscriptionsBySatoshi('12345');
160
- expect(inscriptions.length).toBe(2);
161
- expect(inscriptions[0].inscriptionId).toBe('insc-1');
162
- expect(inscriptions[1].inscriptionId).toBe('insc-2');
163
- });
164
-
165
- test('createInscription generates numeric satoshi identifier', async () => {
166
- const prov = new OrdMockProvider();
167
- const data = Buffer.from('test');
168
- const res = await prov.createInscription({ data, contentType: 'text/plain' });
169
-
170
- // Verify satoshi is numeric
171
- expect(res.satoshi).toBeDefined();
172
- expect(Number.isNaN(Number(res.satoshi))).toBe(false);
173
- expect(Number(res.satoshi!)).toBeGreaterThan(0);
174
- });
175
- });
176
-
@@ -1,6 +0,0 @@
1
- export * from './MemoryStorageAdapter';
2
- export * from './MockFeeOracle';
3
- export * from './MockOrdinalsProvider';
4
- export * from '../MockKeyStore';
5
-
6
-