@aztec/prover-client 0.66.0 → 0.67.1-devnet

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 (83) hide show
  1. package/dest/block_builder/light.d.ts +4 -3
  2. package/dest/block_builder/light.d.ts.map +1 -1
  3. package/dest/block_builder/light.js +30 -20
  4. package/dest/index.d.ts +0 -1
  5. package/dest/index.d.ts.map +1 -1
  6. package/dest/index.js +1 -2
  7. package/dest/mocks/fixtures.d.ts +3 -3
  8. package/dest/mocks/fixtures.d.ts.map +1 -1
  9. package/dest/mocks/fixtures.js +2 -2
  10. package/dest/mocks/test_context.d.ts +10 -9
  11. package/dest/mocks/test_context.d.ts.map +1 -1
  12. package/dest/mocks/test_context.js +24 -13
  13. package/dest/orchestrator/block-building-helpers.d.ts +10 -6
  14. package/dest/orchestrator/block-building-helpers.d.ts.map +1 -1
  15. package/dest/orchestrator/block-building-helpers.js +27 -16
  16. package/dest/orchestrator/block-proving-state.d.ts +6 -5
  17. package/dest/orchestrator/block-proving-state.d.ts.map +1 -1
  18. package/dest/orchestrator/block-proving-state.js +16 -8
  19. package/dest/orchestrator/epoch-proving-state.d.ts +1 -1
  20. package/dest/orchestrator/epoch-proving-state.d.ts.map +1 -1
  21. package/dest/orchestrator/epoch-proving-state.js +3 -3
  22. package/dest/orchestrator/orchestrator.d.ts +11 -8
  23. package/dest/orchestrator/orchestrator.d.ts.map +1 -1
  24. package/dest/orchestrator/orchestrator.js +94 -58
  25. package/dest/orchestrator/orchestrator_metrics.d.ts.map +1 -1
  26. package/dest/orchestrator/orchestrator_metrics.js +2 -5
  27. package/dest/prover-agent/memory-proving-queue.d.ts +2 -1
  28. package/dest/prover-agent/memory-proving-queue.d.ts.map +1 -1
  29. package/dest/prover-agent/memory-proving-queue.js +241 -224
  30. package/dest/prover-agent/prover-agent.d.ts +11 -2
  31. package/dest/prover-agent/prover-agent.d.ts.map +1 -1
  32. package/dest/prover-agent/prover-agent.js +187 -160
  33. package/dest/prover-client/prover-client.d.ts +2 -3
  34. package/dest/prover-client/prover-client.d.ts.map +1 -1
  35. package/dest/prover-client/prover-client.js +6 -9
  36. package/dest/proving_broker/broker_prover_facade.d.ts +26 -0
  37. package/dest/proving_broker/broker_prover_facade.d.ts.map +1 -0
  38. package/dest/proving_broker/broker_prover_facade.js +107 -0
  39. package/dest/proving_broker/proving_agent.d.ts +4 -3
  40. package/dest/proving_broker/proving_agent.d.ts.map +1 -1
  41. package/dest/proving_broker/proving_agent.js +74 -65
  42. package/dest/proving_broker/proving_broker.d.ts +27 -7
  43. package/dest/proving_broker/proving_broker.d.ts.map +1 -1
  44. package/dest/proving_broker/proving_broker.js +405 -258
  45. package/dest/proving_broker/proving_broker_database/persisted.d.ts.map +1 -1
  46. package/dest/proving_broker/proving_broker_database/persisted.js +4 -8
  47. package/dest/proving_broker/proving_broker_instrumentation.d.ts.map +1 -1
  48. package/dest/proving_broker/proving_broker_instrumentation.js +2 -8
  49. package/dest/proving_broker/proving_job_controller.d.ts +2 -1
  50. package/dest/proving_broker/proving_job_controller.d.ts.map +1 -1
  51. package/dest/proving_broker/proving_job_controller.js +15 -14
  52. package/dest/proving_broker/rpc.js +2 -2
  53. package/dest/test/mock_prover.d.ts +6 -6
  54. package/dest/test/mock_prover.d.ts.map +1 -1
  55. package/dest/test/mock_prover.js +5 -5
  56. package/package.json +18 -13
  57. package/src/block_builder/light.ts +31 -22
  58. package/src/index.ts +0 -1
  59. package/src/mocks/fixtures.ts +4 -4
  60. package/src/mocks/test_context.ts +39 -24
  61. package/src/orchestrator/block-building-helpers.ts +33 -20
  62. package/src/orchestrator/block-proving-state.ts +17 -6
  63. package/src/orchestrator/epoch-proving-state.ts +0 -2
  64. package/src/orchestrator/orchestrator.ts +111 -62
  65. package/src/orchestrator/orchestrator_metrics.ts +1 -11
  66. package/src/prover-agent/memory-proving-queue.ts +12 -7
  67. package/src/prover-agent/prover-agent.ts +67 -48
  68. package/src/prover-client/prover-client.ts +5 -12
  69. package/src/proving_broker/{caching_broker_facade.ts → broker_prover_facade.ts} +62 -85
  70. package/src/proving_broker/proving_agent.ts +74 -78
  71. package/src/proving_broker/proving_broker.ts +240 -73
  72. package/src/proving_broker/proving_broker_database/persisted.ts +2 -8
  73. package/src/proving_broker/proving_broker_instrumentation.ts +0 -7
  74. package/src/proving_broker/proving_job_controller.ts +13 -12
  75. package/src/proving_broker/rpc.ts +1 -1
  76. package/src/test/mock_prover.ts +7 -3
  77. package/dest/proving_broker/caching_broker_facade.d.ts +0 -30
  78. package/dest/proving_broker/caching_broker_facade.d.ts.map +0 -1
  79. package/dest/proving_broker/caching_broker_facade.js +0 -150
  80. package/dest/proving_broker/prover_cache/memory.d.ts +0 -9
  81. package/dest/proving_broker/prover_cache/memory.d.ts.map +0 -1
  82. package/dest/proving_broker/prover_cache/memory.js +0 -16
  83. package/src/proving_broker/prover_cache/memory.ts +0 -20
@@ -28,7 +28,7 @@ const GetProvingJobResponse = z.object({
28
28
  export const ProvingJobProducerSchema: ApiSchemaFor<ProvingJobProducer> = {
29
29
  enqueueProvingJob: z.function().args(ProvingJob).returns(z.void()),
30
30
  getProvingJobStatus: z.function().args(ProvingJobId).returns(ProvingJobStatus),
31
- removeAndCancelProvingJob: z.function().args(ProvingJobId).returns(z.void()),
31
+ cancelProvingJob: z.function().args(ProvingJobId).returns(z.void()),
32
32
  waitForJobToSettle: z.function().args(ProvingJobId).returns(ProvingJobSettledResult),
33
33
  };
34
34
 
@@ -58,8 +58,12 @@ export class TestBroker implements ProvingJobProducer {
58
58
  agentCount: number,
59
59
  prover: ServerCircuitProver,
60
60
  private proofStore: ProofStore = new InlineProofStore(),
61
+ agentPollInterval = 100,
61
62
  ) {
62
- this.agents = times(agentCount, () => new ProvingAgent(this.broker, proofStore, prover, new NoopTelemetryClient()));
63
+ this.agents = times(
64
+ agentCount,
65
+ () => new ProvingAgent(this.broker, proofStore, prover, new NoopTelemetryClient(), undefined, agentPollInterval),
66
+ );
63
67
  }
64
68
 
65
69
  public async start() {
@@ -82,8 +86,8 @@ export class TestBroker implements ProvingJobProducer {
82
86
  getProvingJobStatus(id: ProvingJobId): Promise<ProvingJobStatus> {
83
87
  return this.broker.getProvingJobStatus(id);
84
88
  }
85
- removeAndCancelProvingJob(id: ProvingJobId): Promise<void> {
86
- return this.broker.removeAndCancelProvingJob(id);
89
+ cancelProvingJob(id: string): Promise<void> {
90
+ return this.broker.cancelProvingJob(id);
87
91
  }
88
92
  waitForJobToSettle(id: ProvingJobId): Promise<ProvingJobSettledResult> {
89
93
  return this.broker.waitForJobToSettle(id);
@@ -1,30 +0,0 @@
1
- import { type ProofAndVerificationKey, type ProverCache, type ProvingJobProducer, type PublicInputsAndRecursiveProof, type ServerCircuitProver } from '@aztec/circuit-types';
2
- import { type AVM_PROOF_LENGTH_IN_FIELDS, type AvmCircuitInputs, type BaseOrMergeRollupPublicInputs, type BaseParityInputs, type BlockMergeRollupInputs, type BlockRootOrBlockMergePublicInputs, type BlockRootRollupInputs, type EmptyBlockRootRollupInputs, type KernelCircuitPublicInputs, type MergeRollupInputs, type NESTED_RECURSIVE_PROOF_LENGTH, type ParityPublicInputs, type PrivateBaseRollupInputs, type PrivateKernelEmptyInputData, type PublicBaseRollupInputs, type RECURSIVE_PROOF_LENGTH, type RootParityInputs, type RootRollupInputs, type RootRollupPublicInputs, type TUBE_PROOF_LENGTH, type TubeInputs } from '@aztec/circuits.js';
3
- import { type ProofStore } from './proof_store.js';
4
- /**
5
- * A facade around a job broker that generates stable job ids and caches results
6
- */
7
- export declare class CachingBrokerFacade implements ServerCircuitProver {
8
- private broker;
9
- private cache;
10
- private proofStore;
11
- private waitTimeoutMs;
12
- private pollIntervalMs;
13
- private log;
14
- constructor(broker: ProvingJobProducer, cache?: ProverCache, proofStore?: ProofStore, waitTimeoutMs?: number, pollIntervalMs?: number, log?: import("@aztec/foundation/log").Logger);
15
- private enqueueAndWaitForJob;
16
- getAvmProof(inputs: AvmCircuitInputs, signal?: AbortSignal, _blockNumber?: number): Promise<ProofAndVerificationKey<typeof AVM_PROOF_LENGTH_IN_FIELDS>>;
17
- getBaseParityProof(inputs: BaseParityInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<ParityPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
18
- getBlockMergeRollupProof(input: BlockMergeRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
19
- getBlockRootRollupProof(input: BlockRootRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
20
- getEmptyBlockRootRollupProof(input: EmptyBlockRootRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs>>;
21
- getEmptyPrivateKernelProof(inputs: PrivateKernelEmptyInputData, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<KernelCircuitPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
22
- getMergeRollupProof(input: MergeRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BaseOrMergeRollupPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
23
- getPrivateBaseRollupProof(baseRollupInput: PrivateBaseRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BaseOrMergeRollupPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
24
- getPublicBaseRollupProof(inputs: PublicBaseRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<BaseOrMergeRollupPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
25
- getRootParityProof(inputs: RootParityInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<ParityPublicInputs, typeof NESTED_RECURSIVE_PROOF_LENGTH>>;
26
- getRootRollupProof(input: RootRollupInputs, signal?: AbortSignal, _epochNumber?: number): Promise<PublicInputsAndRecursiveProof<RootRollupPublicInputs, typeof RECURSIVE_PROOF_LENGTH>>;
27
- getTubeProof(tubeInput: TubeInputs, signal?: AbortSignal, _epochNumber?: number): Promise<ProofAndVerificationKey<typeof TUBE_PROOF_LENGTH>>;
28
- private generateId;
29
- }
30
- //# sourceMappingURL=caching_broker_facade.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"caching_broker_facade.d.ts","sourceRoot":"","sources":["../../src/proving_broker/caching_broker_facade.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,uBAAuB,EAC5B,KAAK,WAAW,EAGhB,KAAK,kBAAkB,EAGvB,KAAK,6BAA6B,EAClC,KAAK,mBAAmB,EACzB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,KAAK,0BAA0B,EAC/B,KAAK,gBAAgB,EACrB,KAAK,6BAA6B,EAClC,KAAK,gBAAgB,EACrB,KAAK,sBAAsB,EAC3B,KAAK,iCAAiC,EACtC,KAAK,qBAAqB,EAC1B,KAAK,0BAA0B,EAC/B,KAAK,yBAAyB,EAC9B,KAAK,iBAAiB,EACtB,KAAK,6BAA6B,EAClC,KAAK,kBAAkB,EACvB,KAAK,uBAAuB,EAC5B,KAAK,2BAA2B,EAChC,KAAK,sBAAsB,EAC3B,KAAK,sBAAsB,EAC3B,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACrB,KAAK,sBAAsB,EAC3B,KAAK,iBAAiB,EACtB,KAAK,UAAU,EAChB,MAAM,oBAAoB,CAAC;AAK5B,OAAO,EAAoB,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAMrE;;GAEG;AACH,qBAAa,mBAAoB,YAAW,mBAAmB;IAE3D,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,GAAG;gBALH,MAAM,EAAE,kBAAkB,EAC1B,KAAK,GAAE,WAAuC,EAC9C,UAAU,GAAE,UAAmC,EAC/C,aAAa,SAAc,EAC3B,cAAc,SAAO,EACrB,GAAG,yCAAiE;YAGhE,oBAAoB;IA+FlC,WAAW,CACT,MAAM,EAAE,gBAAgB,EACxB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,uBAAuB,CAAC,OAAO,0BAA0B,CAAC,CAAC;IAStE,kBAAkB,CAChB,MAAM,EAAE,gBAAgB,EACxB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,kBAAkB,EAAE,OAAO,sBAAsB,CAAC,CAAC;IAS5F,wBAAwB,CACtB,KAAK,EAAE,sBAAsB,EAC7B,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,iCAAiC,EAAE,OAAO,sBAAsB,CAAC,CAAC;IAS3G,uBAAuB,CACrB,KAAK,EAAE,qBAAqB,EAC5B,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,iCAAiC,EAAE,OAAO,sBAAsB,CAAC,CAAC;IAS3G,4BAA4B,CAC1B,KAAK,EAAE,0BAA0B,EACjC,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,iCAAiC,CAAC,CAAC;IAS5E,0BAA0B,CACxB,MAAM,EAAE,2BAA2B,EACnC,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,yBAAyB,EAAE,OAAO,sBAAsB,CAAC,CAAC;IASnG,mBAAmB,CACjB,KAAK,EAAE,iBAAiB,EACxB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,6BAA6B,EAAE,OAAO,sBAAsB,CAAC,CAAC;IAQvG,yBAAyB,CACvB,eAAe,EAAE,uBAAuB,EACxC,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,6BAA6B,EAAE,OAAO,sBAAsB,CAAC,CAAC;IASvG,wBAAwB,CACtB,MAAM,EAAE,sBAAsB,EAC9B,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,6BAA6B,EAAE,OAAO,sBAAsB,CAAC,CAAC;IASvG,kBAAkB,CAChB,MAAM,EAAE,gBAAgB,EACxB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,kBAAkB,EAAE,OAAO,6BAA6B,CAAC,CAAC;IASnG,kBAAkB,CAChB,KAAK,EAAE,gBAAgB,EACvB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,6BAA6B,CAAC,sBAAsB,EAAE,OAAO,sBAAsB,CAAC,CAAC;IAShG,YAAY,CACV,SAAS,EAAE,UAAU,EACrB,MAAM,CAAC,EAAE,WAAW,EACpB,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,uBAAuB,CAAC,OAAO,iBAAiB,CAAC,CAAC;IAS7D,OAAO,CAAC,UAAU;CAInB"}
@@ -1,150 +0,0 @@
1
- import { ProvingRequestType, } from '@aztec/circuit-types';
2
- import { sha256 } from '@aztec/foundation/crypto';
3
- import { createDebugLogger } from '@aztec/foundation/log';
4
- import { retryUntil } from '@aztec/foundation/retry';
5
- import { InlineProofStore } from './proof_store.js';
6
- import { InMemoryProverCache } from './prover_cache/memory.js';
7
- // 20 minutes, roughly the length of an Aztec epoch. If a proof isn't ready in this amount of time then we've failed to prove the whole epoch
8
- const MAX_WAIT_MS = 1200000;
9
- /**
10
- * A facade around a job broker that generates stable job ids and caches results
11
- */
12
- export class CachingBrokerFacade {
13
- constructor(broker, cache = new InMemoryProverCache(), proofStore = new InlineProofStore(), waitTimeoutMs = MAX_WAIT_MS, pollIntervalMs = 1000, log = createDebugLogger('aztec:prover-client:caching-prover-broker')) {
14
- this.broker = broker;
15
- this.cache = cache;
16
- this.proofStore = proofStore;
17
- this.waitTimeoutMs = waitTimeoutMs;
18
- this.pollIntervalMs = pollIntervalMs;
19
- this.log = log;
20
- }
21
- async enqueueAndWaitForJob(id, type, inputs, signal) {
22
- // first try the cache
23
- let jobEnqueued = false;
24
- try {
25
- const cachedResult = await this.cache.getProvingJobStatus(id);
26
- if (cachedResult.status !== 'not-found') {
27
- this.log.debug(`Found cached result for job=${id}: status=${cachedResult.status}`);
28
- }
29
- if (cachedResult.status === 'fulfilled') {
30
- const output = await this.proofStore.getProofOutput(cachedResult.value);
31
- if (output.type === type) {
32
- return output.result;
33
- }
34
- else {
35
- this.log.warn(`Cached result type mismatch for job=${id}. Expected=${type} but got=${output.type}`);
36
- }
37
- }
38
- else if (cachedResult.status === 'rejected') {
39
- // prefer returning a rejected promises so that we don't trigger the catch block below
40
- return Promise.reject(new Error(cachedResult.reason));
41
- }
42
- else if (cachedResult.status === 'in-progress' || cachedResult.status === 'in-queue') {
43
- jobEnqueued = true;
44
- }
45
- else {
46
- jobEnqueued = false;
47
- }
48
- }
49
- catch (err) {
50
- this.log.warn(`Failed to get cached proving job id=${id}: ${err}. Re-running job`);
51
- }
52
- if (!jobEnqueued) {
53
- try {
54
- const inputsUri = await this.proofStore.saveProofInput(id, type, inputs);
55
- await this.broker.enqueueProvingJob({
56
- id,
57
- type,
58
- inputsUri,
59
- });
60
- await this.cache.setProvingJobStatus(id, { status: 'in-queue' });
61
- }
62
- catch (err) {
63
- this.log.error(`Failed to enqueue proving job id=${id}: ${err}`);
64
- await this.cache.setProvingJobStatus(id, { status: 'not-found' });
65
- throw err;
66
- }
67
- }
68
- // notify broker of cancelled job
69
- const abortFn = async () => {
70
- signal?.removeEventListener('abort', abortFn);
71
- await this.broker.removeAndCancelProvingJob(id);
72
- };
73
- signal?.addEventListener('abort', abortFn);
74
- try {
75
- // loop here until the job settles
76
- // NOTE: this could also terminate because the job was cancelled through event listener above
77
- const result = await retryUntil(async () => {
78
- try {
79
- return await this.broker.waitForJobToSettle(id);
80
- }
81
- catch (err) {
82
- // waitForJobToSettle can only fail for network errors
83
- // keep retrying until we time out
84
- }
85
- }, `Proving job=${id} type=${ProvingRequestType[type]}`, this.waitTimeoutMs / 1000, this.pollIntervalMs / 1000);
86
- try {
87
- await this.cache.setProvingJobStatus(id, result);
88
- }
89
- catch (err) {
90
- this.log.warn(`Failed to cache proving job id=${id} resultStatus=${result.status}: ${err}`);
91
- }
92
- if (result.status === 'fulfilled') {
93
- const output = await this.proofStore.getProofOutput(result.value);
94
- if (output.type === type) {
95
- return output.result;
96
- }
97
- else {
98
- return Promise.reject(new Error(`Unexpected proof type: ${output.type}. Expected: ${type}`));
99
- }
100
- }
101
- else {
102
- return Promise.reject(new Error(result.reason));
103
- }
104
- }
105
- finally {
106
- signal?.removeEventListener('abort', abortFn);
107
- }
108
- }
109
- getAvmProof(inputs, signal, _blockNumber) {
110
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.PUBLIC_VM, inputs), ProvingRequestType.PUBLIC_VM, inputs, signal);
111
- }
112
- getBaseParityProof(inputs, signal, _epochNumber) {
113
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.BASE_PARITY, inputs), ProvingRequestType.BASE_PARITY, inputs, signal);
114
- }
115
- getBlockMergeRollupProof(input, signal, _epochNumber) {
116
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.BLOCK_MERGE_ROLLUP, input), ProvingRequestType.BLOCK_MERGE_ROLLUP, input, signal);
117
- }
118
- getBlockRootRollupProof(input, signal, _epochNumber) {
119
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.BLOCK_ROOT_ROLLUP, input), ProvingRequestType.BLOCK_ROOT_ROLLUP, input, signal);
120
- }
121
- getEmptyBlockRootRollupProof(input, signal, _epochNumber) {
122
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.EMPTY_BLOCK_ROOT_ROLLUP, input), ProvingRequestType.EMPTY_BLOCK_ROOT_ROLLUP, input, signal);
123
- }
124
- getEmptyPrivateKernelProof(inputs, signal, _epochNumber) {
125
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.PRIVATE_KERNEL_EMPTY, inputs), ProvingRequestType.PRIVATE_KERNEL_EMPTY, inputs, signal);
126
- }
127
- getMergeRollupProof(input, signal, _epochNumber) {
128
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.MERGE_ROLLUP, input), ProvingRequestType.MERGE_ROLLUP, input, signal);
129
- }
130
- getPrivateBaseRollupProof(baseRollupInput, signal, _epochNumber) {
131
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.PRIVATE_BASE_ROLLUP, baseRollupInput), ProvingRequestType.PRIVATE_BASE_ROLLUP, baseRollupInput, signal);
132
- }
133
- getPublicBaseRollupProof(inputs, signal, _epochNumber) {
134
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.PUBLIC_BASE_ROLLUP, inputs), ProvingRequestType.PUBLIC_BASE_ROLLUP, inputs, signal);
135
- }
136
- getRootParityProof(inputs, signal, _epochNumber) {
137
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.ROOT_PARITY, inputs), ProvingRequestType.ROOT_PARITY, inputs, signal);
138
- }
139
- getRootRollupProof(input, signal, _epochNumber) {
140
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.ROOT_ROLLUP, input), ProvingRequestType.ROOT_ROLLUP, input, signal);
141
- }
142
- getTubeProof(tubeInput, signal, _epochNumber) {
143
- return this.enqueueAndWaitForJob(this.generateId(ProvingRequestType.TUBE_PROOF, tubeInput), ProvingRequestType.TUBE_PROOF, tubeInput, signal);
144
- }
145
- generateId(type, inputs) {
146
- const inputsHash = sha256(inputs.toBuffer());
147
- return `${ProvingRequestType[type]}:${inputsHash.toString('hex')}`;
148
- }
149
- }
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"caching_broker_facade.js","sourceRoot":"","sources":["../../src/proving_broker/caching_broker_facade.ts"],"names":[],"mappings":"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"}
@@ -1,9 +0,0 @@
1
- import type { ProverCache, ProvingJobStatus } from '@aztec/circuit-types';
2
- export declare class InMemoryProverCache implements ProverCache {
3
- private proofs;
4
- constructor();
5
- setProvingJobStatus(jobId: string, status: ProvingJobStatus): Promise<void>;
6
- getProvingJobStatus(jobId: string): Promise<ProvingJobStatus>;
7
- close(): Promise<void>;
8
- }
9
- //# sourceMappingURL=memory.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../../src/proving_broker/prover_cache/memory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAE1E,qBAAa,mBAAoB,YAAW,WAAW;IACrD,OAAO,CAAC,MAAM,CAAwC;;IAItD,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAK3E,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAI7D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGvB"}
@@ -1,16 +0,0 @@
1
- export class InMemoryProverCache {
2
- constructor() {
3
- this.proofs = {};
4
- }
5
- setProvingJobStatus(jobId, status) {
6
- this.proofs[jobId] = status;
7
- return Promise.resolve();
8
- }
9
- getProvingJobStatus(jobId) {
10
- return Promise.resolve(this.proofs[jobId] ?? { status: 'not-found' });
11
- }
12
- close() {
13
- return Promise.resolve();
14
- }
15
- }
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVtb3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3ZpbmdfYnJva2VyL3Byb3Zlcl9jYWNoZS9tZW1vcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QjtRQUZRLFdBQU0sR0FBcUMsRUFBRSxDQUFDO0lBRXZDLENBQUM7SUFFaEIsbUJBQW1CLENBQUMsS0FBYSxFQUFFLE1BQXdCO1FBQ3pELElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsTUFBTSxDQUFDO1FBQzVCLE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxLQUFhO1FBQy9CLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVELEtBQUs7UUFDSCxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDO0NBQ0YifQ==
@@ -1,20 +0,0 @@
1
- import type { ProverCache, ProvingJobStatus } from '@aztec/circuit-types';
2
-
3
- export class InMemoryProverCache implements ProverCache {
4
- private proofs: Record<string, ProvingJobStatus> = {};
5
-
6
- constructor() {}
7
-
8
- setProvingJobStatus(jobId: string, status: ProvingJobStatus): Promise<void> {
9
- this.proofs[jobId] = status;
10
- return Promise.resolve();
11
- }
12
-
13
- getProvingJobStatus(jobId: string): Promise<ProvingJobStatus> {
14
- return Promise.resolve(this.proofs[jobId] ?? { status: 'not-found' });
15
- }
16
-
17
- close(): Promise<void> {
18
- return Promise.resolve();
19
- }
20
- }