@aztec/prover-client 0.0.0-test.1 → 0.0.1-commit.023c3e5

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 (150) hide show
  1. package/dest/config.d.ts +8 -8
  2. package/dest/config.d.ts.map +1 -1
  3. package/dest/config.js +12 -2
  4. package/dest/index.d.ts +1 -1
  5. package/dest/light/index.d.ts +2 -0
  6. package/dest/light/index.d.ts.map +1 -0
  7. package/dest/light/index.js +1 -0
  8. package/dest/light/lightweight_checkpoint_builder.d.ts +47 -0
  9. package/dest/light/lightweight_checkpoint_builder.d.ts.map +1 -0
  10. package/dest/light/lightweight_checkpoint_builder.js +200 -0
  11. package/dest/mocks/fixtures.d.ts +8 -8
  12. package/dest/mocks/fixtures.d.ts.map +1 -1
  13. package/dest/mocks/fixtures.js +36 -17
  14. package/dest/mocks/test_context.d.ts +43 -32
  15. package/dest/mocks/test_context.d.ts.map +1 -1
  16. package/dest/mocks/test_context.js +149 -87
  17. package/dest/orchestrator/block-building-helpers.d.ts +37 -30
  18. package/dest/orchestrator/block-building-helpers.d.ts.map +1 -1
  19. package/dest/orchestrator/block-building-helpers.js +170 -189
  20. package/dest/orchestrator/block-proving-state.d.ts +70 -48
  21. package/dest/orchestrator/block-proving-state.d.ts.map +1 -1
  22. package/dest/orchestrator/block-proving-state.js +282 -177
  23. package/dest/orchestrator/checkpoint-proving-state.d.ts +76 -0
  24. package/dest/orchestrator/checkpoint-proving-state.d.ts.map +1 -0
  25. package/dest/orchestrator/checkpoint-proving-state.js +243 -0
  26. package/dest/orchestrator/epoch-proving-state.d.ts +43 -28
  27. package/dest/orchestrator/epoch-proving-state.d.ts.map +1 -1
  28. package/dest/orchestrator/epoch-proving-state.js +177 -73
  29. package/dest/orchestrator/index.d.ts +1 -1
  30. package/dest/orchestrator/orchestrator.d.ts +53 -35
  31. package/dest/orchestrator/orchestrator.d.ts.map +1 -1
  32. package/dest/orchestrator/orchestrator.js +855 -302
  33. package/dest/orchestrator/orchestrator_metrics.d.ts +1 -1
  34. package/dest/orchestrator/orchestrator_metrics.d.ts.map +1 -1
  35. package/dest/orchestrator/orchestrator_metrics.js +2 -6
  36. package/dest/orchestrator/tx-proving-state.d.ts +15 -12
  37. package/dest/orchestrator/tx-proving-state.d.ts.map +1 -1
  38. package/dest/orchestrator/tx-proving-state.js +27 -44
  39. package/dest/prover-client/factory.d.ts +3 -3
  40. package/dest/prover-client/factory.d.ts.map +1 -1
  41. package/dest/prover-client/index.d.ts +1 -1
  42. package/dest/prover-client/prover-client.d.ts +5 -5
  43. package/dest/prover-client/prover-client.d.ts.map +1 -1
  44. package/dest/prover-client/prover-client.js +11 -7
  45. package/dest/prover-client/server-epoch-prover.d.ts +16 -12
  46. package/dest/prover-client/server-epoch-prover.d.ts.map +1 -1
  47. package/dest/prover-client/server-epoch-prover.js +11 -11
  48. package/dest/proving_broker/broker_prover_facade.d.ts +28 -19
  49. package/dest/proving_broker/broker_prover_facade.d.ts.map +1 -1
  50. package/dest/proving_broker/broker_prover_facade.js +62 -43
  51. package/dest/proving_broker/config.d.ts +23 -10
  52. package/dest/proving_broker/config.d.ts.map +1 -1
  53. package/dest/proving_broker/config.js +29 -6
  54. package/dest/proving_broker/factory.d.ts +2 -2
  55. package/dest/proving_broker/factory.d.ts.map +1 -1
  56. package/dest/proving_broker/factory.js +5 -1
  57. package/dest/proving_broker/fixtures.d.ts +3 -2
  58. package/dest/proving_broker/fixtures.d.ts.map +1 -1
  59. package/dest/proving_broker/fixtures.js +3 -2
  60. package/dest/proving_broker/index.d.ts +1 -1
  61. package/dest/proving_broker/proof_store/factory.d.ts +2 -2
  62. package/dest/proving_broker/proof_store/factory.js +1 -1
  63. package/dest/proving_broker/proof_store/gcs_proof_store.d.ts +1 -1
  64. package/dest/proving_broker/proof_store/gcs_proof_store.d.ts.map +1 -1
  65. package/dest/proving_broker/proof_store/gcs_proof_store.js +1 -0
  66. package/dest/proving_broker/proof_store/index.d.ts +2 -1
  67. package/dest/proving_broker/proof_store/index.d.ts.map +1 -1
  68. package/dest/proving_broker/proof_store/index.js +1 -0
  69. package/dest/proving_broker/proof_store/inline_proof_store.d.ts +1 -1
  70. package/dest/proving_broker/proof_store/inline_proof_store.d.ts.map +1 -1
  71. package/dest/proving_broker/proof_store/proof_store.d.ts +1 -1
  72. package/dest/proving_broker/proving_agent.d.ts +8 -12
  73. package/dest/proving_broker/proving_agent.d.ts.map +1 -1
  74. package/dest/proving_broker/proving_agent.js +86 -65
  75. package/dest/proving_broker/proving_broker.d.ts +13 -4
  76. package/dest/proving_broker/proving_broker.d.ts.map +1 -1
  77. package/dest/proving_broker/proving_broker.js +40 -33
  78. package/dest/proving_broker/proving_broker_database/memory.d.ts +3 -2
  79. package/dest/proving_broker/proving_broker_database/memory.d.ts.map +1 -1
  80. package/dest/proving_broker/proving_broker_database/memory.js +1 -1
  81. package/dest/proving_broker/proving_broker_database/persisted.d.ts +5 -3
  82. package/dest/proving_broker/proving_broker_database/persisted.d.ts.map +1 -1
  83. package/dest/proving_broker/proving_broker_database/persisted.js +401 -11
  84. package/dest/proving_broker/proving_broker_database.d.ts +3 -2
  85. package/dest/proving_broker/proving_broker_database.d.ts.map +1 -1
  86. package/dest/proving_broker/proving_broker_instrumentation.d.ts +1 -1
  87. package/dest/proving_broker/proving_broker_instrumentation.d.ts.map +1 -1
  88. package/dest/proving_broker/proving_broker_instrumentation.js +15 -35
  89. package/dest/proving_broker/proving_job_controller.d.ts +11 -10
  90. package/dest/proving_broker/proving_job_controller.d.ts.map +1 -1
  91. package/dest/proving_broker/proving_job_controller.js +92 -62
  92. package/dest/proving_broker/rpc.d.ts +4 -6
  93. package/dest/proving_broker/rpc.d.ts.map +1 -1
  94. package/dest/proving_broker/rpc.js +1 -4
  95. package/dest/test/mock_proof_store.d.ts +9 -0
  96. package/dest/test/mock_proof_store.d.ts.map +1 -0
  97. package/dest/test/mock_proof_store.js +10 -0
  98. package/dest/test/mock_prover.d.ts +23 -17
  99. package/dest/test/mock_prover.d.ts.map +1 -1
  100. package/dest/test/mock_prover.js +38 -20
  101. package/package.json +33 -31
  102. package/src/config.ts +25 -9
  103. package/src/light/index.ts +1 -0
  104. package/src/light/lightweight_checkpoint_builder.ts +289 -0
  105. package/src/mocks/fixtures.ts +46 -40
  106. package/src/mocks/test_context.ts +223 -116
  107. package/src/orchestrator/block-building-helpers.ts +258 -334
  108. package/src/orchestrator/block-proving-state.ts +325 -231
  109. package/src/orchestrator/checkpoint-proving-state.ts +349 -0
  110. package/src/orchestrator/epoch-proving-state.ts +237 -111
  111. package/src/orchestrator/orchestrator.ts +653 -343
  112. package/src/orchestrator/orchestrator_metrics.ts +2 -6
  113. package/src/orchestrator/tx-proving-state.ts +48 -66
  114. package/src/prover-client/factory.ts +6 -2
  115. package/src/prover-client/prover-client.ts +41 -29
  116. package/src/prover-client/server-epoch-prover.ts +40 -22
  117. package/src/proving_broker/broker_prover_facade.ts +212 -131
  118. package/src/proving_broker/config.ts +34 -7
  119. package/src/proving_broker/factory.ts +2 -1
  120. package/src/proving_broker/fixtures.ts +8 -3
  121. package/src/proving_broker/proof_store/factory.ts +1 -1
  122. package/src/proving_broker/proof_store/gcs_proof_store.ts +5 -1
  123. package/src/proving_broker/proof_store/index.ts +1 -0
  124. package/src/proving_broker/proof_store/inline_proof_store.ts +1 -1
  125. package/src/proving_broker/proving_agent.ts +95 -66
  126. package/src/proving_broker/proving_broker.ts +57 -41
  127. package/src/proving_broker/proving_broker_database/memory.ts +3 -2
  128. package/src/proving_broker/proving_broker_database/persisted.ts +29 -13
  129. package/src/proving_broker/proving_broker_database.ts +2 -1
  130. package/src/proving_broker/proving_broker_instrumentation.ts +14 -35
  131. package/src/proving_broker/proving_job_controller.ts +100 -83
  132. package/src/proving_broker/rpc.ts +1 -6
  133. package/src/test/mock_proof_store.ts +14 -0
  134. package/src/test/mock_prover.ts +156 -64
  135. package/dest/bin/get-proof-inputs.d.ts +0 -2
  136. package/dest/bin/get-proof-inputs.d.ts.map +0 -1
  137. package/dest/bin/get-proof-inputs.js +0 -51
  138. package/dest/block_builder/index.d.ts +0 -6
  139. package/dest/block_builder/index.d.ts.map +0 -1
  140. package/dest/block_builder/index.js +0 -1
  141. package/dest/block_builder/light.d.ts +0 -33
  142. package/dest/block_builder/light.d.ts.map +0 -1
  143. package/dest/block_builder/light.js +0 -82
  144. package/dest/proving_broker/proving_agent_instrumentation.d.ts +0 -8
  145. package/dest/proving_broker/proving_agent_instrumentation.d.ts.map +0 -1
  146. package/dest/proving_broker/proving_agent_instrumentation.js +0 -16
  147. package/src/bin/get-proof-inputs.ts +0 -59
  148. package/src/block_builder/index.ts +0 -6
  149. package/src/block_builder/light.ts +0 -101
  150. package/src/proving_broker/proving_agent_instrumentation.ts +0 -21
@@ -1,4 +1,4 @@
1
- import { type Histogram, Metrics, type TelemetryClient, type Tracer, ValueType } from '@aztec/telemetry-client';
1
+ import { type Histogram, Metrics, type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
2
2
 
3
3
  export class ProvingOrchestratorMetrics {
4
4
  public readonly tracer: Tracer;
@@ -9,11 +9,7 @@ export class ProvingOrchestratorMetrics {
9
9
  this.tracer = client.getTracer(name);
10
10
  const meter = client.getMeter(name);
11
11
 
12
- this.baseRollupInputsDuration = meter.createHistogram(Metrics.PROVING_ORCHESTRATOR_BASE_ROLLUP_INPUTS_DURATION, {
13
- unit: 'ms',
14
- description: 'Duration to build base rollup inputs',
15
- valueType: ValueType.INT,
16
- });
12
+ this.baseRollupInputsDuration = meter.createHistogram(Metrics.PROVING_ORCHESTRATOR_BASE_ROLLUP_INPUTS_DURATION);
17
13
  }
18
14
 
19
15
  recordBaseRollupInputs(durationMs: number) {
@@ -1,22 +1,26 @@
1
- import { type AVM_PROOF_LENGTH_IN_FIELDS, AVM_VK_INDEX, type TUBE_PROOF_LENGTH, TUBE_VK_INDEX } from '@aztec/constants';
2
- import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
1
+ import { AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED, NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH } from '@aztec/constants';
2
+ import type { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { getVkData } from '@aztec/noir-protocol-circuits-types/server/vks';
3
4
  import type { AvmCircuitInputs } from '@aztec/stdlib/avm';
4
- import type { ProofAndVerificationKey } from '@aztec/stdlib/interfaces/server';
5
+ import type { PublicInputsAndRecursiveProof } from '@aztec/stdlib/interfaces/server';
6
+ import { ProofData, ProofDataForFixedVk, RecursiveProof } from '@aztec/stdlib/proofs';
5
7
  import {
6
- AvmProofData,
7
8
  type BaseRollupHints,
8
9
  PrivateBaseRollupHints,
9
- PrivateBaseRollupInputs,
10
- PrivateTubeData,
10
+ PrivateTxBaseRollupPrivateInputs,
11
11
  PublicBaseRollupHints,
12
- PublicBaseRollupInputs,
13
- PublicTubeData,
14
- TubeInputs,
12
+ PublicChonkVerifierPublicInputs,
13
+ PublicTxBaseRollupPrivateInputs,
15
14
  } from '@aztec/stdlib/rollup';
16
15
  import type { CircuitName } from '@aztec/stdlib/stats';
17
16
  import type { AppendOnlyTreeSnapshot, MerkleTreeId } from '@aztec/stdlib/trees';
18
17
  import type { ProcessedTx } from '@aztec/stdlib/tx';
19
- import { VkWitnessData } from '@aztec/stdlib/vks';
18
+
19
+ import {
20
+ getChonkProofFromTx,
21
+ getPublicChonkVerifierPrivateInputsFromTx,
22
+ toProofData,
23
+ } from './block-building-helpers.js';
20
24
 
21
25
  /**
22
26
  * Helper class to manage the proving cycle of a transaction
@@ -24,13 +28,17 @@ import { VkWitnessData } from '@aztec/stdlib/vks';
24
28
  * Also stores the inputs to the base rollup for this transaction and the tree snapshots
25
29
  */
26
30
  export class TxProvingState {
27
- private tube?: ProofAndVerificationKey<typeof TUBE_PROOF_LENGTH>;
28
- private avm?: ProofAndVerificationKey<typeof AVM_PROOF_LENGTH_IN_FIELDS>;
31
+ private publicChonkVerifier?: PublicInputsAndRecursiveProof<
32
+ PublicChonkVerifierPublicInputs,
33
+ typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH
34
+ >;
35
+ private avmProof?: RecursiveProof<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>;
29
36
 
30
37
  constructor(
31
38
  public readonly processedTx: ProcessedTx,
32
39
  private readonly baseRollupHints: BaseRollupHints,
33
40
  public readonly treeSnapshots: Map<MerkleTreeId, AppendOnlyTreeSnapshot>,
41
+ private readonly proverId: Fr,
34
42
  ) {}
35
43
 
36
44
  get requireAvmProof() {
@@ -38,102 +46,76 @@ export class TxProvingState {
38
46
  }
39
47
 
40
48
  public ready() {
41
- return !!this.tube && (!this.requireAvmProof || !!this.avm);
42
- }
43
-
44
- public getTubeInputs() {
45
- return new TubeInputs(this.processedTx.clientIvcProof);
49
+ return !this.requireAvmProof || (!!this.avmProof && !!this.publicChonkVerifier);
46
50
  }
47
51
 
48
52
  public getAvmInputs(): AvmCircuitInputs {
49
53
  return this.processedTx.avmProvingRequest!.inputs;
50
54
  }
51
55
 
56
+ public getPublicChonkVerifierPrivateInputs() {
57
+ return getPublicChonkVerifierPrivateInputsFromTx(this.processedTx, this.proverId);
58
+ }
59
+
52
60
  public getBaseRollupTypeAndInputs() {
53
61
  if (this.requireAvmProof) {
54
62
  return {
55
- rollupType: 'public-base-rollup' satisfies CircuitName,
63
+ rollupType: 'rollup-tx-base-public' satisfies CircuitName,
56
64
  inputs: this.#getPublicBaseInputs(),
57
65
  };
58
66
  } else {
59
67
  return {
60
- rollupType: 'private-base-rollup' satisfies CircuitName,
68
+ rollupType: 'rollup-tx-base-private' satisfies CircuitName,
61
69
  inputs: this.#getPrivateBaseInputs(),
62
70
  };
63
71
  }
64
72
  }
65
73
 
66
- public setTubeProof(tubeProofAndVk: ProofAndVerificationKey<typeof TUBE_PROOF_LENGTH>) {
67
- this.tube = tubeProofAndVk;
74
+ public setPublicChonkVerifierProof(
75
+ publicChonkVerifierProofAndVk: PublicInputsAndRecursiveProof<
76
+ PublicChonkVerifierPublicInputs,
77
+ typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH
78
+ >,
79
+ ) {
80
+ this.publicChonkVerifier = publicChonkVerifierProofAndVk;
68
81
  }
69
82
 
70
- public setAvmProof(avmProofAndVk: ProofAndVerificationKey<typeof AVM_PROOF_LENGTH_IN_FIELDS>) {
71
- this.avm = avmProofAndVk;
83
+ public setAvmProof(avmProof: RecursiveProof<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>) {
84
+ this.avmProof = avmProof;
72
85
  }
73
86
 
74
87
  #getPrivateBaseInputs() {
75
- if (!this.tube) {
76
- throw new Error('Tx not ready for proving base rollup.');
88
+ if (!(this.baseRollupHints instanceof PrivateBaseRollupHints)) {
89
+ throw new Error('Mismatched base rollup hints, expected private base rollup hints');
77
90
  }
78
91
 
79
- const vkData = this.#getTubeVkData();
80
- const tubeData = new PrivateTubeData(
92
+ const privateTailProofData = new ProofData(
81
93
  this.processedTx.data.toPrivateToRollupKernelCircuitPublicInputs(),
82
- this.tube.proof,
83
- vkData,
94
+ getChonkProofFromTx(this.processedTx),
95
+ getVkData('HidingKernelToRollup'),
84
96
  );
85
97
 
86
- if (!(this.baseRollupHints instanceof PrivateBaseRollupHints)) {
87
- throw new Error('Mismatched base rollup hints, expected private base rollup hints');
88
- }
89
- return new PrivateBaseRollupInputs(tubeData, this.baseRollupHints);
98
+ return new PrivateTxBaseRollupPrivateInputs(privateTailProofData, this.baseRollupHints);
90
99
  }
91
100
 
92
101
  #getPublicBaseInputs() {
93
102
  if (!this.processedTx.avmProvingRequest) {
94
103
  throw new Error('Should create private base rollup for a tx not requiring avm proof.');
95
104
  }
96
- if (!this.tube) {
97
- throw new Error('Tx not ready for proving base rollup: tube proof undefined');
105
+ if (!this.publicChonkVerifier) {
106
+ throw new Error('Tx not ready for proving base rollup: public chonk verifier proof undefined');
98
107
  }
99
- if (!this.avm) {
108
+ if (!this.avmProof) {
100
109
  throw new Error('Tx not ready for proving base rollup: avm proof undefined');
101
110
  }
102
-
103
- const tubeData = new PublicTubeData(
104
- this.processedTx.data.toPrivateToPublicKernelCircuitPublicInputs(),
105
- this.tube.proof,
106
- this.#getTubeVkData(),
107
- );
108
-
109
- const avmProofData = new AvmProofData(
110
- this.processedTx.avmProvingRequest.inputs.publicInputs,
111
- this.avm.proof,
112
- this.#getAvmVkData(),
113
- );
114
-
115
111
  if (!(this.baseRollupHints instanceof PublicBaseRollupHints)) {
116
112
  throw new Error('Mismatched base rollup hints, expected public base rollup hints');
117
113
  }
118
114
 
119
- return new PublicBaseRollupInputs(tubeData, avmProofData, this.baseRollupHints);
120
- }
115
+ const publicChonkVerifierProofData = toProofData(this.publicChonkVerifier);
121
116
 
122
- #getTubeVkData() {
123
- let vkIndex = TUBE_VK_INDEX;
124
- try {
125
- vkIndex = getVKIndex(this.tube!.verificationKey);
126
- } catch (_ignored) {
127
- // TODO(#7410) The VK for the tube won't be in the tree for now, so we manually set it to the tube vk index
128
- }
129
- const vkPath = getVKSiblingPath(vkIndex);
130
-
131
- return new VkWitnessData(this.tube!.verificationKey, vkIndex, vkPath);
132
- }
117
+ const avmProofData = new ProofDataForFixedVk(this.processedTx.avmProvingRequest.inputs.publicInputs, this.avmProof);
133
118
 
134
- #getAvmVkData() {
135
- const vkIndex = AVM_VK_INDEX;
136
- const vkPath = getVKSiblingPath(vkIndex);
137
- return new VkWitnessData(this.avm!.verificationKey, AVM_VK_INDEX, vkPath);
119
+ return new PublicTxBaseRollupPrivateInputs(publicChonkVerifierProofData, avmProofData, this.baseRollupHints);
138
120
  }
139
121
  }
@@ -1,4 +1,8 @@
1
- import type { ForkMerkleTreeOperations, ProvingJobBroker } from '@aztec/stdlib/interfaces/server';
1
+ import type {
2
+ ForkMerkleTreeOperations,
3
+ ProvingJobBroker,
4
+ ReadonlyWorldStateAccess,
5
+ } from '@aztec/stdlib/interfaces/server';
2
6
  import { type TelemetryClient, getTelemetryClient } from '@aztec/telemetry-client';
3
7
 
4
8
  import type { ProverClientConfig } from '../config.js';
@@ -6,7 +10,7 @@ import { ProverClient } from './prover-client.js';
6
10
 
7
11
  export function createProverClient(
8
12
  config: ProverClientConfig,
9
- worldState: ForkMerkleTreeOperations,
13
+ worldState: ForkMerkleTreeOperations & ReadonlyWorldStateAccess,
10
14
  broker: ProvingJobBroker,
11
15
  telemetry: TelemetryClient = getTelemetryClient(),
12
16
  ) {
@@ -1,17 +1,19 @@
1
1
  import { type ACVMConfig, type BBConfig, BBNativeRollupProver, TestCircuitProver } from '@aztec/bb-prover';
2
2
  import { times } from '@aztec/foundation/collection';
3
- import { Fr } from '@aztec/foundation/fields';
4
- import { createLogger } from '@aztec/foundation/log';
3
+ import type { EthAddress } from '@aztec/foundation/eth-address';
4
+ import { type Logger, createLogger } from '@aztec/foundation/log';
5
5
  import { NativeACVMSimulator } from '@aztec/simulator/server';
6
- import type {
7
- ActualProverConfig,
8
- EpochProver,
9
- EpochProverManager,
10
- ForkMerkleTreeOperations,
11
- ProvingJobBroker,
12
- ProvingJobConsumer,
13
- ProvingJobProducer,
14
- ServerCircuitProver,
6
+ import {
7
+ type ActualProverConfig,
8
+ type EpochProver,
9
+ type EpochProverManager,
10
+ type ForkMerkleTreeOperations,
11
+ type ProvingJobBroker,
12
+ type ProvingJobConsumer,
13
+ type ProvingJobProducer,
14
+ type ReadonlyWorldStateAccess,
15
+ type ServerCircuitProver,
16
+ tryStop,
15
17
  } from '@aztec/stdlib/interfaces/server';
16
18
  import { type TelemetryClient, getTelemetryClient } from '@aztec/telemetry-client';
17
19
 
@@ -32,24 +34,38 @@ export class ProverClient implements EpochProverManager {
32
34
 
33
35
  private constructor(
34
36
  private config: ProverClientConfig,
35
- private worldState: ForkMerkleTreeOperations,
37
+ private worldState: ForkMerkleTreeOperations & ReadonlyWorldStateAccess,
36
38
  private orchestratorClient: ProvingJobProducer,
37
39
  private agentClient?: ProvingJobConsumer,
38
40
  private telemetry: TelemetryClient = getTelemetryClient(),
39
- private log = createLogger('prover-client:tx-prover'),
41
+ private log: Logger = createLogger('prover-client:tx-prover'),
40
42
  ) {
41
43
  this.proofStore = new InlineProofStore();
42
44
  this.failedProofStore = this.config.failedProofStore ? createProofStore(this.config.failedProofStore) : undefined;
43
45
  }
44
46
 
45
47
  public createEpochProver(): EpochProver {
46
- const facade = new BrokerCircuitProverFacade(this.orchestratorClient, this.proofStore, this.failedProofStore);
47
- const orchestrator = new ProvingOrchestrator(this.worldState, facade, this.config.proverId, this.telemetry);
48
+ const bindings = this.log.getBindings();
49
+ const facade = new BrokerCircuitProverFacade(
50
+ this.orchestratorClient,
51
+ this.proofStore,
52
+ this.failedProofStore,
53
+ undefined,
54
+ bindings,
55
+ );
56
+ const orchestrator = new ProvingOrchestrator(
57
+ this.worldState,
58
+ facade,
59
+ this.config.proverId,
60
+ this.config.cancelJobsOnStop,
61
+ this.telemetry,
62
+ bindings,
63
+ );
48
64
  return new ServerEpochProver(facade, orchestrator);
49
65
  }
50
66
 
51
- public getProverId(): Fr {
52
- return this.config.proverId ?? Fr.ZERO;
67
+ public getProverId(): EthAddress {
68
+ return this.config.proverId;
53
69
  }
54
70
 
55
71
  async updateProverConfig(config: Partial<ProverClientConfig>): Promise<void> {
@@ -87,6 +103,7 @@ export class ProverClient implements EpochProverManager {
87
103
  }
88
104
  this.running = false;
89
105
  await this.stopAgents();
106
+ await tryStop(this.orchestratorClient);
90
107
  }
91
108
 
92
109
  /**
@@ -97,7 +114,7 @@ export class ProverClient implements EpochProverManager {
97
114
  */
98
115
  public static async new(
99
116
  config: ProverClientConfig,
100
- worldState: ForkMerkleTreeOperations,
117
+ worldState: ForkMerkleTreeOperations & ReadonlyWorldStateAccess,
101
118
  broker: ProvingJobBroker,
102
119
  telemetry: TelemetryClient = getTelemetryClient(),
103
120
  ) {
@@ -125,17 +142,11 @@ export class ProverClient implements EpochProverManager {
125
142
 
126
143
  const proofStore = new InlineProofStore();
127
144
  const prover = await buildServerCircuitProver(this.config, this.telemetry);
145
+ const bindings = this.log.getBindings();
128
146
  this.agents = times(
129
147
  this.config.proverAgentCount,
130
148
  () =>
131
- new ProvingAgent(
132
- this.agentClient!,
133
- proofStore,
134
- prover,
135
- [],
136
- this.config.proverAgentPollIntervalMs,
137
- this.telemetry,
138
- ),
149
+ new ProvingAgent(this.agentClient!, proofStore, prover, [], this.config.proverAgentPollIntervalMs, bindings),
139
150
  );
140
151
 
141
152
  await Promise.all(this.agents.map(agent => agent.start()));
@@ -154,9 +165,10 @@ export function buildServerCircuitProver(
154
165
  return BBNativeRollupProver.new(config, telemetry);
155
166
  }
156
167
 
157
- const simulationProvider = config.acvmBinaryPath
158
- ? new NativeACVMSimulator(config.acvmWorkingDirectory, config.acvmBinaryPath)
168
+ const logger = createLogger('prover-client:acvm-native');
169
+ const simulator = config.acvmBinaryPath
170
+ ? new NativeACVMSimulator(config.acvmWorkingDirectory, config.acvmBinaryPath, undefined, logger)
159
171
  : undefined;
160
172
 
161
- return Promise.resolve(new TestCircuitProver(simulationProvider, config, telemetry));
173
+ return Promise.resolve(new TestCircuitProver(simulator, config, telemetry));
162
174
  }
@@ -1,49 +1,67 @@
1
- import type { Fr } from '@aztec/foundation/fields';
2
- import type { L2Block } from '@aztec/stdlib/block';
1
+ import type { BatchedBlob, FinalBlobBatchingChallenges } from '@aztec/blob-lib/types';
2
+ import { BlockNumber, EpochNumber } from '@aztec/foundation/branded-types';
3
+ import type { Fr } from '@aztec/foundation/curves/bn254';
4
+ import type { EthAddress } from '@aztec/stdlib/block';
3
5
  import type { EpochProver } from '@aztec/stdlib/interfaces/server';
4
6
  import type { Proof } from '@aztec/stdlib/proofs';
5
- import type { RootRollupPublicInputs } from '@aztec/stdlib/rollup';
6
- import type { BlockHeader, GlobalVariables, ProcessedTx, Tx } from '@aztec/stdlib/tx';
7
+ import type { CheckpointConstantData, RootRollupPublicInputs } from '@aztec/stdlib/rollup';
8
+ import type { BlockHeader, ProcessedTx, Tx } from '@aztec/stdlib/tx';
9
+ import type { UInt64 } from '@aztec/stdlib/types';
7
10
 
8
11
  import type { ProvingOrchestrator } from '../orchestrator/orchestrator.js';
9
12
  import type { BrokerCircuitProverFacade } from '../proving_broker/broker_prover_facade.js';
10
13
 
11
14
  /** Encapsulates the proving orchestrator and the broker facade */
12
15
  export class ServerEpochProver implements EpochProver {
13
- constructor(private facade: BrokerCircuitProverFacade, private orchestrator: ProvingOrchestrator) {}
16
+ constructor(
17
+ private facade: BrokerCircuitProverFacade,
18
+ private orchestrator: ProvingOrchestrator,
19
+ ) {}
14
20
 
15
- startNewEpoch(epochNumber: number, firstBlockNumber: number, totalNumBlocks: number): void {
16
- this.orchestrator.startNewEpoch(epochNumber, firstBlockNumber, totalNumBlocks);
21
+ startNewEpoch(
22
+ epochNumber: EpochNumber,
23
+ totalNumCheckpoints: number,
24
+ finalBlobBatchingChallenges: FinalBlobBatchingChallenges,
25
+ ): void {
26
+ this.orchestrator.startNewEpoch(epochNumber, totalNumCheckpoints, finalBlobBatchingChallenges);
17
27
  this.facade.start();
18
28
  }
19
- startTubeCircuits(txs: Tx[]): Promise<void> {
20
- return this.orchestrator.startTubeCircuits(txs);
29
+ startNewCheckpoint(
30
+ checkpointIndex: number,
31
+ constants: CheckpointConstantData,
32
+ l1ToL2Messages: Fr[],
33
+ totalNumBlocks: number,
34
+ headerOfLastBlockInPreviousCheckpoint: BlockHeader,
35
+ ): Promise<void> {
36
+ return this.orchestrator.startNewCheckpoint(
37
+ checkpointIndex,
38
+ constants,
39
+ l1ToL2Messages,
40
+ totalNumBlocks,
41
+ headerOfLastBlockInPreviousCheckpoint,
42
+ );
43
+ }
44
+ startChonkVerifierCircuits(txs: Tx[]): Promise<void> {
45
+ return this.orchestrator.startChonkVerifierCircuits(txs);
21
46
  }
22
- setBlockCompleted(blockNumber: number, expectedBlockHeader?: BlockHeader): Promise<L2Block> {
47
+ setBlockCompleted(blockNumber: BlockNumber, expectedBlockHeader?: BlockHeader): Promise<BlockHeader> {
23
48
  return this.orchestrator.setBlockCompleted(blockNumber, expectedBlockHeader);
24
49
  }
25
- finaliseEpoch(): Promise<{ publicInputs: RootRollupPublicInputs; proof: Proof }> {
26
- return this.orchestrator.finaliseEpoch();
50
+ finalizeEpoch(): Promise<{ publicInputs: RootRollupPublicInputs; proof: Proof; batchedBlobInputs: BatchedBlob }> {
51
+ return this.orchestrator.finalizeEpoch();
27
52
  }
28
53
  cancel(): void {
29
54
  this.orchestrator.cancel();
30
55
  }
31
- getProverId(): Fr {
56
+ getProverId(): EthAddress {
32
57
  return this.orchestrator.getProverId();
33
58
  }
34
- getBlock(index: number): L2Block {
35
- return this.orchestrator.getBlock(index);
36
- }
37
59
  async stop(): Promise<void> {
38
60
  await this.facade.stop();
39
61
  await this.orchestrator.stop();
40
62
  }
41
- startNewBlock(
42
- globalVariables: GlobalVariables,
43
- l1ToL2Messages: Fr[],
44
- previousBlockHeader: BlockHeader,
45
- ): Promise<void> {
46
- return this.orchestrator.startNewBlock(globalVariables, l1ToL2Messages, previousBlockHeader);
63
+ startNewBlock(blockNumber: BlockNumber, timestamp: UInt64, totalNumTxs: number): Promise<void> {
64
+ return this.orchestrator.startNewBlock(blockNumber, timestamp, totalNumTxs);
47
65
  }
48
66
  addTxs(txs: ProcessedTx[]): Promise<void> {
49
67
  return this.orchestrator.addTxs(txs);