@zama-fhe/sdk 3.0.0-alpha.2 → 3.0.0-alpha.21

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 (99) hide show
  1. package/README.md +207 -122
  2. package/dist/cjs/build.cjs +2 -0
  3. package/dist/cjs/build.cjs.map +1 -0
  4. package/dist/cjs/chains/index.cjs +1 -0
  5. package/dist/cjs/chains.cjs +2 -0
  6. package/dist/cjs/chains.cjs.map +1 -0
  7. package/dist/cjs/cleartext/index.cjs +1 -1
  8. package/dist/cjs/eip1193-subscribe.cjs +1 -1
  9. package/dist/cjs/eip1193-subscribe.cjs.map +1 -1
  10. package/dist/cjs/encryption.cjs +2 -0
  11. package/dist/cjs/encryption.cjs.map +1 -0
  12. package/dist/cjs/ethers/index.cjs +1 -1
  13. package/dist/cjs/ethers/index.cjs.map +1 -1
  14. package/dist/cjs/index.cjs +73 -73
  15. package/dist/cjs/index.cjs.map +1 -1
  16. package/dist/cjs/query/index.cjs +1 -1
  17. package/dist/cjs/query/index.cjs.map +1 -1
  18. package/dist/cjs/readonly-token.cjs +1 -1
  19. package/dist/cjs/readonly-token.cjs.map +1 -1
  20. package/dist/cjs/relayer-cleartext.cjs +2 -0
  21. package/dist/cjs/relayer-cleartext.cjs.map +1 -0
  22. package/dist/cjs/relayer-sdk.worker.js +71 -71
  23. package/dist/cjs/relayer.cjs +1 -1
  24. package/dist/cjs/relayer.cjs.map +1 -1
  25. package/dist/cjs/viem/index.cjs +1 -1
  26. package/dist/cjs/viem/index.cjs.map +1 -1
  27. package/dist/cjs/wrappers-registry.cjs +1 -1
  28. package/dist/cjs/wrappers-registry.cjs.map +1 -1
  29. package/dist/esm/{assertions-BARApuMj.js → assertions-CfqI3AJv.js} +1 -1
  30. package/dist/esm/{assertions-BARApuMj.js.map → assertions-CfqI3AJv.js.map} +1 -1
  31. package/dist/esm/build-CvenCk6R.js +2 -0
  32. package/dist/esm/build-CvenCk6R.js.map +1 -0
  33. package/dist/esm/chains/index.d.ts +3 -0
  34. package/dist/esm/chains/index.js +1 -0
  35. package/dist/esm/chains-aHmrozPh.js +2 -0
  36. package/dist/esm/chains-aHmrozPh.js.map +1 -0
  37. package/dist/esm/cleartext/index.d.ts +2 -86
  38. package/dist/esm/cleartext/index.js +1 -1
  39. package/dist/esm/cleartext-BHu6-LCv.d.ts +19 -0
  40. package/dist/esm/cleartext-I-etE_7S.js +2 -0
  41. package/dist/esm/cleartext-I-etE_7S.js.map +1 -0
  42. package/dist/esm/eip1193-subscribe-CcotSOIm.js +2 -0
  43. package/dist/esm/eip1193-subscribe-CcotSOIm.js.map +1 -0
  44. package/dist/esm/{encryption-CmIPBcfP.js → encryption-YS-Kb7qm.js} +2 -2
  45. package/dist/esm/{encryption-CmIPBcfP.js.map → encryption-YS-Kb7qm.js.map} +1 -1
  46. package/dist/esm/ethers/index.d.ts +53 -8
  47. package/dist/esm/ethers/index.js +1 -1
  48. package/dist/esm/ethers/index.js.map +1 -1
  49. package/dist/esm/{hex-D_B-zoId.js → hex-BZVTzEK6.js} +2 -2
  50. package/dist/esm/{hex-D_B-zoId.js.map → hex-BZVTzEK6.js.map} +1 -1
  51. package/dist/esm/{relayer-utils-iSPis4x-.d.ts → index-BTY0MxOt.d.ts} +50 -23
  52. package/dist/esm/{onchain-events-2VNiL78c.d.ts → index-BdyljG1F.d.ts} +387 -1505
  53. package/dist/esm/index.d.ts +61 -93
  54. package/dist/esm/index.js +73 -73
  55. package/dist/esm/index.js.map +1 -1
  56. package/dist/esm/memory-storage-CFXqXUcm.js +2 -0
  57. package/dist/esm/memory-storage-CFXqXUcm.js.map +1 -0
  58. package/dist/esm/node/index.d.ts +88 -110
  59. package/dist/esm/node/index.js +1 -1
  60. package/dist/esm/node/index.js.map +1 -1
  61. package/dist/esm/node/relayer-sdk.node-worker.js +1 -1
  62. package/dist/esm/node/relayer-sdk.node-worker.js.map +1 -1
  63. package/dist/esm/query/index.d.ts +40 -50
  64. package/dist/esm/query/index.js +1 -1
  65. package/dist/esm/query/index.js.map +1 -1
  66. package/dist/esm/readonly-token-DCLOYhws.js +2 -0
  67. package/dist/esm/readonly-token-DCLOYhws.js.map +1 -0
  68. package/dist/esm/{relayer-C6u3eOlN.js → relayer-7Hd00A6X.js} +2 -2
  69. package/dist/esm/relayer-7Hd00A6X.js.map +1 -0
  70. package/dist/esm/{relayer-sdk.types-CGfXwKcB.d.ts → relayer-cleartext-DJkSUlZ2.d.ts} +263 -106
  71. package/dist/esm/relayer-cleartext-SZCM9wTx.js +2 -0
  72. package/dist/esm/relayer-cleartext-SZCM9wTx.js.map +1 -0
  73. package/dist/esm/relayer-sdk.worker.js +71 -71
  74. package/dist/esm/types-C1S426x4.d.ts +48 -0
  75. package/dist/esm/types-CVyJHEya.d.ts +14 -0
  76. package/dist/esm/types-DePjTTbo.d.ts +30 -0
  77. package/dist/esm/types-FY7ciI37.d.ts +615 -0
  78. package/dist/esm/viem/index.d.ts +39 -11
  79. package/dist/esm/viem/index.js +1 -1
  80. package/dist/esm/viem/index.js.map +1 -1
  81. package/dist/esm/wrappers-registry-CXNs4eR0.js +2 -0
  82. package/dist/esm/wrappers-registry-CXNs4eR0.js.map +1 -0
  83. package/package.json +17 -3
  84. package/dist/cjs/cleartext.cjs +0 -2
  85. package/dist/cjs/cleartext.cjs.map +0 -1
  86. package/dist/esm/cleartext-Cs28cTsa.js +0 -2
  87. package/dist/esm/cleartext-Cs28cTsa.js.map +0 -1
  88. package/dist/esm/eip1193-subscribe-Cl_wlVuQ.js +0 -2
  89. package/dist/esm/eip1193-subscribe-Cl_wlVuQ.js.map +0 -1
  90. package/dist/esm/memory-storage-F8xjMzVy.js +0 -2
  91. package/dist/esm/memory-storage-F8xjMzVy.js.map +0 -1
  92. package/dist/esm/readonly-token-D4GjTj0q.js +0 -2
  93. package/dist/esm/readonly-token-D4GjTj0q.js.map +0 -1
  94. package/dist/esm/relayer-C6u3eOlN.js.map +0 -1
  95. package/dist/esm/relayer-sdk-DPqytEbO.d.ts +0 -44
  96. package/dist/esm/relayer-utils-BeoTNDM4.js +0 -2
  97. package/dist/esm/relayer-utils-BeoTNDM4.js.map +0 -1
  98. package/dist/esm/wrappers-registry-ydyySM9g.js +0 -2
  99. package/dist/esm/wrappers-registry-ydyySM9g.js.map +0 -1
@@ -1,8 +1,5 @@
1
1
  (function() {
2
2
  //#region src/utils/assertions.ts
3
- function assertNonNullable(value, context) {
4
- if (value === null || value === void 0) throw new TypeError(`${context} must not be null or undefined`);
5
- }
6
3
  function assertObject(value, context) {
7
4
  if (typeof value !== "object" || value === null || Array.isArray(value)) throw new TypeError(`${context} must be an object, got ${typeof value}`);
8
5
  }
@@ -63,19 +60,46 @@
63
60
  }
64
61
  //#endregion
65
62
  //#region src/worker/relayer-sdk.worker.ts
66
- let sdkInstance = null;
63
+ const instances = /* @__PURE__ */ new Map();
64
+ const pending = /* @__PURE__ */ new Map();
65
+ const configs = /* @__PURE__ */ new Map();
66
+ /** Convert an FheChain to the FhevmInstanceConfig shape expected by createInstance. */
67
+ function toInstanceConfig(chain) {
68
+ return {
69
+ ...chain,
70
+ chainId: chain.id
71
+ };
72
+ }
67
73
  let sdkGlobal = null;
68
- function assertSdkInstance(instance) {
69
- try {
70
- assertNonNullable(instance, "Relayer SDK instance");
71
- } catch (error) {
72
- throw new Error("Relayer SDK is not initialized. Call INIT first.", { cause: error });
73
- }
74
+ /**
75
+ * Get or lazily create an FhevmInstance for the given chain.
76
+ */
77
+ async function getInstance(chainId) {
78
+ const existing = instances.get(chainId);
79
+ if (existing) return existing;
80
+ const inflight = pending.get(chainId);
81
+ if (inflight) return inflight;
82
+ const config = configs.get(chainId);
83
+ if (!config) throw new Error(`No config for chain ${chainId}. Available: [${[...configs.keys()].join(", ")}]`);
84
+ if (!sdkGlobal) throw new Error("Relayer SDK is not initialized. Call INIT first.");
85
+ const promise = sdkGlobal.createInstance({
86
+ ...toInstanceConfig(config),
87
+ batchRpcCalls: false
88
+ }).then((instance) => {
89
+ instances.set(chainId, instance);
90
+ pending.delete(chainId);
91
+ return instance;
92
+ }).catch((err) => {
93
+ pending.delete(chainId);
94
+ throw err;
95
+ });
96
+ pending.set(chainId, promise);
97
+ return promise;
74
98
  }
75
99
  function unreachableFheType(_) {
76
100
  throw new Error("Unsupported FHE type");
77
101
  }
78
- let relayerUrlBase = "";
102
+ const relayerUrls = /* @__PURE__ */ new Set();
79
103
  let csrfTokenBase = "";
80
104
  const CSRF_HEADER_NAME = "x-csrf-token";
81
105
  const MUTATING_METHODS = new Set([
@@ -85,6 +109,12 @@
85
109
  "PATCH"
86
110
  ]);
87
111
  /**
112
+ * Register relayer URLs from chain configs for fetch interception.
113
+ */
114
+ function registerRelayerUrls(chainConfigs) {
115
+ for (const c of chainConfigs) if (c.relayerUrl) relayerUrls.add(c.relayerUrl);
116
+ }
117
+ /**
88
118
  * Send a success response back to the main thread.
89
119
  * Optionally transfers ArrayBuffers for zero-copy performance.
90
120
  */
@@ -138,7 +168,7 @@
138
168
  globalThis.fetch = async (input, init) => {
139
169
  const url = typeof input === "string" ? input : input instanceof URL ? input.href : input.url;
140
170
  const method = init?.method?.toUpperCase() ?? "GET";
141
- if (relayerUrlBase && url.startsWith(relayerUrlBase)) {
171
+ if (relayerUrls.size > 0 && [...relayerUrls].some((base) => url.startsWith(base))) {
142
172
  const headers = new Headers(init?.headers);
143
173
  if (MUTATING_METHODS.has(method) && csrfTokenBase) headers.set(CSRF_HEADER_NAME, csrfTokenBase);
144
174
  return originalFetch(input, {
@@ -193,24 +223,21 @@
193
223
  }
194
224
  }
195
225
  /**
196
- * Handle INIT request - load SDK and initialize WASM.
226
+ * Handle INIT request - load SDK WASM and register chain configs (instances are lazy).
197
227
  */
198
228
  async function handleInit(request) {
199
229
  const { id, type, payload } = request;
200
- const { cdnUrl, fhevmConfig, csrfToken, integrity, thread } = payload;
201
230
  try {
202
- relayerUrlBase = fhevmConfig.relayerUrl ?? "";
231
+ if (payload.env !== "web") throw new Error(`Web worker received unexpected env: ${payload.env}`);
232
+ const { cdnUrl, csrfToken, integrity, thread } = payload;
203
233
  csrfTokenBase = csrfToken;
204
234
  setupFetchInterceptor();
205
235
  await loadSdkScript(cdnUrl, integrity);
206
236
  if (!self.relayerSDK) throw new Error("Failed to load relayerSDK from CDN");
207
237
  sdkGlobal = self.relayerSDK;
208
238
  await sdkGlobal.initSDK(thread !== null && thread !== void 0 ? { thread } : void 0);
209
- const config = {
210
- ...fhevmConfig,
211
- batchRpcCalls: false
212
- };
213
- sdkInstance = await sdkGlobal.createInstance(config);
239
+ registerRelayerUrls(payload.chains);
240
+ for (const chain of payload.chains) configs.set(chain.id, chain);
214
241
  sendSuccess(id, type, { initialized: true });
215
242
  } catch (error) {
216
243
  const message = error instanceof Error ? error.message : String(error);
@@ -262,8 +289,7 @@
262
289
  const { id, type, payload } = request;
263
290
  const { values, contractAddress, userAddress } = payload;
264
291
  try {
265
- assertSdkInstance(sdkInstance);
266
- const input = sdkInstance.createEncryptedInput(contractAddress, userAddress);
292
+ const input = (await getInstance(payload.chainId)).createEncryptedInput(contractAddress, userAddress);
267
293
  for (const entry of values) addTypedValue(input, entry);
268
294
  const encrypted = await input.encrypt();
269
295
  sendSuccess(id, type, {
@@ -282,12 +308,12 @@
282
308
  async function handleUserDecrypt(request) {
283
309
  const { id, type, payload } = request;
284
310
  try {
285
- assertSdkInstance(sdkInstance);
311
+ const instance = await getInstance(payload.chainId);
286
312
  const handleContractPairs = payload.handles.map((handle) => ({
287
313
  handle,
288
314
  contractAddress: payload.contractAddress
289
315
  }));
290
- sendSuccess(id, type, { clearValues: await sdkInstance.userDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.signerAddress, payload.startTimestamp, payload.durationDays) });
316
+ sendSuccess(id, type, { clearValues: await instance.userDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.signerAddress, payload.startTimestamp, payload.durationDays) });
291
317
  } catch (error) {
292
318
  const message = error instanceof Error ? error.message : String(error);
293
319
  const statusCode = extractHttpStatus(error);
@@ -316,8 +342,7 @@
316
342
  async function handlePublicDecrypt(request) {
317
343
  const { id, type, payload } = request;
318
344
  try {
319
- assertSdkInstance(sdkInstance);
320
- sendSuccess(id, type, { ...await sdkInstance.publicDecrypt(payload.handles) });
345
+ sendSuccess(id, type, { ...await (await getInstance(payload.chainId)).publicDecrypt(payload.handles) });
321
346
  } catch (error) {
322
347
  const message = error instanceof Error ? error.message : String(error);
323
348
  console.error("[Worker] PublicDecrypt error:", message);
@@ -327,11 +352,10 @@
327
352
  /**
328
353
  * Handle GENERATE_KEYPAIR request.
329
354
  */
330
- function handleGenerateKeypair(request) {
331
- const { id, type } = request;
355
+ async function handleGenerateKeypair(request) {
356
+ const { id, type, payload } = request;
332
357
  try {
333
- assertSdkInstance(sdkInstance);
334
- const keypair = sdkInstance.generateKeypair();
358
+ const keypair = (await getInstance(payload.chainId)).generateKeypair();
335
359
  sendSuccess(id, type, {
336
360
  publicKey: prefixHex(keypair.publicKey),
337
361
  privateKey: prefixHex(keypair.privateKey)
@@ -345,30 +369,10 @@
345
369
  /**
346
370
  * Handle CREATE_EIP712 request.
347
371
  */
348
- function handleCreateEIP712(request) {
372
+ async function handleCreateEIP712(request) {
349
373
  const { id, type, payload } = request;
350
374
  try {
351
- assertSdkInstance(sdkInstance);
352
- const eip712 = sdkInstance.createEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.startTimestamp, payload.durationDays);
353
- sendSuccess(id, type, {
354
- domain: {
355
- name: eip712.domain.name,
356
- version: eip712.domain.version,
357
- chainId: Number(eip712.domain.chainId),
358
- verifyingContract: eip712.domain.verifyingContract
359
- },
360
- types: { UserDecryptRequestVerification: eip712.types.UserDecryptRequestVerification.map((field) => ({
361
- name: field.name,
362
- type: field.type
363
- })) },
364
- message: {
365
- publicKey: prefixHex(eip712.message.publicKey),
366
- contractAddresses: [...eip712.message.contractAddresses],
367
- startTimestamp: BigInt(eip712.message.startTimestamp),
368
- durationDays: BigInt(eip712.message.durationDays),
369
- extraData: prefixHex(eip712.message.extraData)
370
- }
371
- });
375
+ sendSuccess(id, type, (await getInstance(payload.chainId)).createEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.startTimestamp, payload.durationDays));
372
376
  } catch (error) {
373
377
  const message = error instanceof Error ? error.message : String(error);
374
378
  console.error("[Worker] CreateEIP712 error:", message);
@@ -378,11 +382,10 @@
378
382
  /**
379
383
  * Handle CREATE_DELEGATED_EIP712 request.
380
384
  */
381
- function handleCreateDelegatedEIP712(request) {
385
+ async function handleCreateDelegatedEIP712(request) {
382
386
  const { id, type, payload } = request;
383
387
  try {
384
- assertSdkInstance(sdkInstance);
385
- sendSuccess(id, type, sdkInstance.createDelegatedUserDecryptEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.delegatorAddress, payload.startTimestamp, payload.durationDays));
388
+ sendSuccess(id, type, (await getInstance(payload.chainId)).createDelegatedUserDecryptEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.delegatorAddress, payload.startTimestamp, payload.durationDays));
386
389
  } catch (error) {
387
390
  const message = error instanceof Error ? error.message : String(error);
388
391
  console.error("[Worker] CreateDelegatedEIP712 error:", message);
@@ -395,12 +398,12 @@
395
398
  async function handleDelegatedUserDecrypt(request) {
396
399
  const { id, type, payload } = request;
397
400
  try {
398
- assertSdkInstance(sdkInstance);
401
+ const instance = await getInstance(payload.chainId);
399
402
  const handleContractPairs = payload.handles.map((handle) => ({
400
403
  handle,
401
404
  contractAddress: payload.contractAddress
402
405
  }));
403
- sendSuccess(id, type, { clearValues: await sdkInstance.delegatedUserDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.delegatorAddress, payload.delegateAddress, payload.startTimestamp, payload.durationDays) });
406
+ sendSuccess(id, type, { clearValues: await instance.delegatedUserDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.delegatorAddress, payload.delegateAddress, payload.startTimestamp, payload.durationDays) });
404
407
  } catch (error) {
405
408
  const message = error instanceof Error ? error.message : String(error);
406
409
  const statusCode = extractHttpStatus(error);
@@ -414,8 +417,7 @@
414
417
  async function handleRequestZKProofVerification(request) {
415
418
  const { id, type, payload } = request;
416
419
  try {
417
- assertSdkInstance(sdkInstance);
418
- const result = await sdkInstance.requestZKProofVerification(payload.zkProof);
420
+ const result = await (await getInstance(payload.chainId)).requestZKProofVerification(payload.zkProof);
419
421
  sendSuccess(id, type, result, [result.inputProof.buffer, ...result.handles.map((h) => h.buffer)]);
420
422
  } catch (error) {
421
423
  const message = error instanceof Error ? error.message : String(error);
@@ -426,11 +428,10 @@
426
428
  /**
427
429
  * Handle GET_PUBLIC_KEY request.
428
430
  */
429
- function handleGetPublicKey(request) {
430
- const { id, type } = request;
431
+ async function handleGetPublicKey(request) {
432
+ const { id, type, payload } = request;
431
433
  try {
432
- assertSdkInstance(sdkInstance);
433
- sendSuccess(id, type, { result: sdkInstance.getPublicKey() });
434
+ sendSuccess(id, type, { result: (await getInstance(payload.chainId)).getPublicKey() });
434
435
  } catch (error) {
435
436
  const message = error instanceof Error ? error.message : String(error);
436
437
  console.error("[Worker] GetPublicKey error:", message);
@@ -440,11 +441,10 @@
440
441
  /**
441
442
  * Handle GET_PUBLIC_PARAMS request.
442
443
  */
443
- function handleGetPublicParams(request) {
444
+ async function handleGetPublicParams(request) {
444
445
  const { id, type, payload } = request;
445
446
  try {
446
- assertSdkInstance(sdkInstance);
447
- sendSuccess(id, type, { result: sdkInstance.getPublicParams(payload.bits) });
447
+ sendSuccess(id, type, { result: (await getInstance(payload.chainId)).getPublicParams(payload.bits) });
448
448
  } catch (error) {
449
449
  const message = error instanceof Error ? error.message : String(error);
450
450
  console.error("[Worker] GetPublicParams error:", message);
@@ -482,13 +482,13 @@
482
482
  await handlePublicDecrypt(request);
483
483
  break;
484
484
  case "GENERATE_KEYPAIR":
485
- handleGenerateKeypair(request);
485
+ await handleGenerateKeypair(request);
486
486
  break;
487
487
  case "CREATE_EIP712":
488
- handleCreateEIP712(request);
488
+ await handleCreateEIP712(request);
489
489
  break;
490
490
  case "CREATE_DELEGATED_EIP712":
491
- handleCreateDelegatedEIP712(request);
491
+ await handleCreateDelegatedEIP712(request);
492
492
  break;
493
493
  case "DELEGATED_USER_DECRYPT":
494
494
  await handleDelegatedUserDecrypt(request);
@@ -497,10 +497,10 @@
497
497
  await handleRequestZKProofVerification(request);
498
498
  break;
499
499
  case "GET_PUBLIC_KEY":
500
- handleGetPublicKey(request);
500
+ await handleGetPublicKey(request);
501
501
  break;
502
502
  case "GET_PUBLIC_PARAMS":
503
- handleGetPublicParams(request);
503
+ await handleGetPublicParams(request);
504
504
  break;
505
505
  default: console.error("[Worker] Unknown request type:", request.type);
506
506
  }
@@ -0,0 +1,48 @@
1
+ import { Address, EIP1193Provider, Hex } from "viem";
2
+ import { Auth } from "@zama-fhe/relayer-sdk/bundle";
3
+
4
+ //#region src/chains/types.d.ts
5
+ /**
6
+ * Complete chain configuration — the single source of truth for
7
+ * per-chain FHE contract addresses and network settings.
8
+ *
9
+ * All built-in presets (`mainnet`, `sepolia`, `hardhat`, `hoodi`)
10
+ * are `FheChain` objects exported from `@zama-fhe/sdk/chains`.
11
+ */
12
+ interface FheChain<TId extends number = number> {
13
+ readonly id: TId;
14
+ readonly gatewayChainId: number;
15
+ readonly relayerUrl: string;
16
+ readonly network: EIP1193Provider | string;
17
+ readonly aclContractAddress: Address;
18
+ readonly kmsContractAddress: Address;
19
+ readonly inputVerifierContractAddress: Address;
20
+ readonly verifyingContractAddressDecryption: Address;
21
+ readonly verifyingContractAddressInputVerification: Address;
22
+ /**
23
+ * Address of the `ConfidentialTokenWrappersRegistry` contract.
24
+ * `undefined` for chains where no registry is deployed (e.g. Hardhat).
25
+ */
26
+ readonly registryAddress: Address | undefined;
27
+ /**
28
+ * Address of the `TFHEExecutor` contract (cleartext mode only).
29
+ * Required by the `cleartext()` transport to read mock plaintexts.
30
+ * `undefined` for chains that use real FHE infrastructure.
31
+ */
32
+ readonly executorAddress?: Address | undefined;
33
+ /**
34
+ * Authentication for the relayer endpoint.
35
+ * Use `{ __type: "ApiKeyHeader", value: "your-key" }` for API-key auth,
36
+ * or `{ __type: "BearerToken", value: "your-token" }` for bearer auth.
37
+ */
38
+ readonly auth?: Auth;
39
+ /** Private key of the KMS signer used for EIP-712 verification of the decryption (cleartext mode). */
40
+ readonly kmsSignerPrivateKey?: Hex;
41
+ /** Private key of the input signer used for EIP-712 verification of the input verification (cleartext mode). */
42
+ readonly inputSignerPrivateKey?: Hex;
43
+ }
44
+ /** At least one chain is required. */
45
+ type AtLeastOneChain = readonly [FheChain, ...FheChain[]];
46
+ //#endregion
47
+ export { FheChain as n, AtLeastOneChain as t };
48
+ //# sourceMappingURL=types-C1S426x4.d.ts.map
@@ -0,0 +1,14 @@
1
+ import { t as AtLeastOneChain } from "./types-C1S426x4.js";
2
+ import { o as ZamaConfigBase } from "./types-FY7ciI37.js";
3
+ import { EIP1193Provider, PublicClient, WalletClient } from "viem";
4
+
5
+ //#region src/viem/types.d.ts
6
+ /** Viem config — pass native viem clients directly. */
7
+ interface ZamaConfigViem<TChains extends AtLeastOneChain = AtLeastOneChain> extends ZamaConfigBase<TChains> {
8
+ publicClient: PublicClient;
9
+ walletClient: WalletClient;
10
+ ethereum?: EIP1193Provider;
11
+ }
12
+ //#endregion
13
+ export { ZamaConfigViem as t };
14
+ //# sourceMappingURL=types-CVyJHEya.d.ts.map
@@ -0,0 +1,30 @@
1
+ import { t as AtLeastOneChain } from "./types-C1S426x4.js";
2
+ import { o as ZamaConfigBase } from "./types-FY7ciI37.js";
3
+ import { EIP1193Provider } from "viem";
4
+ import { Provider, Signer } from "ethers";
5
+
6
+ //#region src/ethers/types.d.ts
7
+ /**
8
+ * Ethers config — pass an EIP-1193 provider, ethers Signer, or ethers Provider.
9
+ *
10
+ * The three variants are mutually exclusive, matching {@link EthersSignerConfig}:
11
+ * - `{ ethereum }` — browser EIP-1193 provider
12
+ * - `{ signer }` — ethers Signer (e.g. Wallet)
13
+ * - `{ provider }` — ethers Provider (read-only)
14
+ */
15
+ type ZamaConfigEthers<TChains extends AtLeastOneChain = AtLeastOneChain> = ZamaConfigBase<TChains> & ({
16
+ ethereum: EIP1193Provider;
17
+ signer?: never;
18
+ provider?: never;
19
+ } | {
20
+ signer: Signer;
21
+ ethereum?: never;
22
+ provider?: never;
23
+ } | {
24
+ ethereum: EIP1193Provider;
25
+ provider: Provider;
26
+ signer?: never;
27
+ });
28
+ //#endregion
29
+ export { ZamaConfigEthers as t };
30
+ //# sourceMappingURL=types-DePjTTbo.d.ts.map