@originals/sdk 1.1.0 → 1.4.2

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 (247) hide show
  1. package/package.json +3 -2
  2. package/src/did/DIDManager.ts +1 -1
  3. package/src/did/WebVHManager.ts +11 -2
  4. package/src/examples/create-module-original.ts +435 -0
  5. package/src/examples/full-lifecycle-flow.ts +514 -0
  6. package/src/examples/run.ts +59 -4
  7. package/src/index.ts +69 -3
  8. package/src/kinds/KindRegistry.ts +290 -0
  9. package/src/kinds/index.ts +74 -0
  10. package/src/kinds/types.ts +470 -0
  11. package/src/kinds/validators/AgentValidator.ts +257 -0
  12. package/src/kinds/validators/AppValidator.ts +211 -0
  13. package/src/kinds/validators/DatasetValidator.ts +242 -0
  14. package/src/kinds/validators/DocumentValidator.ts +311 -0
  15. package/src/kinds/validators/MediaValidator.ts +269 -0
  16. package/src/kinds/validators/ModuleValidator.ts +225 -0
  17. package/src/kinds/validators/base.ts +276 -0
  18. package/src/kinds/validators/index.ts +12 -0
  19. package/src/lifecycle/LifecycleManager.ts +909 -1
  20. package/src/resources/ResourceManager.ts +655 -0
  21. package/src/resources/index.ts +21 -0
  22. package/src/resources/types.ts +202 -0
  23. package/src/types/common.ts +1 -1
  24. package/src/vc/CredentialManager.ts +647 -2
  25. package/tests/integration/createTypedOriginal.test.ts +379 -0
  26. package/tests/performance/BatchOperations.perf.test.ts +2 -2
  27. package/tests/unit/kinds/KindRegistry.test.ts +329 -0
  28. package/tests/unit/kinds/types.test.ts +409 -0
  29. package/tests/unit/kinds/validators.test.ts +651 -0
  30. package/tests/unit/lifecycle/LifecycleManager.cleanapi.test.ts +441 -0
  31. package/tests/unit/resources/ResourceManager.test.ts +740 -0
  32. package/tests/unit/vc/CredentialManager.helpers.test.ts +527 -0
  33. package/tsconfig.json +0 -1
  34. package/.turbo/turbo-build.log +0 -1
  35. package/.turbo/turbo-test.log +0 -68353
  36. package/dist/adapters/FeeOracleMock.d.ts +0 -6
  37. package/dist/adapters/FeeOracleMock.js +0 -8
  38. package/dist/adapters/index.d.ts +0 -4
  39. package/dist/adapters/index.js +0 -4
  40. package/dist/adapters/providers/OrdHttpProvider.d.ts +0 -56
  41. package/dist/adapters/providers/OrdHttpProvider.js +0 -110
  42. package/dist/adapters/providers/OrdMockProvider.d.ts +0 -70
  43. package/dist/adapters/providers/OrdMockProvider.js +0 -75
  44. package/dist/adapters/types.d.ts +0 -71
  45. package/dist/adapters/types.js +0 -1
  46. package/dist/bitcoin/BitcoinManager.d.ts +0 -15
  47. package/dist/bitcoin/BitcoinManager.js +0 -262
  48. package/dist/bitcoin/BroadcastClient.d.ts +0 -30
  49. package/dist/bitcoin/BroadcastClient.js +0 -35
  50. package/dist/bitcoin/OrdinalsClient.d.ts +0 -21
  51. package/dist/bitcoin/OrdinalsClient.js +0 -105
  52. package/dist/bitcoin/PSBTBuilder.d.ts +0 -24
  53. package/dist/bitcoin/PSBTBuilder.js +0 -80
  54. package/dist/bitcoin/fee-calculation.d.ts +0 -14
  55. package/dist/bitcoin/fee-calculation.js +0 -31
  56. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +0 -38
  57. package/dist/bitcoin/providers/OrdNodeProvider.js +0 -67
  58. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +0 -33
  59. package/dist/bitcoin/providers/OrdinalsProvider.js +0 -50
  60. package/dist/bitcoin/providers/types.d.ts +0 -63
  61. package/dist/bitcoin/providers/types.js +0 -1
  62. package/dist/bitcoin/transactions/commit.d.ts +0 -89
  63. package/dist/bitcoin/transactions/commit.js +0 -311
  64. package/dist/bitcoin/transactions/index.d.ts +0 -7
  65. package/dist/bitcoin/transactions/index.js +0 -8
  66. package/dist/bitcoin/transfer.d.ts +0 -9
  67. package/dist/bitcoin/transfer.js +0 -26
  68. package/dist/bitcoin/utxo-selection.d.ts +0 -78
  69. package/dist/bitcoin/utxo-selection.js +0 -237
  70. package/dist/bitcoin/utxo.d.ts +0 -26
  71. package/dist/bitcoin/utxo.js +0 -78
  72. package/dist/contexts/credentials-v1.json +0 -195
  73. package/dist/contexts/credentials-v2-examples.json +0 -5
  74. package/dist/contexts/credentials-v2.json +0 -301
  75. package/dist/contexts/credentials.json +0 -195
  76. package/dist/contexts/data-integrity-v2.json +0 -81
  77. package/dist/contexts/dids.json +0 -57
  78. package/dist/contexts/ed255192020.json +0 -93
  79. package/dist/contexts/ordinals-plus.json +0 -23
  80. package/dist/contexts/originals.json +0 -22
  81. package/dist/core/OriginalsSDK.d.ts +0 -158
  82. package/dist/core/OriginalsSDK.js +0 -274
  83. package/dist/crypto/Multikey.d.ts +0 -30
  84. package/dist/crypto/Multikey.js +0 -149
  85. package/dist/crypto/Signer.d.ts +0 -21
  86. package/dist/crypto/Signer.js +0 -196
  87. package/dist/crypto/noble-init.d.ts +0 -18
  88. package/dist/crypto/noble-init.js +0 -106
  89. package/dist/did/BtcoDidResolver.d.ts +0 -57
  90. package/dist/did/BtcoDidResolver.js +0 -166
  91. package/dist/did/DIDManager.d.ts +0 -101
  92. package/dist/did/DIDManager.js +0 -493
  93. package/dist/did/Ed25519Verifier.d.ts +0 -30
  94. package/dist/did/Ed25519Verifier.js +0 -59
  95. package/dist/did/KeyManager.d.ts +0 -17
  96. package/dist/did/KeyManager.js +0 -207
  97. package/dist/did/WebVHManager.d.ts +0 -100
  98. package/dist/did/WebVHManager.js +0 -304
  99. package/dist/did/createBtcoDidDocument.d.ts +0 -10
  100. package/dist/did/createBtcoDidDocument.js +0 -42
  101. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +0 -23
  102. package/dist/did/providers/OrdinalsClientProviderAdapter.js +0 -51
  103. package/dist/events/EventEmitter.d.ts +0 -115
  104. package/dist/events/EventEmitter.js +0 -198
  105. package/dist/events/index.d.ts +0 -7
  106. package/dist/events/index.js +0 -6
  107. package/dist/events/types.d.ts +0 -286
  108. package/dist/events/types.js +0 -9
  109. package/dist/examples/basic-usage.d.ts +0 -3
  110. package/dist/examples/basic-usage.js +0 -62
  111. package/dist/examples/run.d.ts +0 -1
  112. package/dist/examples/run.js +0 -4
  113. package/dist/index.d.ts +0 -39
  114. package/dist/index.js +0 -47
  115. package/dist/lifecycle/BatchOperations.d.ts +0 -147
  116. package/dist/lifecycle/BatchOperations.js +0 -251
  117. package/dist/lifecycle/LifecycleManager.d.ts +0 -116
  118. package/dist/lifecycle/LifecycleManager.js +0 -971
  119. package/dist/lifecycle/OriginalsAsset.d.ts +0 -164
  120. package/dist/lifecycle/OriginalsAsset.js +0 -380
  121. package/dist/lifecycle/ProvenanceQuery.d.ts +0 -126
  122. package/dist/lifecycle/ProvenanceQuery.js +0 -220
  123. package/dist/lifecycle/ResourceVersioning.d.ts +0 -73
  124. package/dist/lifecycle/ResourceVersioning.js +0 -127
  125. package/dist/migration/MigrationManager.d.ts +0 -86
  126. package/dist/migration/MigrationManager.js +0 -412
  127. package/dist/migration/audit/AuditLogger.d.ts +0 -51
  128. package/dist/migration/audit/AuditLogger.js +0 -156
  129. package/dist/migration/checkpoint/CheckpointManager.d.ts +0 -31
  130. package/dist/migration/checkpoint/CheckpointManager.js +0 -96
  131. package/dist/migration/checkpoint/CheckpointStorage.d.ts +0 -26
  132. package/dist/migration/checkpoint/CheckpointStorage.js +0 -89
  133. package/dist/migration/index.d.ts +0 -22
  134. package/dist/migration/index.js +0 -27
  135. package/dist/migration/operations/BaseMigration.d.ts +0 -48
  136. package/dist/migration/operations/BaseMigration.js +0 -83
  137. package/dist/migration/operations/PeerToBtcoMigration.d.ts +0 -25
  138. package/dist/migration/operations/PeerToBtcoMigration.js +0 -67
  139. package/dist/migration/operations/PeerToWebvhMigration.d.ts +0 -19
  140. package/dist/migration/operations/PeerToWebvhMigration.js +0 -46
  141. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +0 -25
  142. package/dist/migration/operations/WebvhToBtcoMigration.js +0 -67
  143. package/dist/migration/rollback/RollbackManager.d.ts +0 -29
  144. package/dist/migration/rollback/RollbackManager.js +0 -146
  145. package/dist/migration/state/StateMachine.d.ts +0 -25
  146. package/dist/migration/state/StateMachine.js +0 -76
  147. package/dist/migration/state/StateTracker.d.ts +0 -36
  148. package/dist/migration/state/StateTracker.js +0 -123
  149. package/dist/migration/types.d.ts +0 -306
  150. package/dist/migration/types.js +0 -33
  151. package/dist/migration/validation/BitcoinValidator.d.ts +0 -13
  152. package/dist/migration/validation/BitcoinValidator.js +0 -83
  153. package/dist/migration/validation/CredentialValidator.d.ts +0 -13
  154. package/dist/migration/validation/CredentialValidator.js +0 -46
  155. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +0 -16
  156. package/dist/migration/validation/DIDCompatibilityValidator.js +0 -127
  157. package/dist/migration/validation/LifecycleValidator.d.ts +0 -10
  158. package/dist/migration/validation/LifecycleValidator.js +0 -52
  159. package/dist/migration/validation/StorageValidator.d.ts +0 -10
  160. package/dist/migration/validation/StorageValidator.js +0 -65
  161. package/dist/migration/validation/ValidationPipeline.d.ts +0 -29
  162. package/dist/migration/validation/ValidationPipeline.js +0 -180
  163. package/dist/storage/LocalStorageAdapter.d.ts +0 -11
  164. package/dist/storage/LocalStorageAdapter.js +0 -53
  165. package/dist/storage/MemoryStorageAdapter.d.ts +0 -6
  166. package/dist/storage/MemoryStorageAdapter.js +0 -21
  167. package/dist/storage/StorageAdapter.d.ts +0 -16
  168. package/dist/storage/StorageAdapter.js +0 -1
  169. package/dist/storage/index.d.ts +0 -2
  170. package/dist/storage/index.js +0 -2
  171. package/dist/types/bitcoin.d.ts +0 -84
  172. package/dist/types/bitcoin.js +0 -1
  173. package/dist/types/common.d.ts +0 -82
  174. package/dist/types/common.js +0 -1
  175. package/dist/types/credentials.d.ts +0 -75
  176. package/dist/types/credentials.js +0 -1
  177. package/dist/types/did.d.ts +0 -26
  178. package/dist/types/did.js +0 -1
  179. package/dist/types/index.d.ts +0 -5
  180. package/dist/types/index.js +0 -5
  181. package/dist/types/network.d.ts +0 -78
  182. package/dist/types/network.js +0 -145
  183. package/dist/utils/EventLogger.d.ts +0 -71
  184. package/dist/utils/EventLogger.js +0 -232
  185. package/dist/utils/Logger.d.ts +0 -106
  186. package/dist/utils/Logger.js +0 -257
  187. package/dist/utils/MetricsCollector.d.ts +0 -110
  188. package/dist/utils/MetricsCollector.js +0 -264
  189. package/dist/utils/bitcoin-address.d.ts +0 -38
  190. package/dist/utils/bitcoin-address.js +0 -113
  191. package/dist/utils/cbor.d.ts +0 -2
  192. package/dist/utils/cbor.js +0 -9
  193. package/dist/utils/encoding.d.ts +0 -37
  194. package/dist/utils/encoding.js +0 -120
  195. package/dist/utils/hash.d.ts +0 -1
  196. package/dist/utils/hash.js +0 -5
  197. package/dist/utils/retry.d.ts +0 -10
  198. package/dist/utils/retry.js +0 -35
  199. package/dist/utils/satoshi-validation.d.ts +0 -60
  200. package/dist/utils/satoshi-validation.js +0 -156
  201. package/dist/utils/serialization.d.ts +0 -14
  202. package/dist/utils/serialization.js +0 -76
  203. package/dist/utils/telemetry.d.ts +0 -17
  204. package/dist/utils/telemetry.js +0 -24
  205. package/dist/utils/validation.d.ts +0 -5
  206. package/dist/utils/validation.js +0 -98
  207. package/dist/vc/CredentialManager.d.ts +0 -22
  208. package/dist/vc/CredentialManager.js +0 -227
  209. package/dist/vc/Issuer.d.ts +0 -27
  210. package/dist/vc/Issuer.js +0 -70
  211. package/dist/vc/Verifier.d.ts +0 -16
  212. package/dist/vc/Verifier.js +0 -50
  213. package/dist/vc/cryptosuites/bbs.d.ts +0 -44
  214. package/dist/vc/cryptosuites/bbs.js +0 -213
  215. package/dist/vc/cryptosuites/bbsSimple.d.ts +0 -9
  216. package/dist/vc/cryptosuites/bbsSimple.js +0 -12
  217. package/dist/vc/cryptosuites/eddsa.d.ts +0 -30
  218. package/dist/vc/cryptosuites/eddsa.js +0 -81
  219. package/dist/vc/documentLoader.d.ts +0 -16
  220. package/dist/vc/documentLoader.js +0 -59
  221. package/dist/vc/proofs/data-integrity.d.ts +0 -21
  222. package/dist/vc/proofs/data-integrity.js +0 -15
  223. package/dist/vc/utils/jsonld.d.ts +0 -2
  224. package/dist/vc/utils/jsonld.js +0 -15
  225. package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +0 -1
  226. package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +0 -1
  227. package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +0 -1
  228. package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +0 -1
  229. package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +0 -1
  230. package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +0 -1
  231. package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +0 -1
  232. package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +0 -1
  233. package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +0 -1
  234. package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +0 -1
  235. package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +0 -1
  236. package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +0 -1
  237. package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +0 -1
  238. package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +0 -1
  239. package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +0 -1
  240. package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +0 -1
  241. package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +0 -1
  242. package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +0 -1
  243. package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +0 -1
  244. package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +0 -1
  245. package/tests/e2e/README.md +0 -97
  246. package/tests/e2e/example.spec.ts +0 -78
  247. package/tsconfig.tsbuildinfo +0 -1
@@ -1,6 +0,0 @@
1
- import { FeeOracleAdapter } from './types';
2
- export declare class FeeOracleMock implements FeeOracleAdapter {
3
- private feeRate;
4
- constructor(feeRate?: number);
5
- estimateFeeRate(targetBlocks?: number): Promise<number>;
6
- }
@@ -1,8 +0,0 @@
1
- export class FeeOracleMock {
2
- constructor(feeRate = 7) {
3
- this.feeRate = feeRate;
4
- }
5
- async estimateFeeRate(targetBlocks = 1) {
6
- return Math.max(1, this.feeRate - (targetBlocks - 1));
7
- }
8
- }
@@ -1,4 +0,0 @@
1
- export * from './types';
2
- export * from './FeeOracleMock';
3
- export * from './providers/OrdMockProvider';
4
- export * from './providers/OrdHttpProvider';
@@ -1,4 +0,0 @@
1
- export * from './types';
2
- export * from './FeeOracleMock';
3
- export * from './providers/OrdMockProvider';
4
- export * from './providers/OrdHttpProvider';
@@ -1,56 +0,0 @@
1
- import type { OrdinalsProvider } from '../types';
2
- interface HttpProviderOptions {
3
- baseUrl: string;
4
- }
5
- export declare class OrdHttpProvider implements OrdinalsProvider {
6
- private readonly baseUrl;
7
- constructor(options: HttpProviderOptions);
8
- getInscriptionById(id: string): Promise<{
9
- inscriptionId: any;
10
- content: any;
11
- contentType: any;
12
- txid: any;
13
- vout: any;
14
- satoshi: string;
15
- blockHeight: any;
16
- } | null>;
17
- getInscriptionsBySatoshi(satoshi: string): Promise<{
18
- inscriptionId: string;
19
- }[]>;
20
- broadcastTransaction(_txHexOrObj: unknown): Promise<string>;
21
- getTransactionStatus(_txid: string): Promise<{
22
- confirmed: boolean;
23
- }>;
24
- estimateFee(blocks?: number): Promise<number>;
25
- createInscription(params: {
26
- data: any;
27
- contentType: string;
28
- feeRate?: number;
29
- }): Promise<{
30
- inscriptionId: string;
31
- revealTxId: string;
32
- txid: string;
33
- vout: number;
34
- blockHeight: undefined;
35
- content: any;
36
- contentType: string;
37
- feeRate: number | undefined;
38
- }>;
39
- transferInscription(inscriptionId: string, _toAddress: string, _options?: {
40
- feeRate?: number;
41
- }): Promise<{
42
- txid: string;
43
- vin: {
44
- txid: string;
45
- vout: number;
46
- }[];
47
- vout: {
48
- value: number;
49
- scriptPubKey: string;
50
- }[];
51
- fee: number;
52
- confirmations: number;
53
- }>;
54
- }
55
- export declare function createOrdinalsProviderFromEnv(): Promise<OrdinalsProvider>;
56
- export {};
@@ -1,110 +0,0 @@
1
- function buildUrl(baseUrl, path) {
2
- const base = baseUrl.replace(/\/$/, '');
3
- return `${base}${path.startsWith('/') ? '' : '/'}${path}`;
4
- }
5
- async function fetchJson(url) {
6
- const res = await globalThis.fetch(url, {
7
- headers: {
8
- 'Accept': 'application/json'
9
- }
10
- });
11
- if (!res.ok)
12
- return null;
13
- return (await res.json());
14
- }
15
- export class OrdHttpProvider {
16
- constructor(options) {
17
- if (!options?.baseUrl) {
18
- throw new Error('OrdHttpProvider requires baseUrl');
19
- }
20
- this.baseUrl = options.baseUrl;
21
- }
22
- async getInscriptionById(id) {
23
- if (!id)
24
- return null;
25
- const data = await fetchJson(buildUrl(this.baseUrl, `/inscription/${id}`));
26
- if (!data)
27
- return null;
28
- // Expecting a shape similar to Ordinals indexers; adapt minimally
29
- const ownerOutput = data.owner_output;
30
- let txid = data.txid || 'unknown';
31
- let vout = typeof data.vout === 'number' ? data.vout : 0;
32
- if (ownerOutput && ownerOutput.includes(':')) {
33
- const [tid, v] = ownerOutput.split(':');
34
- txid = tid;
35
- vout = Number(v) || 0;
36
- }
37
- const contentType = data.content_type || 'application/octet-stream';
38
- const contentUrl = data.content_url || buildUrl(this.baseUrl, `/content/${id}`);
39
- const contentRes = await globalThis.fetch(contentUrl);
40
- if (!contentRes.ok)
41
- return null;
42
- const buf = globalThis.Buffer
43
- ? globalThis.Buffer.from(new Uint8Array(await contentRes.arrayBuffer()))
44
- : new Uint8Array(await contentRes.arrayBuffer());
45
- return {
46
- inscriptionId: data.inscription_id || id,
47
- content: buf,
48
- contentType,
49
- txid,
50
- vout,
51
- satoshi: String(data.sat ?? ''),
52
- blockHeight: data.block_height
53
- };
54
- }
55
- async getInscriptionsBySatoshi(satoshi) {
56
- if (!satoshi)
57
- return [];
58
- const data = await fetchJson(buildUrl(this.baseUrl, `/sat/${satoshi}`));
59
- const ids = Array.isArray(data?.inscription_ids) ? data.inscription_ids : [];
60
- return ids.map((inscriptionId) => ({ inscriptionId }));
61
- }
62
- async broadcastTransaction(_txHexOrObj) {
63
- // For example purposes only, return a placeholder
64
- return 'broadcast-txid';
65
- }
66
- async getTransactionStatus(_txid) {
67
- return { confirmed: false };
68
- }
69
- async estimateFee(blocks = 1) {
70
- // Basic fallback: some providers expose fee estimates; for example purposes, return linear estimate
71
- return 5 * Math.max(1, blocks);
72
- }
73
- async createInscription(params) {
74
- // Example placeholder: a real implementation would POST to a service
75
- // Here we return a deterministic mock-like result to avoid network coupling in code
76
- const inscriptionId = `insc-${Math.random().toString(36).slice(2)}`;
77
- const txid = `tx-${Math.random().toString(36).slice(2)}`;
78
- return {
79
- inscriptionId,
80
- revealTxId: txid,
81
- txid,
82
- vout: 0,
83
- blockHeight: undefined,
84
- content: params.data,
85
- contentType: params.contentType,
86
- feeRate: params.feeRate
87
- };
88
- }
89
- async transferInscription(inscriptionId, _toAddress, _options) {
90
- if (!inscriptionId)
91
- throw new Error('inscriptionId required');
92
- const txid = `tx-${Math.random().toString(36).slice(2)}`;
93
- return {
94
- txid,
95
- vin: [{ txid: 'prev', vout: 0 }],
96
- vout: [{ value: 546, scriptPubKey: 'script' }],
97
- fee: 100,
98
- confirmations: 0
99
- };
100
- }
101
- }
102
- export async function createOrdinalsProviderFromEnv() {
103
- const useLive = String((globalThis.process?.env?.USE_LIVE_ORD_PROVIDER) || '').toLowerCase() === 'true';
104
- if (useLive) {
105
- const baseUrl = (globalThis.process?.env?.ORD_PROVIDER_BASE_URL) || 'https://ord.example.com/api';
106
- return new OrdHttpProvider({ baseUrl });
107
- }
108
- const mod = await import('./OrdMockProvider');
109
- return new mod.OrdMockProvider();
110
- }
@@ -1,70 +0,0 @@
1
- import { OrdinalsProvider } from '../types';
2
- export interface OrdMockState {
3
- inscriptionsById: Map<string, {
4
- inscriptionId: string;
5
- content: Buffer;
6
- contentType: string;
7
- txid: string;
8
- vout: number;
9
- satoshi?: string;
10
- blockHeight?: number;
11
- }>;
12
- inscriptionsBySatoshi: Map<string, string[]>;
13
- feeRate: number;
14
- }
15
- export declare class OrdMockProvider implements OrdinalsProvider {
16
- private state;
17
- constructor(state?: Partial<OrdMockState>);
18
- getInscriptionById(id: string): Promise<{
19
- inscriptionId: string;
20
- content: Buffer;
21
- contentType: string;
22
- txid: string;
23
- vout: number;
24
- satoshi?: string;
25
- blockHeight?: number;
26
- } | null>;
27
- getInscriptionsBySatoshi(satoshi: string): Promise<{
28
- inscriptionId: string;
29
- }[]>;
30
- broadcastTransaction(_txHexOrObj: unknown): Promise<string>;
31
- getTransactionStatus(txid: string): Promise<{
32
- confirmed: boolean;
33
- blockHeight: number;
34
- confirmations: number;
35
- }>;
36
- estimateFee(blocks?: number): Promise<number>;
37
- createInscription(params: {
38
- data: Buffer;
39
- contentType: string;
40
- feeRate?: number;
41
- }): Promise<{
42
- inscriptionId: string;
43
- revealTxId: string;
44
- commitTxId: undefined;
45
- satoshi: string;
46
- txid: string;
47
- vout: number;
48
- blockHeight: number;
49
- content: Buffer<ArrayBufferLike>;
50
- contentType: string;
51
- feeRate: number | undefined;
52
- }>;
53
- transferInscription(inscriptionId: string, _toAddress: string, _options?: {
54
- feeRate?: number;
55
- }): Promise<{
56
- txid: string;
57
- vin: {
58
- txid: string;
59
- vout: number;
60
- }[];
61
- vout: {
62
- value: number;
63
- scriptPubKey: string;
64
- }[];
65
- fee: number;
66
- blockHeight: number;
67
- confirmations: number;
68
- satoshi: string | undefined;
69
- }>;
70
- }
@@ -1,75 +0,0 @@
1
- export class OrdMockProvider {
2
- constructor(state) {
3
- this.state = {
4
- inscriptionsById: new Map(),
5
- inscriptionsBySatoshi: new Map(),
6
- feeRate: 5,
7
- ...state
8
- };
9
- }
10
- async getInscriptionById(id) {
11
- const rec = this.state.inscriptionsById.get(id);
12
- return rec ? { ...rec } : null;
13
- }
14
- async getInscriptionsBySatoshi(satoshi) {
15
- const list = this.state.inscriptionsBySatoshi.get(satoshi) || [];
16
- return list.map((inscriptionId) => ({ inscriptionId }));
17
- }
18
- async broadcastTransaction(_txHexOrObj) {
19
- return 'mock-broadcast-txid';
20
- }
21
- async getTransactionStatus(txid) {
22
- return { confirmed: true, blockHeight: 1, confirmations: 1 };
23
- }
24
- async estimateFee(blocks = 1) {
25
- return Math.max(1, this.state.feeRate - (blocks - 1));
26
- }
27
- async createInscription(params) {
28
- const inscriptionId = `insc-${Math.random().toString(36).slice(2)}`;
29
- const txid = `tx-${Math.random().toString(36).slice(2)}`;
30
- // Generate a valid numeric satoshi identifier (not sat-123 format)
31
- const satoshi = `${Math.floor(Math.random() * 1e12)}`;
32
- const vout = 0;
33
- const record = {
34
- inscriptionId,
35
- content: params.data,
36
- contentType: params.contentType,
37
- txid,
38
- vout,
39
- satoshi,
40
- blockHeight: 1
41
- };
42
- this.state.inscriptionsById.set(inscriptionId, record);
43
- const list = this.state.inscriptionsBySatoshi.get(satoshi) || [];
44
- list.push(inscriptionId);
45
- this.state.inscriptionsBySatoshi.set(satoshi, list);
46
- return {
47
- inscriptionId,
48
- revealTxId: txid,
49
- commitTxId: undefined,
50
- satoshi,
51
- txid,
52
- vout,
53
- blockHeight: 1,
54
- content: params.data,
55
- contentType: params.contentType,
56
- feeRate: params.feeRate
57
- };
58
- }
59
- async transferInscription(inscriptionId, _toAddress, _options) {
60
- const rec = this.state.inscriptionsById.get(inscriptionId);
61
- if (!rec) {
62
- return Promise.reject(new Error('inscription not found'));
63
- }
64
- const txid = `tx-${Math.random().toString(36).slice(2)}`;
65
- return {
66
- txid,
67
- vin: [{ txid: rec.txid, vout: rec.vout }],
68
- vout: [{ value: 546, scriptPubKey: 'script' }],
69
- fee: 100,
70
- blockHeight: 1,
71
- confirmations: 0,
72
- satoshi: rec.satoshi
73
- };
74
- }
75
- }
@@ -1,71 +0,0 @@
1
- export interface StoragePutOptions {
2
- contentType?: string;
3
- cacheControl?: string;
4
- }
5
- export interface StorageGetResult {
6
- content: Buffer;
7
- contentType: string;
8
- }
9
- export interface StorageAdapter {
10
- put(objectKey: string, data: Buffer | string, options?: StoragePutOptions): Promise<string>;
11
- get(objectKey: string): Promise<StorageGetResult | null>;
12
- delete?(objectKey: string): Promise<boolean>;
13
- }
14
- export interface FeeOracleAdapter {
15
- estimateFeeRate(targetBlocks?: number): Promise<number>;
16
- }
17
- export interface OrdinalsProvider {
18
- getInscriptionById(id: string): Promise<{
19
- inscriptionId: string;
20
- content: Buffer;
21
- contentType: string;
22
- txid: string;
23
- vout: number;
24
- satoshi?: string;
25
- blockHeight?: number;
26
- } | null>;
27
- getInscriptionsBySatoshi(satoshi: string): Promise<Array<{
28
- inscriptionId: string;
29
- }>>;
30
- broadcastTransaction(txHexOrObj: unknown): Promise<string>;
31
- getTransactionStatus(txid: string): Promise<{
32
- confirmed: boolean;
33
- blockHeight?: number;
34
- confirmations?: number;
35
- }>;
36
- estimateFee(blocks?: number): Promise<number>;
37
- createInscription(params: {
38
- data: Buffer;
39
- contentType: string;
40
- feeRate?: number;
41
- }): Promise<{
42
- inscriptionId: string;
43
- revealTxId: string;
44
- commitTxId?: string;
45
- satoshi?: string;
46
- txid?: string;
47
- vout?: number;
48
- blockHeight?: number;
49
- content?: Buffer;
50
- contentType?: string;
51
- feeRate?: number;
52
- }>;
53
- transferInscription(inscriptionId: string, toAddress: string, options?: {
54
- feeRate?: number;
55
- }): Promise<{
56
- txid: string;
57
- vin: Array<{
58
- txid: string;
59
- vout: number;
60
- }>;
61
- vout: Array<{
62
- value: number;
63
- scriptPubKey: string;
64
- address?: string;
65
- }>;
66
- fee: number;
67
- blockHeight?: number;
68
- confirmations?: number;
69
- satoshi?: string;
70
- }>;
71
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,15 +0,0 @@
1
- import { OriginalsConfig, OrdinalsInscription, BitcoinTransaction } from '../types';
2
- export declare class BitcoinManager {
3
- private config;
4
- private readonly feeOracle?;
5
- private readonly ord?;
6
- constructor(config: OriginalsConfig);
7
- private resolveFeeRate;
8
- inscribeData(data: any, contentType: string, feeRate?: number): Promise<OrdinalsInscription>;
9
- trackInscription(inscriptionId: string): Promise<OrdinalsInscription | null>;
10
- transferInscription(inscription: OrdinalsInscription, toAddress: string): Promise<BitcoinTransaction>;
11
- preventFrontRunning(satoshi: string): Promise<boolean>;
12
- getSatoshiFromInscription(inscriptionId: string): Promise<string | null>;
13
- validateBTCODID(didId: string): Promise<boolean>;
14
- private extractSatoshiFromBTCODID;
15
- }