@aztec/simulator 0.87.4 → 0.87.6

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 (122) hide show
  1. package/dest/client.d.ts +5 -5
  2. package/dest/client.d.ts.map +1 -1
  3. package/dest/client.js +4 -4
  4. package/dest/private/acvm/acvm.d.ts +1 -2
  5. package/dest/private/acvm/acvm.d.ts.map +1 -1
  6. package/dest/private/acvm/index.d.ts +0 -1
  7. package/dest/private/acvm/index.d.ts.map +1 -1
  8. package/dest/private/acvm/index.js +0 -1
  9. package/dest/private/{providers/acvm_native.d.ts → acvm_native.d.ts} +4 -4
  10. package/dest/private/acvm_native.d.ts.map +1 -0
  11. package/dest/private/{providers/acvm_wasm.d.ts → acvm_wasm.d.ts} +4 -4
  12. package/dest/private/acvm_wasm.d.ts.map +1 -0
  13. package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +2 -2
  14. package/dest/private/{providers/acvm_wasm_with_blobs.d.ts → acvm_wasm_with_blobs.d.ts} +5 -5
  15. package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
  16. package/dest/private/{providers/acvm_wasm_with_blobs.js → acvm_wasm_with_blobs.js} +2 -2
  17. package/dest/private/{providers/circuit_recording → circuit_recording}/circuit_recorder.d.ts +2 -2
  18. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
  19. package/dest/private/{providers/circuit_recording → circuit_recording}/circuit_recorder.js +2 -3
  20. package/dest/private/{providers/circuit_recording → circuit_recording}/file_circuit_recorder.d.ts +1 -1
  21. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
  22. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
  23. package/dest/private/{providers/circuit_recording/simulation_provider_recorder_wrapper.d.ts → circuit_recording/simulator_recorder_wrapper.d.ts} +7 -7
  24. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
  25. package/dest/private/{providers/circuit_recording/simulation_provider_recorder_wrapper.js → circuit_recording/simulator_recorder_wrapper.js} +2 -2
  26. package/dest/private/{providers/simulation_provider.d.ts → circuit_simulator.d.ts} +4 -4
  27. package/dest/private/circuit_simulator.d.ts.map +1 -0
  28. package/dest/private/{providers/simulation_provider.js → circuit_simulator.js} +1 -1
  29. package/dest/private/factory.d.ts +12 -0
  30. package/dest/private/factory.d.ts.map +1 -0
  31. package/dest/private/{providers/factory.js → factory.js} +2 -2
  32. package/dest/server.d.ts +6 -5
  33. package/dest/server.d.ts.map +1 -1
  34. package/dest/server.js +5 -4
  35. package/dest/testing.d.ts +1 -1
  36. package/dest/testing.d.ts.map +1 -1
  37. package/dest/testing.js +1 -1
  38. package/package.json +15 -15
  39. package/src/client.ts +5 -5
  40. package/src/private/acvm/acvm.ts +2 -3
  41. package/src/private/acvm/index.ts +0 -1
  42. package/src/private/{providers/acvm_native.ts → acvm_native.ts} +4 -4
  43. package/src/private/{providers/acvm_wasm.ts → acvm_wasm.ts} +4 -4
  44. package/src/private/{providers/acvm_wasm_with_blobs.ts → acvm_wasm_with_blobs.ts} +5 -5
  45. package/src/private/{providers/circuit_recording → circuit_recording}/circuit_recorder.ts +4 -5
  46. package/src/private/{providers/circuit_recording → circuit_recording}/file_circuit_recorder.ts +1 -1
  47. package/src/private/{providers/circuit_recording/simulation_provider_recorder_wrapper.ts → circuit_recording/simulator_recorder_wrapper.ts} +6 -6
  48. package/src/private/{providers/simulation_provider.ts → circuit_simulator.ts} +3 -3
  49. package/src/private/{providers/factory.ts → factory.ts} +6 -6
  50. package/src/server.ts +6 -5
  51. package/src/testing.ts +1 -1
  52. package/dest/private/acvm/oracle/index.d.ts +0 -14
  53. package/dest/private/acvm/oracle/index.d.ts.map +0 -1
  54. package/dest/private/acvm/oracle/index.js +0 -2
  55. package/dest/private/acvm/oracle/oracle.d.ts +0 -52
  56. package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
  57. package/dest/private/acvm/oracle/oracle.js +0 -312
  58. package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
  59. package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
  60. package/dest/private/acvm/oracle/typed_oracle.js +0 -138
  61. package/dest/private/execution_data_provider.d.ts +0 -301
  62. package/dest/private/execution_data_provider.d.ts.map +0 -1
  63. package/dest/private/execution_data_provider.js +0 -14
  64. package/dest/private/execution_note_cache.d.ts +0 -93
  65. package/dest/private/execution_note_cache.d.ts.map +0 -1
  66. package/dest/private/execution_note_cache.js +0 -180
  67. package/dest/private/hashed_values_cache.d.ts +0 -28
  68. package/dest/private/hashed_values_cache.d.ts.map +0 -1
  69. package/dest/private/hashed_values_cache.js +0 -36
  70. package/dest/private/index.d.ts +0 -16
  71. package/dest/private/index.d.ts.map +0 -1
  72. package/dest/private/index.js +0 -15
  73. package/dest/private/message_load_oracle_inputs.d.ts +0 -19
  74. package/dest/private/message_load_oracle_inputs.d.ts.map +0 -1
  75. package/dest/private/message_load_oracle_inputs.js +0 -24
  76. package/dest/private/pick_notes.d.ts +0 -85
  77. package/dest/private/pick_notes.d.ts.map +0 -1
  78. package/dest/private/pick_notes.js +0 -51
  79. package/dest/private/private_execution.d.ts +0 -25
  80. package/dest/private/private_execution.d.ts.map +0 -1
  81. package/dest/private/private_execution.js +0 -96
  82. package/dest/private/private_execution_oracle.d.ts +0 -187
  83. package/dest/private/private_execution_oracle.d.ts.map +0 -1
  84. package/dest/private/private_execution_oracle.js +0 -318
  85. package/dest/private/providers/acvm_native.d.ts.map +0 -1
  86. package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
  87. package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
  88. package/dest/private/providers/circuit_recording/circuit_recorder.d.ts.map +0 -1
  89. package/dest/private/providers/circuit_recording/file_circuit_recorder.d.ts.map +0 -1
  90. package/dest/private/providers/circuit_recording/memory_circuit_recorder.d.ts.map +0 -1
  91. package/dest/private/providers/circuit_recording/simulation_provider_recorder_wrapper.d.ts.map +0 -1
  92. package/dest/private/providers/factory.d.ts +0 -12
  93. package/dest/private/providers/factory.d.ts.map +0 -1
  94. package/dest/private/providers/simulation_provider.d.ts.map +0 -1
  95. package/dest/private/simulator.d.ts +0 -36
  96. package/dest/private/simulator.d.ts.map +0 -1
  97. package/dest/private/simulator.js +0 -104
  98. package/dest/private/utility_execution_oracle.d.ts +0 -163
  99. package/dest/private/utility_execution_oracle.d.ts.map +0 -1
  100. package/dest/private/utility_execution_oracle.js +0 -257
  101. package/dest/test/utils.d.ts +0 -13
  102. package/dest/test/utils.d.ts.map +0 -1
  103. package/dest/test/utils.js +0 -22
  104. package/src/private/acvm/oracle/index.ts +0 -16
  105. package/src/private/acvm/oracle/oracle.ts +0 -523
  106. package/src/private/acvm/oracle/typed_oracle.ts +0 -273
  107. package/src/private/execution_data_provider.ts +0 -388
  108. package/src/private/execution_note_cache.ts +0 -217
  109. package/src/private/hashed_values_cache.ts +0 -47
  110. package/src/private/index.ts +0 -19
  111. package/src/private/message_load_oracle_inputs.ts +0 -23
  112. package/src/private/pick_notes.ts +0 -141
  113. package/src/private/private_execution.ts +0 -160
  114. package/src/private/private_execution_oracle.ts +0 -508
  115. package/src/private/simulator.ts +0 -170
  116. package/src/private/utility_execution_oracle.ts +0 -384
  117. package/src/test/utils.ts +0 -36
  118. /package/dest/private/{providers/acvm_native.js → acvm_native.js} +0 -0
  119. /package/dest/private/{providers/circuit_recording → circuit_recording}/file_circuit_recorder.js +0 -0
  120. /package/dest/private/{providers/circuit_recording → circuit_recording}/memory_circuit_recorder.d.ts +0 -0
  121. /package/dest/private/{providers/circuit_recording → circuit_recording}/memory_circuit_recorder.js +0 -0
  122. /package/src/private/{providers/circuit_recording → circuit_recording}/memory_circuit_recorder.ts +0 -0
@@ -1,7 +1,7 @@
1
1
  import fs from 'fs/promises';
2
2
  import path from 'path';
3
3
 
4
- import type { ACVMWitness } from '../../acvm/acvm_types.js';
4
+ import type { ACVMWitness } from '../acvm/acvm_types.js';
5
5
  import { CircuitRecorder, type CircuitRecording } from './circuit_recorder.js';
6
6
 
7
7
  export class FileCircuitRecorder extends CircuitRecorder {
@@ -2,19 +2,19 @@ import type { ForeignCallHandler } from '@aztec/noir-protocol-circuits-types/typ
2
2
  import type { FunctionArtifactWithContractName } from '@aztec/stdlib/abi';
3
3
  import type { NoirCompiledCircuitWithName } from '@aztec/stdlib/noir';
4
4
 
5
- import type { ACIRCallback, ACIRCallbackStats, ACIRExecutionResult } from '../../acvm/acvm.js';
6
- import type { ACVMWitness } from '../../acvm/acvm_types.js';
5
+ import type { ACIRCallback, ACIRCallbackStats, ACIRExecutionResult } from '../acvm/acvm.js';
6
+ import type { ACVMWitness } from '../acvm/acvm_types.js';
7
7
  import type { ACVMSuccess } from '../acvm_native.js';
8
- import type { SimulationProvider } from '../simulation_provider.js';
8
+ import type { CircuitSimulator } from '../circuit_simulator.js';
9
9
  import type { CircuitRecorder } from './circuit_recorder.js';
10
10
 
11
11
  /**
12
- * Takes a simulation provider and wraps it in a circuit recorder. See CircuitRecorder for more details on how circuit
12
+ * Takes a circuit simulator and wraps it in a circuit recorder. See CircuitRecorder for more details on how circuit
13
13
  * recording works.
14
14
  */
15
- export class SimulationProviderRecorderWrapper implements SimulationProvider {
15
+ export class SimulatorRecorderWrapper implements CircuitSimulator {
16
16
  constructor(
17
- private simulator: SimulationProvider,
17
+ private simulator: CircuitSimulator,
18
18
  private recorder: CircuitRecorder,
19
19
  ) {}
20
20
 
@@ -4,14 +4,14 @@ import { parseDebugSymbols } from '@aztec/stdlib/abi';
4
4
  import type { FunctionArtifactWithContractName } from '@aztec/stdlib/abi';
5
5
  import type { NoirCompiledCircuit, NoirCompiledCircuitWithName } from '@aztec/stdlib/noir';
6
6
 
7
- import { type ACIRCallback, type ACIRExecutionResult, extractCallStack } from '../acvm/acvm.js';
8
- import type { ACVMWitness } from '../acvm/acvm_types.js';
7
+ import { type ACIRCallback, type ACIRExecutionResult, extractCallStack } from './acvm/acvm.js';
8
+ import type { ACVMWitness } from './acvm/acvm_types.js';
9
9
  import type { ACVMSuccess } from './acvm_native.js';
10
10
 
11
11
  /**
12
12
  * Low level simulation interface
13
13
  */
14
- export interface SimulationProvider {
14
+ export interface CircuitSimulator {
15
15
  /**
16
16
  * Execute a protocol circuit/generate a witness
17
17
  * @param input - The initial witness map defining all of the inputs to `circuit`.
@@ -4,14 +4,14 @@ import { promises as fs } from 'fs';
4
4
 
5
5
  import { NativeACVMSimulator } from './acvm_native.js';
6
6
  import { WASMSimulator } from './acvm_wasm.js';
7
- import type { SimulationProvider } from './simulation_provider.js';
7
+ import type { CircuitSimulator } from './circuit_simulator.js';
8
8
 
9
- export type SimulationProviderConfig = {
9
+ export type SimulatorConfig = {
10
10
  acvmBinaryPath?: string;
11
11
  acvmWorkingDirectory?: string;
12
12
  };
13
13
 
14
- export function getSimulationProviderConfigFromEnv() {
14
+ export function getSimulatorConfigFromEnv() {
15
15
  const { ACVM_BINARY_PATH, ACVM_WORKING_DIRECTORY } = process.env;
16
16
  return {
17
17
  acvmWorkingDirectory: ACVM_WORKING_DIRECTORY ? ACVM_WORKING_DIRECTORY : undefined,
@@ -19,10 +19,10 @@ export function getSimulationProviderConfigFromEnv() {
19
19
  };
20
20
  }
21
21
 
22
- export async function createSimulationProvider(
23
- config: SimulationProviderConfig,
22
+ export async function createSimulator(
23
+ config: SimulatorConfig,
24
24
  logger: Logger = createLogger('simulator'),
25
- ): Promise<SimulationProvider> {
25
+ ): Promise<CircuitSimulator> {
26
26
  if (config.acvmBinaryPath && config.acvmWorkingDirectory) {
27
27
  try {
28
28
  await fs.access(config.acvmBinaryPath, fs.constants.R_OK);
package/src/server.ts CHANGED
@@ -1,7 +1,8 @@
1
1
  export * from './public/index.js';
2
- export { WASMSimulatorWithBlobs } from './private/providers/acvm_wasm_with_blobs.js';
3
- export { NativeACVMSimulator } from './private/providers/acvm_native.js';
4
- export { SimulationProviderRecorderWrapper } from './private/providers/circuit_recording/simulation_provider_recorder_wrapper.js';
5
- export { MemoryCircuitRecorder } from './private/providers/circuit_recording/memory_circuit_recorder.js';
6
- export { type SimulationProvider } from './private/providers/simulation_provider.js';
2
+ export * from './private/acvm/index.js';
3
+ export { WASMSimulatorWithBlobs } from './private/acvm_wasm_with_blobs.js';
4
+ export { NativeACVMSimulator } from './private/acvm_native.js';
5
+ export { SimulatorRecorderWrapper } from './private/circuit_recording/simulator_recorder_wrapper.js';
6
+ export { MemoryCircuitRecorder } from './private/circuit_recording/memory_circuit_recorder.js';
7
+ export { type CircuitSimulator, type DecodedError } from './private/circuit_simulator.js';
7
8
  export * from './common/index.js';
package/src/testing.ts CHANGED
@@ -1 +1 @@
1
- export { FileCircuitRecorder } from './private/providers/circuit_recording/file_circuit_recorder.js';
1
+ export { FileCircuitRecorder } from './private/circuit_recording/file_circuit_recorder.js';
@@ -1,14 +0,0 @@
1
- import type { Oracle } from './oracle.js';
2
- export * from './oracle.js';
3
- export * from './typed_oracle.js';
4
- /**
5
- * A conditional type that takes a type `T` and returns a union of its method names.
6
- */
7
- type MethodNames<T> = {
8
- [K in keyof T]: T[K] extends (...args: any[]) => any ? K : never;
9
- }[keyof T];
10
- /**
11
- * Available oracle function names.
12
- */
13
- export type ORACLE_NAMES = MethodNames<Oracle>;
14
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/private/acvm/oracle/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAElC;;GAEG;AACH,KAAK,WAAW,CAAC,CAAC,IAAI;KACnB,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,GAAG,CAAC,GAAG,KAAK;CACjE,CAAC,MAAM,CAAC,CAAC,CAAC;AAEX;;GAEG;AACH,MAAM,MAAM,YAAY,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export * from './oracle.js';
2
- export * from './typed_oracle.js';
@@ -1,52 +0,0 @@
1
- import type { ACVMField } from '../acvm_types.js';
2
- import type { TypedOracle } from './typed_oracle.js';
3
- /**
4
- * A data source that has all the apis required by Aztec.nr.
5
- */
6
- export declare class Oracle {
7
- private typedOracle;
8
- constructor(typedOracle: TypedOracle);
9
- getRandomField(): Promise<ACVMField[]>;
10
- storeInExecutionCache(_length: ACVMField[], values: ACVMField[], [hash]: ACVMField[]): Promise<ACVMField[]>;
11
- loadFromExecutionCache([returnsHash]: ACVMField[]): Promise<ACVMField[][]>;
12
- getBlockNumber(): Promise<ACVMField[]>;
13
- getContractAddress(): Promise<ACVMField[]>;
14
- getVersion(): Promise<ACVMField[]>;
15
- getChainId(): Promise<ACVMField[]>;
16
- getKeyValidationRequest([pkMHash]: ACVMField[]): Promise<ACVMField[]>;
17
- getContractInstance([address]: ACVMField[]): Promise<ACVMField[]>;
18
- getMembershipWitness([blockNumber]: ACVMField[], [treeId]: ACVMField[], [leafValue]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
19
- getNullifierMembershipWitness([blockNumber]: ACVMField[], [nullifier]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
20
- getLowNullifierMembershipWitness([blockNumber]: ACVMField[], [nullifier]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
21
- getPublicDataWitness([blockNumber]: ACVMField[], [leafSlot]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
22
- getBlockHeader([blockNumber]: ACVMField[]): Promise<ACVMField[]>;
23
- getAuthWitness([messageHash]: ACVMField[]): Promise<ACVMField[][]>;
24
- getPublicKeysAndPartialAddress([address]: ACVMField[]): Promise<ACVMField[][]>;
25
- getNotes([storageSlot]: ACVMField[], [numSelects]: ACVMField[], selectByIndexes: ACVMField[], selectByOffsets: ACVMField[], selectByLengths: ACVMField[], selectValues: ACVMField[], selectComparators: ACVMField[], sortByIndexes: ACVMField[], sortByOffsets: ACVMField[], sortByLengths: ACVMField[], sortOrder: ACVMField[], [limit]: ACVMField[], [offset]: ACVMField[], [status]: ACVMField[], [maxNotes]: ACVMField[], [packedRetrievedNoteLength]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
26
- notifyCreatedNote([storageSlot]: ACVMField[], [noteTypeId]: ACVMField[], note: ACVMField[], [noteHash]: ACVMField[], [counter]: ACVMField[]): Promise<ACVMField[]>;
27
- notifyNullifiedNote([innerNullifier]: ACVMField[], [noteHash]: ACVMField[], [counter]: ACVMField[]): Promise<ACVMField[]>;
28
- notifyCreatedNullifier([innerNullifier]: ACVMField[]): Promise<ACVMField[]>;
29
- checkNullifierExists([innerNullifier]: ACVMField[]): Promise<ACVMField[]>;
30
- getL1ToL2MembershipWitness([contractAddress]: ACVMField[], [messageHash]: ACVMField[], [secret]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
31
- storageRead([contractAddress]: ACVMField[], [startStorageSlot]: ACVMField[], [blockNumber]: ACVMField[], [numberOfElements]: ACVMField[]): Promise<ACVMField[][]>;
32
- storageWrite([startStorageSlot]: ACVMField[], values: ACVMField[]): Promise<ACVMField[]>;
33
- notifyCreatedContractClassLog([contractAddress]: ACVMField[], message: ACVMField[], [length]: ACVMField[], [counter]: ACVMField[]): Promise<ACVMField[]>;
34
- debugLog(message: ACVMField[], _ignoredFieldsSize: ACVMField[], fields: ACVMField[]): Promise<ACVMField[]>;
35
- callPrivateFunction([contractAddress]: ACVMField[], [functionSelector]: ACVMField[], [argsHash]: ACVMField[], [sideEffectCounter]: ACVMField[], [isStaticCall]: ACVMField[]): Promise<ACVMField[][]>;
36
- notifyEnqueuedPublicFunctionCall([contractAddress]: ACVMField[], [calldataHash]: ACVMField[], [sideEffectCounter]: ACVMField[], [isStaticCall]: ACVMField[]): Promise<ACVMField[]>;
37
- notifySetPublicTeardownFunctionCall([contractAddress]: ACVMField[], [calldataHash]: ACVMField[], [sideEffectCounter]: ACVMField[], [isStaticCall]: ACVMField[]): Promise<ACVMField[]>;
38
- notifySetMinRevertibleSideEffectCounter([minRevertibleSideEffectCounter]: ACVMField[]): Promise<ACVMField[]>;
39
- getIndexedTaggingSecretAsSender([sender]: ACVMField[], [recipient]: ACVMField[]): Promise<ACVMField[]>;
40
- incrementAppTaggingSecretIndexAsSender([sender]: ACVMField[], [recipient]: ACVMField[]): Promise<ACVMField[]>;
41
- fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]: ACVMField[]): Promise<ACVMField[]>;
42
- deliverNote([contractAddress]: ACVMField[], [storageSlot]: ACVMField[], [nonce]: ACVMField[], content: ACVMField[], [contentLength]: ACVMField[], [noteHash]: ACVMField[], [nullifier]: ACVMField[], [txHash]: ACVMField[], [recipient]: ACVMField[]): Promise<ACVMField[]>;
43
- getLogByTag([tag]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
44
- storeCapsule([contractAddress]: ACVMField[], [slot]: ACVMField[], capsule: ACVMField[]): Promise<ACVMField[]>;
45
- loadCapsule([contractAddress]: ACVMField[], [slot]: ACVMField[], [tSize]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
46
- deleteCapsule([contractAddress]: ACVMField[], [slot]: ACVMField[]): Promise<ACVMField[]>;
47
- copyCapsule([contractAddress]: ACVMField[], [srcSlot]: ACVMField[], [dstSlot]: ACVMField[], [numEntries]: ACVMField[]): Promise<ACVMField[]>;
48
- aes128Decrypt(ciphertextBVecStorage: ACVMField[], [ciphertextLength]: ACVMField[], iv: ACVMField[], symKey: ACVMField[]): Promise<(ACVMField | ACVMField[])[]>;
49
- getSharedSecret([address]: ACVMField[], [ephPKField0]: ACVMField[], [ephPKField1]: ACVMField[], [ephPKField2]: ACVMField[]): Promise<ACVMField[]>;
50
- storePrivateEventLog([contractAddress]: ACVMField[], [recipient]: ACVMField[], [eventSelector]: ACVMField[], msgContentBVecStorage: ACVMField[], [msgContentLength]: ACVMField[], [txHash]: ACVMField[], [logIndexInTx]: ACVMField[], [txIndexInBlock]: ACVMField[]): Promise<never[]>;
51
- }
52
- //# sourceMappingURL=oracle.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"oracle.d.ts","sourceRoot":"","sources":["../../../../src/private/acvm/oracle/oracle.ts"],"names":[],"mappings":"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"}
@@ -1,312 +0,0 @@
1
- import { Fr, Point } from '@aztec/foundation/fields';
2
- import { EventSelector, FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
3
- import { AztecAddress } from '@aztec/stdlib/aztec-address';
4
- import { ContractClassLog, ContractClassLogFields, LogWithTxData } from '@aztec/stdlib/logs';
5
- import { MerkleTreeId } from '@aztec/stdlib/trees';
6
- import { TxHash } from '@aztec/stdlib/tx';
7
- import { fromBoundedVec, fromUintArray, fromUintBoundedVec } from '../deserialize.js';
8
- import { arrayOfArraysToBoundedVecOfArrays, bufferToBoundedVec, toACVMField, toACVMFieldSingleOrArray } from '../serialize.js';
9
- /**
10
- * A data source that has all the apis required by Aztec.nr.
11
- */ export class Oracle {
12
- typedOracle;
13
- constructor(typedOracle){
14
- this.typedOracle = typedOracle;
15
- }
16
- getRandomField() {
17
- const val = this.typedOracle.getRandomField();
18
- return Promise.resolve([
19
- toACVMField(val)
20
- ]);
21
- }
22
- // Since the argument is a slice, noir automatically adds a length field to oracle call.
23
- storeInExecutionCache(_length, values, [hash]) {
24
- this.typedOracle.storeInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
25
- return Promise.resolve([]);
26
- }
27
- async loadFromExecutionCache([returnsHash]) {
28
- const values = await this.typedOracle.loadFromExecutionCache(Fr.fromString(returnsHash));
29
- return [
30
- values.map(toACVMField)
31
- ];
32
- }
33
- async getBlockNumber() {
34
- return [
35
- toACVMField(await this.typedOracle.getBlockNumber())
36
- ];
37
- }
38
- async getContractAddress() {
39
- return [
40
- toACVMField(await this.typedOracle.getContractAddress())
41
- ];
42
- }
43
- async getVersion() {
44
- return [
45
- toACVMField(await this.typedOracle.getVersion())
46
- ];
47
- }
48
- async getChainId() {
49
- return [
50
- toACVMField(await this.typedOracle.getChainId())
51
- ];
52
- }
53
- async getKeyValidationRequest([pkMHash]) {
54
- const keyValidationRequest = await this.typedOracle.getKeyValidationRequest(Fr.fromString(pkMHash));
55
- return keyValidationRequest.toFields().map(toACVMField);
56
- }
57
- async getContractInstance([address]) {
58
- const instance = await this.typedOracle.getContractInstance(AztecAddress.fromField(Fr.fromString(address)));
59
- return [
60
- instance.salt,
61
- instance.deployer,
62
- instance.currentContractClassId,
63
- instance.initializationHash,
64
- ...instance.publicKeys.toFields()
65
- ].map(toACVMField);
66
- }
67
- async getMembershipWitness([blockNumber], [treeId], [leafValue]) {
68
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
69
- const parsedTreeId = Fr.fromString(treeId).toNumber();
70
- const parsedLeafValue = Fr.fromString(leafValue);
71
- const witness = await this.typedOracle.getMembershipWitness(parsedBlockNumber, parsedTreeId, parsedLeafValue);
72
- if (!witness) {
73
- throw new Error(`Leaf ${leafValue} not found in the tree ${MerkleTreeId[parsedTreeId]} at block ${parsedBlockNumber}.`);
74
- }
75
- return [
76
- toACVMField(witness[0]),
77
- witness.slice(1).map(toACVMField)
78
- ];
79
- }
80
- async getNullifierMembershipWitness([blockNumber], [nullifier]) {
81
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
82
- const parsedNullifier = Fr.fromString(nullifier);
83
- const witness = await this.typedOracle.getNullifierMembershipWitness(parsedBlockNumber, parsedNullifier);
84
- if (!witness) {
85
- throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
86
- }
87
- return witness.toNoirRepresentation();
88
- }
89
- async getLowNullifierMembershipWitness([blockNumber], [nullifier]) {
90
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
91
- const parsedNullifier = Fr.fromString(nullifier);
92
- const witness = await this.typedOracle.getLowNullifierMembershipWitness(parsedBlockNumber, parsedNullifier);
93
- if (!witness) {
94
- throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
95
- }
96
- return witness.toNoirRepresentation();
97
- }
98
- async getPublicDataWitness([blockNumber], [leafSlot]) {
99
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
100
- const parsedLeafSlot = Fr.fromString(leafSlot);
101
- const witness = await this.typedOracle.getPublicDataWitness(parsedBlockNumber, parsedLeafSlot);
102
- if (!witness) {
103
- throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block ${parsedBlockNumber}.`);
104
- }
105
- return witness.toNoirRepresentation();
106
- }
107
- async getBlockHeader([blockNumber]) {
108
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
109
- const header = await this.typedOracle.getBlockHeader(parsedBlockNumber);
110
- if (!header) {
111
- throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
112
- }
113
- return header.toFields().map(toACVMField);
114
- }
115
- async getAuthWitness([messageHash]) {
116
- const messageHashField = Fr.fromString(messageHash);
117
- const witness = await this.typedOracle.getAuthWitness(messageHashField);
118
- if (!witness) {
119
- throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
120
- }
121
- return [
122
- witness.map(toACVMField)
123
- ];
124
- }
125
- async getPublicKeysAndPartialAddress([address]) {
126
- const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
127
- const { publicKeys, partialAddress } = await this.typedOracle.getCompleteAddress(parsedAddress);
128
- return [
129
- [
130
- ...publicKeys.toFields(),
131
- partialAddress
132
- ].map(toACVMField)
133
- ];
134
- }
135
- async getNotes([storageSlot], [numSelects], selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, [limit], [offset], [status], [maxNotes], [packedRetrievedNoteLength]) {
136
- const noteDatas = await this.typedOracle.getNotes(Fr.fromString(storageSlot), +numSelects, selectByIndexes.map((s)=>+s), selectByOffsets.map((s)=>+s), selectByLengths.map((s)=>+s), selectValues.map(Fr.fromString), selectComparators.map((s)=>+s), sortByIndexes.map((s)=>+s), sortByOffsets.map((s)=>+s), sortByLengths.map((s)=>+s), sortOrder.map((s)=>+s), +limit, +offset, +status);
137
- if (noteDatas.length > 0) {
138
- const noteLength = noteDatas[0].note.items.length;
139
- if (!noteDatas.every(({ note })=>noteLength === note.items.length)) {
140
- throw new Error('Notes should all be the same length.');
141
- }
142
- }
143
- // The expected return type is a BoundedVec<[Field; packedRetrievedNoteLength], maxNotes> where each
144
- // array is structured as [contract_address, nonce, nonzero_note_hash_counter, ...packed_note].
145
- const returnDataAsArrayOfArrays = noteDatas.map(({ contractAddress, nonce, index, note })=>{
146
- // If index is undefined, the note is transient which implies that the nonzero_note_hash_counter has to be true
147
- const noteIsTransient = index === undefined;
148
- const nonzeroNoteHashCounter = noteIsTransient ? true : false;
149
- // If you change the array on the next line you have to change the `unpack_retrieved_note` function in
150
- // `aztec/src/note/retrieved_note.nr`
151
- return [
152
- contractAddress,
153
- nonce,
154
- nonzeroNoteHashCounter,
155
- ...note.items
156
- ];
157
- });
158
- // Now we convert each sub-array to an array of ACVMField
159
- const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfArrays.map((subArray)=>subArray.map(toACVMField));
160
- // At last we convert the array of arrays to a bounded vec of arrays
161
- return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedRetrievedNoteLength);
162
- }
163
- notifyCreatedNote([storageSlot], [noteTypeId], note, [noteHash], [counter]) {
164
- this.typedOracle.notifyCreatedNote(Fr.fromString(storageSlot), NoteSelector.fromField(Fr.fromString(noteTypeId)), note.map(Fr.fromString), Fr.fromString(noteHash), +counter);
165
- return Promise.resolve([]);
166
- }
167
- async notifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
168
- await this.typedOracle.notifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
169
- return [];
170
- }
171
- async notifyCreatedNullifier([innerNullifier]) {
172
- await this.typedOracle.notifyCreatedNullifier(Fr.fromString(innerNullifier));
173
- return [];
174
- }
175
- async checkNullifierExists([innerNullifier]) {
176
- const exists = await this.typedOracle.checkNullifierExists(Fr.fromString(innerNullifier));
177
- return [
178
- toACVMField(exists)
179
- ];
180
- }
181
- async getL1ToL2MembershipWitness([contractAddress], [messageHash], [secret]) {
182
- const message = await this.typedOracle.getL1ToL2MembershipWitness(AztecAddress.fromString(contractAddress), Fr.fromString(messageHash), Fr.fromString(secret));
183
- return message.toNoirRepresentation();
184
- }
185
- async storageRead([contractAddress], [startStorageSlot], [blockNumber], [numberOfElements]) {
186
- const values = await this.typedOracle.storageRead(new AztecAddress(Fr.fromString(contractAddress)), Fr.fromString(startStorageSlot), +blockNumber, +numberOfElements);
187
- return [
188
- values.map(toACVMField)
189
- ];
190
- }
191
- async storageWrite([startStorageSlot], values) {
192
- const newValues = await this.typedOracle.storageWrite(Fr.fromString(startStorageSlot), values.map(Fr.fromString));
193
- return newValues.map(toACVMField);
194
- }
195
- notifyCreatedContractClassLog([contractAddress], message, [length], [counter]) {
196
- const logFields = new ContractClassLogFields(message.map(Fr.fromString));
197
- const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
198
- this.typedOracle.notifyCreatedContractClassLog(log, +counter);
199
- return Promise.resolve([]);
200
- }
201
- debugLog(message, _ignoredFieldsSize, fields) {
202
- const messageStr = message.map((acvmField)=>String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
203
- const fieldsFr = fields.map(Fr.fromString);
204
- this.typedOracle.debugLog(messageStr, fieldsFr);
205
- return Promise.resolve([]);
206
- }
207
- async callPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideEffectCounter], [isStaticCall]) {
208
- const { endSideEffectCounter, returnsHash } = await this.typedOracle.callPrivateFunction(AztecAddress.fromField(Fr.fromString(contractAddress)), FunctionSelector.fromField(Fr.fromString(functionSelector)), Fr.fromString(argsHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
209
- return [
210
- [
211
- endSideEffectCounter,
212
- returnsHash
213
- ].map(toACVMField)
214
- ];
215
- }
216
- async notifyEnqueuedPublicFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
217
- await this.typedOracle.notifyEnqueuedPublicFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
218
- return [];
219
- }
220
- async notifySetPublicTeardownFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
221
- await this.typedOracle.notifySetPublicTeardownFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
222
- return [];
223
- }
224
- async notifySetMinRevertibleSideEffectCounter([minRevertibleSideEffectCounter]) {
225
- await this.typedOracle.notifySetMinRevertibleSideEffectCounter(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
226
- return Promise.resolve([]);
227
- }
228
- async getIndexedTaggingSecretAsSender([sender], [recipient]) {
229
- const taggingSecret = await this.typedOracle.getIndexedTaggingSecretAsSender(AztecAddress.fromString(sender), AztecAddress.fromString(recipient));
230
- return taggingSecret.toFields().map(toACVMField);
231
- }
232
- async incrementAppTaggingSecretIndexAsSender([sender], [recipient]) {
233
- await this.typedOracle.incrementAppTaggingSecretIndexAsSender(AztecAddress.fromString(sender), AztecAddress.fromString(recipient));
234
- return [];
235
- }
236
- async fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]) {
237
- await this.typedOracle.fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
238
- return [];
239
- }
240
- async deliverNote([contractAddress], [storageSlot], [nonce], content, [contentLength], [noteHash], [nullifier], [txHash], [recipient]) {
241
- // TODO(#10728): try-catch this block and return false if we get an exception so that the contract can decide what
242
- // to do if a note fails delivery (e.g. not increment the tagging index, or add it to some pending work list).
243
- // Delivery might fail due to temporary issues, such as poor node connectivity.
244
- await this.typedOracle.deliverNote(AztecAddress.fromString(contractAddress), Fr.fromString(storageSlot), Fr.fromString(nonce), fromBoundedVec(content, contentLength), Fr.fromString(noteHash), Fr.fromString(nullifier), TxHash.fromString(txHash), AztecAddress.fromString(recipient));
245
- return [
246
- toACVMField(true)
247
- ];
248
- }
249
- async getLogByTag([tag]) {
250
- const log = await this.typedOracle.getLogByTag(Fr.fromString(tag));
251
- if (log == null) {
252
- return [
253
- toACVMField(0),
254
- ...LogWithTxData.noirSerializationOfEmpty().map(toACVMFieldSingleOrArray)
255
- ];
256
- } else {
257
- return [
258
- toACVMField(1),
259
- ...log.toNoirSerialization().map(toACVMFieldSingleOrArray)
260
- ];
261
- }
262
- }
263
- async storeCapsule([contractAddress], [slot], capsule) {
264
- await this.typedOracle.storeCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
265
- return [];
266
- }
267
- async loadCapsule([contractAddress], [slot], [tSize]) {
268
- const values = await this.typedOracle.loadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
269
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
270
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
271
- if (values === null) {
272
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
273
- return [
274
- toACVMField(0),
275
- Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))
276
- ];
277
- } else {
278
- // Data was found so we set `some` to 1 and return it along with `value`.
279
- return [
280
- toACVMField(1),
281
- values.map(toACVMField)
282
- ];
283
- }
284
- }
285
- async deleteCapsule([contractAddress], [slot]) {
286
- await this.typedOracle.deleteCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
287
- return [];
288
- }
289
- async copyCapsule([contractAddress], [srcSlot], [dstSlot], [numEntries]) {
290
- await this.typedOracle.copyCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(srcSlot), Fr.fromString(dstSlot), Fr.fromString(numEntries).toNumber());
291
- return [];
292
- }
293
- async aes128Decrypt(ciphertextBVecStorage, [ciphertextLength], iv, symKey) {
294
- const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
295
- const ivBuffer = fromUintArray(iv, 8);
296
- const symKeyBuffer = fromUintArray(symKey, 8);
297
- const plaintext = await this.typedOracle.aes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
298
- return bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
299
- }
300
- async getSharedSecret([address], [ephPKField0], [ephPKField1], [ephPKField2]) {
301
- const secret = await this.typedOracle.getSharedSecret(AztecAddress.fromField(Fr.fromString(address)), Point.fromFields([
302
- ephPKField0,
303
- ephPKField1,
304
- ephPKField2
305
- ].map(Fr.fromString)));
306
- return secret.toFields().map(toACVMField);
307
- }
308
- async storePrivateEventLog([contractAddress], [recipient], [eventSelector], msgContentBVecStorage, [msgContentLength], [txHash], [logIndexInTx], [txIndexInBlock]) {
309
- await this.typedOracle.storePrivateEventLog(AztecAddress.fromField(Fr.fromString(contractAddress)), AztecAddress.fromField(Fr.fromString(recipient)), EventSelector.fromField(Fr.fromString(eventSelector)), fromBoundedVec(msgContentBVecStorage, msgContentLength), new TxHash(Fr.fromString(txHash)), Fr.fromString(logIndexInTx).toNumber(), Fr.fromString(txIndexInBlock).toNumber());
310
- return [];
311
- }
312
- }
@@ -1,83 +0,0 @@
1
- import type { L1_TO_L2_MSG_TREE_HEIGHT } from '@aztec/constants';
2
- import { Fr, Point } from '@aztec/foundation/fields';
3
- import type { EventSelector, FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
4
- import type { AztecAddress } from '@aztec/stdlib/aztec-address';
5
- import type { CompleteAddress, ContractInstance } from '@aztec/stdlib/contract';
6
- import type { KeyValidationRequest } from '@aztec/stdlib/kernel';
7
- import type { ContractClassLog, IndexedTaggingSecret, LogWithTxData } from '@aztec/stdlib/logs';
8
- import type { Note, NoteStatus } from '@aztec/stdlib/note';
9
- import { type MerkleTreeId, type NullifierMembershipWitness, PublicDataWitness } from '@aztec/stdlib/trees';
10
- import type { BlockHeader, TxHash } from '@aztec/stdlib/tx';
11
- import type { MessageLoadOracleInputs } from '../../message_load_oracle_inputs.js';
12
- /**
13
- * Information about a note needed during execution.
14
- */
15
- export interface NoteData {
16
- /** The note. */
17
- note: Note;
18
- /** The contract address of the note. */
19
- contractAddress: AztecAddress;
20
- /** The storage slot of the note. */
21
- storageSlot: Fr;
22
- /** The nonce of the note. */
23
- nonce: Fr;
24
- /** A hash of the note. */
25
- noteHash: Fr;
26
- /** The corresponding nullifier of the note. Undefined for pending notes. */
27
- siloedNullifier?: Fr;
28
- /** The note's leaf index in the note hash tree. Undefined for pending notes. */
29
- index?: bigint;
30
- }
31
- /**
32
- * Oracle with typed parameters and typed return values.
33
- * Methods that require read and/or write will have to be implemented based on the context (public, private, or view)
34
- * and are unavailable by default.
35
- */
36
- export declare abstract class TypedOracle {
37
- getRandomField(): Fr;
38
- storeInExecutionCache(_values: Fr[], _hash: Fr): void;
39
- loadFromExecutionCache(_hash: Fr): Promise<Fr[]>;
40
- getBlockNumber(): Promise<number>;
41
- getContractAddress(): Promise<AztecAddress>;
42
- getChainId(): Promise<Fr>;
43
- getVersion(): Promise<Fr>;
44
- getKeyValidationRequest(_pkMHash: Fr): Promise<KeyValidationRequest>;
45
- getContractInstance(_address: AztecAddress): Promise<ContractInstance>;
46
- getMembershipWitness(_blockNumber: number, _treeId: MerkleTreeId, _leafValue: Fr): Promise<Fr[] | undefined>;
47
- getNullifierMembershipWitness(_blockNumber: number, _nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
48
- getPublicDataWitness(_blockNumber: number, _leafSlot: Fr): Promise<PublicDataWitness | undefined>;
49
- getLowNullifierMembershipWitness(_blockNumber: number, _nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
50
- getBlockHeader(_blockNumber: number): Promise<BlockHeader | undefined>;
51
- getCompleteAddress(_account: AztecAddress): Promise<CompleteAddress>;
52
- getAuthWitness(_messageHash: Fr): Promise<Fr[] | undefined>;
53
- getNotes(_storageSlot: Fr, _numSelects: number, _selectByIndexes: number[], _selectByOffsets: number[], _selectByLengths: number[], _selectValues: Fr[], _selectComparators: number[], _sortByIndexes: number[], _sortByOffsets: number[], _sortByLengths: number[], _sortOrder: number[], _limit: number, _offset: number, _status: NoteStatus): Promise<NoteData[]>;
54
- notifyCreatedNote(_storageSlot: Fr, _noteTypeId: NoteSelector, _note: Fr[], _noteHash: Fr, _counter: number): void;
55
- notifyNullifiedNote(_innerNullifier: Fr, _noteHash: Fr, _counter: number): Promise<void>;
56
- notifyCreatedNullifier(_innerNullifier: Fr): Promise<void>;
57
- checkNullifierExists(_innerNullifier: Fr): Promise<boolean>;
58
- getL1ToL2MembershipWitness(_contractAddress: AztecAddress, _messageHash: Fr, _secret: Fr): Promise<MessageLoadOracleInputs<typeof L1_TO_L2_MSG_TREE_HEIGHT>>;
59
- storageRead(_contractAddress: AztecAddress, _startStorageSlot: Fr, _blockNumber: number, _numberOfElements: number): Promise<Fr[]>;
60
- storageWrite(_startStorageSlot: Fr, _values: Fr[]): Promise<Fr[]>;
61
- notifyCreatedContractClassLog(_log: ContractClassLog, _counter: number): void;
62
- callPrivateFunction(_targetContractAddress: AztecAddress, _functionSelector: FunctionSelector, _argsHash: Fr, _sideEffectCounter: number, _isStaticCall: boolean): Promise<{
63
- endSideEffectCounter: Fr;
64
- returnsHash: Fr;
65
- }>;
66
- notifyEnqueuedPublicFunctionCall(_targetContractAddress: AztecAddress, _calldataHash: Fr, _sideEffectCounter: number, _isStaticCall: boolean): Promise<void>;
67
- notifySetPublicTeardownFunctionCall(_targetContractAddress: AztecAddress, _calldataHash: Fr, _sideEffectCounter: number, _isStaticCall: boolean): Promise<void>;
68
- notifySetMinRevertibleSideEffectCounter(_minRevertibleSideEffectCounter: number): Promise<void>;
69
- debugLog(_message: string, _fields: Fr[]): void;
70
- getIndexedTaggingSecretAsSender(_sender: AztecAddress, _recipient: AztecAddress): Promise<IndexedTaggingSecret>;
71
- incrementAppTaggingSecretIndexAsSender(_sender: AztecAddress, _recipient: AztecAddress): Promise<void>;
72
- fetchTaggedLogs(_pendingTaggedLogArrayBaseSlot: Fr): Promise<void>;
73
- deliverNote(_contractAddress: AztecAddress, _storageSlot: Fr, _nonce: Fr, _content: Fr[], _noteHash: Fr, _nullifier: Fr, _txHash: TxHash, _recipient: AztecAddress): Promise<void>;
74
- getLogByTag(_tag: Fr): Promise<LogWithTxData | null>;
75
- storeCapsule(_contractAddress: AztecAddress, _key: Fr, _capsule: Fr[]): Promise<void>;
76
- loadCapsule(_contractAddress: AztecAddress, _key: Fr): Promise<Fr[] | null>;
77
- deleteCapsule(_contractAddress: AztecAddress, _key: Fr): Promise<void>;
78
- copyCapsule(_contractAddress: AztecAddress, _srcKey: Fr, _dstKey: Fr, _numEntries: number): Promise<void>;
79
- aes128Decrypt(_ciphertext: Buffer, _iv: Buffer, _symKey: Buffer): Promise<Buffer>;
80
- getSharedSecret(_address: AztecAddress, _ephPk: Point): Promise<Point>;
81
- storePrivateEventLog(_contractAddress: AztecAddress, _recipient: AztecAddress, _eventSelector: EventSelector, _logContent: Fr[], _txHash: TxHash, _logIndexInTx: number, _txIndexInBlock: number): Promise<void>;
82
- }
83
- //# sourceMappingURL=typed_oracle.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typed_oracle.d.ts","sourceRoot":"","sources":["../../../../src/private/acvm/oracle/typed_oracle.ts"],"names":[],"mappings":"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"}