From 41fc0f047a6412b824dc33b49cf8fd98c99598aa Mon Sep 17 00:00:00 2001 From: Maddiaa <47148561+Maddiaa0@users.noreply.github.com> Date: Sat, 14 Dec 2024 02:08:20 +0800 Subject: [PATCH] chore(prover): prover node should not gossip attestations (#10672) fixes: https://github.com/AztecProtocol/aztec-packages/issues/10668 --- .../aztec-node/src/aztec-node/server.ts | 10 +++- .../circuit-types/src/interfaces/p2p.ts | 27 +++++++---- .../circuit-types/src/p2p/client_type.ts | 6 +++ yarn-project/circuit-types/src/p2p/index.ts | 1 + .../circuit-types/src/p2p/topic_type.ts | 9 ++++ yarn-project/p2p/src/client/index.ts | 46 ++++++++++++++----- .../p2p/src/client/p2p_client.test.ts | 16 +++---- yarn-project/p2p/src/client/p2p_client.ts | 21 +++++---- yarn-project/p2p/src/mem_pools/interface.ts | 8 ++-- yarn-project/p2p/src/mocks/index.ts | 9 ++-- .../p2p/src/service/libp2p_service.ts | 20 ++++---- .../reqresp/reqresp.integration.test.ts | 17 ++++++- .../src/prover-coordination/factory.ts | 8 +++- .../prover-node/src/prover-node.test.ts | 17 +++---- yarn-project/prover-node/src/prover-node.ts | 3 +- 15 files changed, 150 insertions(+), 68 deletions(-) create mode 100644 yarn-project/circuit-types/src/p2p/client_type.ts diff --git a/yarn-project/aztec-node/src/aztec-node/server.ts b/yarn-project/aztec-node/src/aztec-node/server.ts index b7167253c20..dd29b991f0c 100644 --- a/yarn-project/aztec-node/src/aztec-node/server.ts +++ b/yarn-project/aztec-node/src/aztec-node/server.ts @@ -15,6 +15,7 @@ import { MerkleTreeId, NullifierMembershipWitness, type NullifierWithBlockSource, + P2PClientType, type ProcessedTx, type ProverConfig, PublicDataWitness, @@ -167,7 +168,14 @@ export class AztecNodeService implements AztecNode, Traceable { } // create the tx pool and the p2p client, which will need the l2 block source - const p2pClient = await createP2PClient(config, archiver, proofVerifier, worldStateSynchronizer, telemetry); + const p2pClient = await createP2PClient( + P2PClientType.Full, + config, + archiver, + proofVerifier, + worldStateSynchronizer, + telemetry, + ); // start both and wait for them to sync from the block source await Promise.all([p2pClient.start(), worldStateSynchronizer.start()]); diff --git a/yarn-project/circuit-types/src/interfaces/p2p.ts b/yarn-project/circuit-types/src/interfaces/p2p.ts index 00fa526899d..d2032f9d129 100644 --- a/yarn-project/circuit-types/src/interfaces/p2p.ts +++ b/yarn-project/circuit-types/src/interfaces/p2p.ts @@ -3,6 +3,7 @@ import { type ApiSchemaFor, optional, schemas } from '@aztec/foundation/schemas' import { z } from 'zod'; import { BlockAttestation } from '../p2p/block_attestation.js'; +import { type P2PClientType } from '../p2p/client_type.js'; import { EpochProofQuote } from '../prover_coordination/epoch_proof_quote.js'; import { Tx } from '../tx/tx.js'; @@ -24,16 +25,7 @@ const PeerInfoSchema = z.discriminatedUnion('status', [ ]); /** Exposed API to the P2P module. */ -export interface P2PApi { - /** - * Queries the Attestation pool for attestations for the given slot - * - * @param slot - the slot to query - * @param proposalId - the proposal id to query, or undefined to query all proposals for the slot - * @returns BlockAttestations - */ - getAttestationsForSlot(slot: bigint, proposalId?: string): Promise; - +export interface P2PApiWithoutAttestations { /** * Queries the EpochProofQuote pool for quotes for the given epoch * @@ -59,6 +51,21 @@ export interface P2PApi { getPeers(includePending?: boolean): Promise; } +export interface P2PClient extends P2PApiWithoutAttestations { + /** + * Queries the Attestation pool for attestations for the given slot + * + * @param slot - the slot to query + * @param proposalId - the proposal id to query, or undefined to query all proposals for the slot + * @returns BlockAttestations + */ + getAttestationsForSlot(slot: bigint, proposalId?: string): Promise; +} + +export type P2PApi = T extends P2PClientType.Full + ? P2PClient & P2PApiWithoutAttestations + : P2PApiWithoutAttestations; + export const P2PApiSchema: ApiSchemaFor = { getAttestationsForSlot: z .function() diff --git a/yarn-project/circuit-types/src/p2p/client_type.ts b/yarn-project/circuit-types/src/p2p/client_type.ts new file mode 100644 index 00000000000..75d1fea547c --- /dev/null +++ b/yarn-project/circuit-types/src/p2p/client_type.ts @@ -0,0 +1,6 @@ +export enum P2PClientType { + // Full p2p clients will subscribe to all gossip topics + Full, + // Prove p2p clients will only subscribe to transaction and proving topics + Prover, +} diff --git a/yarn-project/circuit-types/src/p2p/index.ts b/yarn-project/circuit-types/src/p2p/index.ts index 0974775870a..972988c8b7f 100644 --- a/yarn-project/circuit-types/src/p2p/index.ts +++ b/yarn-project/circuit-types/src/p2p/index.ts @@ -5,3 +5,4 @@ export * from './gossipable.js'; export * from './interface.js'; export * from './signature_utils.js'; export * from './topic_type.js'; +export * from './client_type.js'; diff --git a/yarn-project/circuit-types/src/p2p/topic_type.ts b/yarn-project/circuit-types/src/p2p/topic_type.ts index 8094905276c..db8d215a5ca 100644 --- a/yarn-project/circuit-types/src/p2p/topic_type.ts +++ b/yarn-project/circuit-types/src/p2p/topic_type.ts @@ -1,3 +1,5 @@ +import { P2PClientType } from './client_type.js'; + /** Create Topic String * * The topic channel identifier @@ -18,6 +20,13 @@ export enum TopicType { epoch_proof_quote = 'epoch_proof_quote', } +export function getTopicTypeForClientType(clientType: P2PClientType) { + if (clientType === P2PClientType.Full) { + return Object.values(TopicType); + } + return [TopicType.tx, TopicType.epoch_proof_quote]; +} + /** * Convert the topic string into a set of labels * diff --git a/yarn-project/p2p/src/client/index.ts b/yarn-project/p2p/src/client/index.ts index 509e5d51614..3e3d5de5ca3 100644 --- a/yarn-project/p2p/src/client/index.ts +++ b/yarn-project/p2p/src/client/index.ts @@ -1,4 +1,9 @@ -import type { ClientProtocolCircuitVerifier, L2BlockSource, WorldStateSynchronizer } from '@aztec/circuit-types'; +import { + type ClientProtocolCircuitVerifier, + type L2BlockSource, + P2PClientType, + type WorldStateSynchronizer, +} from '@aztec/circuit-types'; import { createLogger } from '@aztec/foundation/log'; import { type AztecKVStore } from '@aztec/kv-store'; import { type DataStoreConfig } from '@aztec/kv-store/config'; @@ -21,27 +26,35 @@ import { configureP2PClientAddresses, createLibP2PPeerIdFromPrivateKey, getPeerI export * from './p2p_client.js'; -export const createP2PClient = async ( +type P2PClientDeps = { + txPool?: TxPool; + store?: AztecKVStore; + attestationPool?: T extends P2PClientType.Full ? AttestationPool : undefined; + epochProofQuotePool?: EpochProofQuotePool; +}; + +export const createP2PClient = async ( + clientType: T, _config: P2PConfig & DataStoreConfig, l2BlockSource: L2BlockSource, proofVerifier: ClientProtocolCircuitVerifier, worldStateSynchronizer: WorldStateSynchronizer, telemetry: TelemetryClient = new NoopTelemetryClient(), - deps: { - txPool?: TxPool; - store?: AztecKVStore; - attestationPool?: AttestationPool; - epochProofQuotePool?: EpochProofQuotePool; - } = {}, + deps: P2PClientDeps = {}, ) => { let config = { ..._config }; const logger = createLogger('p2p'); const store = deps.store ?? (await createStore('p2p', config, createLogger('p2p:lmdb'))); - const mempools: MemPools = { + const mempools: MemPools = { txPool: deps.txPool ?? new AztecKVTxPool(store, telemetry), - attestationPool: deps.attestationPool ?? new InMemoryAttestationPool(telemetry), epochProofQuotePool: deps.epochProofQuotePool ?? new MemoryEpochProofQuotePool(telemetry), + attestationPool: + clientType === P2PClientType.Full + ? ((deps.attestationPool ?? new InMemoryAttestationPool(telemetry)) as T extends P2PClientType.Full + ? AttestationPool + : undefined) + : undefined, }; let p2pService; @@ -55,7 +68,8 @@ export const createP2PClient = async ( const peerId = await createLibP2PPeerIdFromPrivateKey(peerIdPrivateKey); const discoveryService = new DiscV5Service(peerId, config, telemetry); - p2pService = await LibP2PService.new( + p2pService = await LibP2PService.new( + clientType, config, discoveryService, peerId, @@ -70,5 +84,13 @@ export const createP2PClient = async ( logger.verbose('P2P is disabled. Using dummy P2P service'); p2pService = new DummyP2PService(); } - return new P2PClient(store, l2BlockSource, mempools, p2pService, config.keepProvenTxsInPoolFor, telemetry); + return new P2PClient( + clientType, + store, + l2BlockSource, + mempools, + p2pService, + config.keepProvenTxsInPoolFor, + telemetry, + ); }; diff --git a/yarn-project/p2p/src/client/p2p_client.test.ts b/yarn-project/p2p/src/client/p2p_client.test.ts index 5d926dec481..577a9228bcd 100644 --- a/yarn-project/p2p/src/client/p2p_client.test.ts +++ b/yarn-project/p2p/src/client/p2p_client.test.ts @@ -1,5 +1,5 @@ import { MockL2BlockSource } from '@aztec/archiver/test'; -import { L2Block, mockEpochProofQuote, mockTx } from '@aztec/circuit-types'; +import { L2Block, P2PClientType, mockEpochProofQuote, mockTx } from '@aztec/circuit-types'; import { Fr } from '@aztec/circuits.js'; import { retryUntil } from '@aztec/foundation/retry'; import { sleep } from '@aztec/foundation/sleep'; @@ -49,7 +49,7 @@ describe('In-Memory P2P Client', () => { }; kvStore = openTmpStore(); - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 0); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 0); }); const advanceToProvenBlock = async (getProvenBlockNumber: number, provenEpochNumber = getProvenBlockNumber) => { @@ -119,7 +119,7 @@ describe('In-Memory P2P Client', () => { await client.start(); await client.stop(); - const client2 = new P2PClient(kvStore, blockSource, mempools, p2pService, 0); + const client2 = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 0); expect(client2.getSyncedLatestBlockNum()).toEqual(client.getSyncedLatestBlockNum()); }); @@ -134,7 +134,7 @@ describe('In-Memory P2P Client', () => { }); it('deletes txs after waiting the set number of blocks', async () => { - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 10); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 10); blockSource.setProvenBlockNumber(0); await client.start(); expect(txPool.deleteTxs).not.toHaveBeenCalled(); @@ -151,7 +151,7 @@ describe('In-Memory P2P Client', () => { }); it('stores and returns epoch proof quotes', async () => { - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 0); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 0); blockSource.setProvenEpochNumber(2); await client.start(); @@ -182,7 +182,7 @@ describe('In-Memory P2P Client', () => { }); it('deletes expired proof quotes', async () => { - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 0); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 0); blockSource.setProvenEpochNumber(1); blockSource.setProvenBlockNumber(1); @@ -245,7 +245,7 @@ describe('In-Memory P2P Client', () => { }); it('deletes txs created from a pruned block', async () => { - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 10); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 10); blockSource.setProvenBlockNumber(0); await client.start(); @@ -267,7 +267,7 @@ describe('In-Memory P2P Client', () => { }); it('moves mined and valid txs back to the pending set', async () => { - client = new P2PClient(kvStore, blockSource, mempools, p2pService, 10); + client = new P2PClient(P2PClientType.Full, kvStore, blockSource, mempools, p2pService, 10); blockSource.setProvenBlockNumber(0); await client.start(); diff --git a/yarn-project/p2p/src/client/p2p_client.ts b/yarn-project/p2p/src/client/p2p_client.ts index eda78826d7a..d138e1e6ceb 100644 --- a/yarn-project/p2p/src/client/p2p_client.ts +++ b/yarn-project/p2p/src/client/p2p_client.ts @@ -8,6 +8,7 @@ import { type L2BlockStreamEvent, type L2Tips, type P2PApi, + type P2PClientType, type PeerInfo, type Tx, type TxHash, @@ -61,7 +62,7 @@ export interface P2PSyncState { /** * Interface of a P2P client. **/ -export interface P2P extends P2PApi { +export type P2P = P2PApi & { /** * Broadcasts a block proposal to other peers. * @@ -171,12 +172,15 @@ export interface P2P extends P2PApi { /** Identifies a p2p client. */ isP2PClient(): true; -} +}; /** * The P2P client implementation. */ -export class P2PClient extends WithTracer implements P2P { +export class P2PClient + extends WithTracer + implements P2P, P2P +{ /** Property that indicates whether the client is running. */ private stopping = false; @@ -194,7 +198,7 @@ export class P2PClient extends WithTracer implements P2P { private synchedProvenBlockNumber: AztecSingleton; private txPool: TxPool; - private attestationPool: AttestationPool; + private attestationPool: T extends P2PClientType.Full ? AttestationPool : undefined; private epochProofQuotePool: EpochProofQuotePool; /** How many slots to keep attestations for. */ @@ -212,9 +216,10 @@ export class P2PClient extends WithTracer implements P2P { * @param log - A logger. */ constructor( + clientType: T, store: AztecKVStore, private l2BlockSource: L2BlockSource, - mempools: MemPools, + mempools: MemPools, private p2pService: P2PService, private keepProvenTxsFor: number, telemetry: TelemetryClient = new NoopTelemetryClient(), @@ -238,8 +243,8 @@ export class P2PClient extends WithTracer implements P2P { this.synchedProvenBlockNumber = store.openSingleton('p2p_pool_last_proven_l2_block'); this.txPool = mempools.txPool; - this.attestationPool = mempools.attestationPool; this.epochProofQuotePool = mempools.epochProofQuotePool; + this.attestationPool = mempools.attestationPool!; } public isP2PClient(): true { @@ -406,7 +411,7 @@ export class P2PClient extends WithTracer implements P2P { } public getAttestationsForSlot(slot: bigint, proposalId: string): Promise { - return Promise.resolve(this.attestationPool.getAttestationsForSlot(slot, proposalId)); + return Promise.resolve(this.attestationPool?.getAttestationsForSlot(slot, proposalId) ?? []); } // REVIEW: https://github.com/AztecProtocol/aztec-packages/issues/7963 @@ -651,7 +656,7 @@ export class P2PClient extends WithTracer implements P2P { // We delete attestations older than the last block slot minus the number of slots we want to keep in the pool. const lastBlockSlotMinusKeepAttestationsInPoolFor = lastBlockSlot - BigInt(this.keepAttestationsInPoolFor); if (lastBlockSlotMinusKeepAttestationsInPoolFor >= BigInt(INITIAL_L2_BLOCK_NUM)) { - await this.attestationPool.deleteAttestationsOlderThan(lastBlockSlotMinusKeepAttestationsInPoolFor); + await this.attestationPool?.deleteAttestationsOlderThan(lastBlockSlotMinusKeepAttestationsInPoolFor); } await this.synchedProvenBlockNumber.set(lastBlockNum); diff --git a/yarn-project/p2p/src/mem_pools/interface.ts b/yarn-project/p2p/src/mem_pools/interface.ts index faf38e0638c..4db4c0fa899 100644 --- a/yarn-project/p2p/src/mem_pools/interface.ts +++ b/yarn-project/p2p/src/mem_pools/interface.ts @@ -1,3 +1,5 @@ +import { type P2PClientType } from '@aztec/circuit-types'; + import { type AttestationPool } from './attestation_pool/attestation_pool.js'; import { type EpochProofQuotePool } from './epoch_proof_quote_pool/epoch_proof_quote_pool.js'; import { type TxPool } from './tx_pool/tx_pool.js'; @@ -5,8 +7,8 @@ import { type TxPool } from './tx_pool/tx_pool.js'; /** * A interface the combines all mempools */ -export interface MemPools { +export type MemPools = { txPool: TxPool; - attestationPool: AttestationPool; + attestationPool?: T extends P2PClientType.Full ? AttestationPool : undefined; epochProofQuotePool: EpochProofQuotePool; -} +}; diff --git a/yarn-project/p2p/src/mocks/index.ts b/yarn-project/p2p/src/mocks/index.ts index d0524378806..bee6dc519fa 100644 --- a/yarn-project/p2p/src/mocks/index.ts +++ b/yarn-project/p2p/src/mocks/index.ts @@ -1,6 +1,7 @@ import { type ClientProtocolCircuitVerifier, type L2BlockSource, + type P2PClientType, type Tx, type WorldStateSynchronizer, } from '@aztec/circuit-types'; @@ -95,11 +96,12 @@ export async function createLibp2pNode( * * */ -export async function createTestLibP2PService( +export async function createTestLibP2PService( + clientType: T, boostrapAddrs: string[] = [], l2BlockSource: L2BlockSource, worldStateSynchronizer: WorldStateSynchronizer, - mempools: MemPools, + mempools: MemPools, telemetry: TelemetryClient, port: number = 0, peerId?: PeerId, @@ -123,7 +125,8 @@ export async function createTestLibP2PService( // No bootstrap nodes provided as the libp2p service will register them in the constructor const p2pNode = await createLibp2pNode([], peerId, port, /*enable gossip */ true, /**start */ false); - return new LibP2PService( + return new LibP2PService( + clientType, config, p2pNode as PubSubLibp2p, discoveryService, diff --git a/yarn-project/p2p/src/service/libp2p_service.ts b/yarn-project/p2p/src/service/libp2p_service.ts index 393bae440ec..a95d1368064 100644 --- a/yarn-project/p2p/src/service/libp2p_service.ts +++ b/yarn-project/p2p/src/service/libp2p_service.ts @@ -8,13 +8,14 @@ import { MerkleTreeId, type PeerInfo, type RawGossipMessage, - TopicType, TopicTypeMap, Tx, TxHash, type WorldStateSynchronizer, + getTopicTypeForClientType, metricsTopicStrToLabels, } from '@aztec/circuit-types'; +import { P2PClientType } from '@aztec/circuit-types'; import { Fr } from '@aztec/circuits.js'; import { createLogger } from '@aztec/foundation/log'; import { SerialQueue } from '@aztec/foundation/queue'; @@ -64,7 +65,7 @@ import type { P2PService, PeerDiscoveryService } from './service.js'; /** * Lib P2P implementation of the P2PService interface. */ -export class LibP2PService extends WithTracer implements P2PService { +export class LibP2PService extends WithTracer implements P2PService { private jobQueue: SerialQueue = new SerialQueue(); private peerManager: PeerManager; private discoveryRunningPromise?: RunningPromise; @@ -80,10 +81,11 @@ export class LibP2PService extends WithTracer implements P2PService { private blockReceivedCallback: (block: BlockProposal) => Promise; constructor( + private clientType: T, private config: P2PConfig, private node: PubSubLibp2p, private peerDiscoveryService: PeerDiscoveryService, - private mempools: MemPools, + private mempools: MemPools, private l2BlockSource: L2BlockSource, private proofVerifier: ClientProtocolCircuitVerifier, private worldStateSynchronizer: WorldStateSynchronizer, @@ -131,7 +133,7 @@ export class LibP2PService extends WithTracer implements P2PService { await this.node.start(); // Subscribe to standard GossipSub topics by default - for (const topic in TopicType) { + for (const topic of getTopicTypeForClientType(this.clientType)) { this.subscribeToTopic(TopicTypeMap[topic].p2pTopic); } @@ -188,11 +190,12 @@ export class LibP2PService extends WithTracer implements P2PService { * @param txPool - The transaction pool to be accessed by the service. * @returns The new service. */ - public static async new( + public static async new( + clientType: T, config: P2PConfig, peerDiscoveryService: PeerDiscoveryService, peerId: PeerId, - mempools: MemPools, + mempools: MemPools, l2BlockSource: L2BlockSource, proofVerifier: ClientProtocolCircuitVerifier, worldStateSynchronizer: WorldStateSynchronizer, @@ -301,6 +304,7 @@ export class LibP2PService extends WithTracer implements P2PService { }; return new LibP2PService( + clientType, config, node, peerDiscoveryService, @@ -383,7 +387,7 @@ export class LibP2PService extends WithTracer implements P2PService { const tx = Tx.fromBuffer(Buffer.from(message.data)); await this.processTxFromPeer(tx, peerId); } - if (message.topic === BlockAttestation.p2pTopic) { + if (message.topic === BlockAttestation.p2pTopic && this.clientType === P2PClientType.Full) { const attestation = BlockAttestation.fromBuffer(Buffer.from(message.data)); await this.processAttestationFromPeer(attestation); } @@ -412,7 +416,7 @@ export class LibP2PService extends WithTracer implements P2PService { })) private async processAttestationFromPeer(attestation: BlockAttestation): Promise { this.logger.debug(`Received attestation ${attestation.p2pMessageIdentifier()} from external peer.`); - await this.mempools.attestationPool.addAttestations([attestation]); + await this.mempools.attestationPool!.addAttestations([attestation]); } /**Process block from peer diff --git a/yarn-project/p2p/src/service/reqresp/reqresp.integration.test.ts b/yarn-project/p2p/src/service/reqresp/reqresp.integration.test.ts index 739da0d5a09..f6483ba9563 100644 --- a/yarn-project/p2p/src/service/reqresp/reqresp.integration.test.ts +++ b/yarn-project/p2p/src/service/reqresp/reqresp.integration.test.ts @@ -1,6 +1,11 @@ // An integration test for the p2p client to test req resp protocols import { MockL2BlockSource } from '@aztec/archiver/test'; -import { type ClientProtocolCircuitVerifier, type WorldStateSynchronizer, mockTx } from '@aztec/circuit-types'; +import { + type ClientProtocolCircuitVerifier, + P2PClientType, + type WorldStateSynchronizer, + mockTx, +} from '@aztec/circuit-types'; import { createLogger } from '@aztec/foundation/log'; import { sleep } from '@aztec/foundation/sleep'; import { type AztecKVStore } from '@aztec/kv-store'; @@ -148,7 +153,15 @@ describe('Req Resp p2p client integration', () => { epochProofQuotePool: epochProofQuotePool as unknown as EpochProofQuotePool, store: kvStore, }; - const client = await createP2PClient(config, l2BlockSource, proofVerifier, worldState, undefined, deps); + const client = await createP2PClient( + P2PClientType.Full, + config, + l2BlockSource, + proofVerifier, + worldState, + undefined, + deps, + ); await client.start(); clients.push(client); diff --git a/yarn-project/prover-node/src/prover-coordination/factory.ts b/yarn-project/prover-node/src/prover-coordination/factory.ts index e8e94f1153a..48194d44c47 100644 --- a/yarn-project/prover-node/src/prover-coordination/factory.ts +++ b/yarn-project/prover-node/src/prover-coordination/factory.ts @@ -1,6 +1,11 @@ import { type ArchiveSource, type Archiver } from '@aztec/archiver'; import { BBCircuitVerifier, TestCircuitVerifier } from '@aztec/bb-prover'; -import { type ProverCoordination, type WorldStateSynchronizer, createAztecNodeClient } from '@aztec/circuit-types'; +import { + P2PClientType, + type ProverCoordination, + type WorldStateSynchronizer, + createAztecNodeClient, +} from '@aztec/circuit-types'; import { createLogger } from '@aztec/foundation/log'; import { type DataStoreConfig } from '@aztec/kv-store/config'; import { createP2PClient } from '@aztec/p2p'; @@ -42,6 +47,7 @@ export async function createProverCoordination( const proofVerifier = config.realProofs ? await BBCircuitVerifier.new(config) : new TestCircuitVerifier(); const p2pClient = await createP2PClient( + P2PClientType.Prover, config, deps.archiver, proofVerifier, diff --git a/yarn-project/prover-node/src/prover-node.test.ts b/yarn-project/prover-node/src/prover-node.test.ts index 8d09f5174d3..c7b70d6136a 100644 --- a/yarn-project/prover-node/src/prover-node.test.ts +++ b/yarn-project/prover-node/src/prover-node.test.ts @@ -7,6 +7,7 @@ import { type L2Block, type L2BlockSource, type MerkleTreeWriteOperations, + P2PClientType, type ProverCache, type ProverCoordination, WorldStateRunningState, @@ -18,13 +19,7 @@ import { Signature } from '@aztec/foundation/eth-signature'; import { makeBackoff, retry } from '@aztec/foundation/retry'; import { sleep } from '@aztec/foundation/sleep'; import { openTmpStore } from '@aztec/kv-store/lmdb'; -import { - type BootstrapNode, - InMemoryAttestationPool, - InMemoryTxPool, - MemoryEpochProofQuotePool, - P2PClient, -} from '@aztec/p2p'; +import { type BootstrapNode, InMemoryTxPool, MemoryEpochProofQuotePool, P2PClient } from '@aztec/p2p'; import { createBootstrapNode, createTestLibP2PService } from '@aztec/p2p/mocks'; import { type L1Publisher } from '@aztec/sequencer-client'; import { type PublicProcessorFactory } from '@aztec/simulator'; @@ -299,16 +294,16 @@ describe('prover-node', () => { // - The prover node can get the it is missing via p2p, or it has them in it's mempool describe('Using a p2p coordination', () => { let bootnode: BootstrapNode; - let p2pClient: P2PClient; - let otherP2PClient: P2PClient; + let p2pClient: P2PClient; + let otherP2PClient: P2PClient; const createP2PClient = async (bootnodeAddr: string, port: number) => { const mempools = { txPool: new InMemoryTxPool(telemetryClient), - attestationPool: new InMemoryAttestationPool(telemetryClient), epochProofQuotePool: new MemoryEpochProofQuotePool(telemetryClient), }; const libp2pService = await createTestLibP2PService( + P2PClientType.Prover, [bootnodeAddr], l2BlockSource, worldState, @@ -317,7 +312,7 @@ describe('prover-node', () => { port, ); const kvStore = openTmpStore(); - return new P2PClient(kvStore, l2BlockSource, mempools, libp2pService, 0); + return new P2PClient(P2PClientType.Prover, kvStore, l2BlockSource, mempools, libp2pService, 0); }; beforeEach(async () => { diff --git a/yarn-project/prover-node/src/prover-node.ts b/yarn-project/prover-node/src/prover-node.ts index d70ce17bb87..ceabaf00e33 100644 --- a/yarn-project/prover-node/src/prover-node.ts +++ b/yarn-project/prover-node/src/prover-node.ts @@ -6,6 +6,7 @@ import { type L1ToL2MessageSource, type L2Block, type L2BlockSource, + type P2PClientType, type ProverCache, type ProverCoordination, type ProverNodeApi, @@ -80,7 +81,7 @@ export class ProverNode implements ClaimsMonitorHandler, EpochMonitorHandler, Pr } public getP2P() { - const asP2PClient = this.coordination as P2P; + const asP2PClient = this.coordination as P2P; if (typeof asP2PClient.isP2PClient === 'function' && asP2PClient.isP2PClient()) { return asP2PClient; }