diff --git a/yarn-project/pxe/src/database/kv_pxe_database.ts b/yarn-project/pxe/src/database/kv_pxe_database.ts index 280bc679fd7..08a0539bcd6 100644 --- a/yarn-project/pxe/src/database/kv_pxe_database.ts +++ b/yarn-project/pxe/src/database/kv_pxe_database.ts @@ -545,12 +545,12 @@ export class KVPxeDatabase implements PxeDatabase { return Promise.resolve(Array.from(this.#addresses).map(v => CompleteAddress.fromBuffer(v))); } - getSynchedBlockNumberForPublicKey(publicKey: Point): number | undefined { - return this.#syncedBlockPerPublicKey.get(publicKey.toString()); + getSynchedBlockNumberForAccount(account: AztecAddress): number | undefined { + return this.#syncedBlockPerPublicKey.get(account.toString()); } - setSynchedBlockNumberForPublicKey(publicKey: Point, blockNumber: number): Promise { - return this.#syncedBlockPerPublicKey.set(publicKey.toString(), blockNumber); + setSynchedBlockNumberForAccount(account: AztecAddress, blockNumber: number): Promise { + return this.#syncedBlockPerPublicKey.set(account.toString(), blockNumber); } async estimateSize(): Promise { diff --git a/yarn-project/pxe/src/database/pxe_database.ts b/yarn-project/pxe/src/database/pxe_database.ts index 0562f79bd6d..860b3d742a0 100644 --- a/yarn-project/pxe/src/database/pxe_database.ts +++ b/yarn-project/pxe/src/database/pxe_database.ts @@ -169,16 +169,16 @@ export interface PxeDatabase extends ContractArtifactDatabase, ContractInstanceD /** * Updates up to which block number we have processed notes for a given public key. - * @param publicKey - The public key to set the synched block number for. + * @param account - The account to set the synched block number for. * @param blockNumber - The block number to set. */ - setSynchedBlockNumberForPublicKey(publicKey: PublicKey, blockNumber: number): Promise; + setSynchedBlockNumberForAccount(account: AztecAddress, blockNumber: number): Promise; /** * Get the synched block number for a given public key. - * @param publicKey - The public key to get the synched block number for. + * @param account - The account to get the synched block number for. */ - getSynchedBlockNumberForPublicKey(publicKey: PublicKey): number | undefined; + getSynchedBlockNumberForAccount(account: AztecAddress): number | undefined; /** * Returns the estimated size in bytes of this db. diff --git a/yarn-project/pxe/src/note_processor/note_processor.ts b/yarn-project/pxe/src/note_processor/note_processor.ts index b3bfa94e53e..025a989a5ea 100644 --- a/yarn-project/pxe/src/note_processor/note_processor.ts +++ b/yarn-project/pxe/src/note_processor/note_processor.ts @@ -1,12 +1,6 @@ import { type AztecNode, L1NotePayload, type L2Block } from '@aztec/circuit-types'; import { type NoteProcessorStats } from '@aztec/circuit-types/stats'; -import { - type CompleteAddress, - INITIAL_L2_BLOCK_NUM, - MAX_NOTE_HASHES_PER_TX, - type PublicKey, - computeAddressSecret, -} from '@aztec/circuits.js'; +import { type CompleteAddress, computeAddressSecret, INITIAL_L2_BLOCK_NUM, MAX_NOTE_HASHES_PER_TX } from '@aztec/circuits.js'; import { type Fr } from '@aztec/foundation/fields'; import { type Logger, createDebugLogger } from '@aztec/foundation/log'; import { Timer } from '@aztec/foundation/timer'; @@ -54,10 +48,6 @@ export class NoteProcessor { private constructor( public readonly account: CompleteAddress, - /** The public counterpart to the secret key to be used in the decryption of incoming note logs. */ - private readonly ivpkM: PublicKey, - /** The public counterpart to the secret key to be used in the decryption of outgoing note logs. */ - private readonly ovpkM: PublicKey, private keyStore: KeyStore, private db: PxeDatabase, private node: AztecNode, @@ -66,7 +56,7 @@ export class NoteProcessor { private log: Logger, ) {} - public static async create( + public static create( account: CompleteAddress, keyStore: KeyStore, db: PxeDatabase, @@ -75,10 +65,7 @@ export class NoteProcessor { simulator = getAcirSimulator(db, node, keyStore), log = createDebugLogger('aztec:note_processor'), ) { - const ivpkM = await keyStore.getMasterIncomingViewingPublicKey(account.address); - const ovpkM = await keyStore.getMasterOutgoingViewingPublicKey(account.address); - - return new NoteProcessor(account, ivpkM, ovpkM, keyStore, db, node, startingBlock, simulator, log); + return new NoteProcessor(account, keyStore, db, node, startingBlock, simulator, log); } /** @@ -101,7 +88,7 @@ export class NoteProcessor { } private getSyncedToBlock(): number { - return this.db.getSynchedBlockNumberForPublicKey(this.ivpkM) ?? this.startingBlock - 1; + return this.db.getSynchedBlockNumberForAccount(this.account.address) ?? this.startingBlock - 1; } /** @@ -120,10 +107,10 @@ export class NoteProcessor { const deferredIncomingNotes: DeferredNoteDao[] = []; const deferredOutgoingNotes: DeferredNoteDao[] = []; - const ivskM = await this.keyStore.getMasterSecretKey(this.ivpkM); + const ivskM = await this.keyStore.getMasterSecretKey(this.account.publicKeys.masterIncomingViewingPublicKey); const addressSecret = computeAddressSecret(this.account.getPreaddress(), ivskM); - const ovskM = await this.keyStore.getMasterSecretKey(this.ovpkM); + const ovskM = await this.keyStore.getMasterSecretKey(this.account.publicKeys.masterOutgoingViewingPublicKey); // Iterate over both blocks and encrypted logs. for (const block of blocks) { @@ -168,8 +155,8 @@ export class NoteProcessor { const { incomingNote, outgoingNote, incomingDeferredNote, outgoingDeferredNote } = await produceNoteDaos( this.simulator, this.db, - incomingNotePayload ? this.ivpkM : undefined, - outgoingNotePayload ? this.ovpkM : undefined, + incomingNotePayload ? this.account.publicKeys.masterIncomingViewingPublicKey : undefined, + outgoingNotePayload ? this.account.publicKeys.masterOutgoingViewingPublicKey : undefined, payload!, txEffect.txHash, noteHashes, @@ -215,7 +202,7 @@ export class NoteProcessor { await this.processDeferredNotes(deferredIncomingNotes, deferredOutgoingNotes); const syncedToBlock = blocks[blocks.length - 1].number; - await this.db.setSynchedBlockNumberForPublicKey(this.ivpkM, syncedToBlock); + await this.db.setSynchedBlockNumberForAccount(this.account.address, syncedToBlock); this.log.debug(`Synched block ${syncedToBlock}`); } @@ -249,7 +236,7 @@ export class NoteProcessor { const nullifiers: Fr[] = blocksAndNotes.flatMap(b => b.block.body.txEffects.flatMap(txEffect => txEffect.nullifiers), ); - const removedNotes = await this.db.removeNullifiedNotes(nullifiers, this.ivpkM); + const removedNotes = await this.db.removeNullifiedNotes(nullifiers, this.account.publicKeys.masterIncomingViewingPublicKey); removedNotes.forEach(noteDao => { this.log.verbose( `Removed note for contract ${noteDao.contractAddress} at slot ${ @@ -319,8 +306,8 @@ export class NoteProcessor { } = deferredNote; const payload = new L1NotePayload(note, contractAddress, storageSlot, noteTypeId); - const isIncoming = publicKey.equals(this.ivpkM); - const isOutgoing = publicKey.equals(this.ovpkM); + const isIncoming = publicKey.equals(this.account.publicKeys.masterIncomingViewingPublicKey); + const isOutgoing = publicKey.equals(this.account.publicKeys.masterOutgoingViewingPublicKey); if (!isIncoming && !isOutgoing) { // The note does not belong to this note processor @@ -330,8 +317,8 @@ export class NoteProcessor { const { incomingNote, outgoingNote } = await produceNoteDaos( this.simulator, this.db, - isIncoming ? this.ivpkM : undefined, - isOutgoing ? this.ovpkM : undefined, + isIncoming ? this.account.publicKeys.masterIncomingViewingPublicKey : undefined, + isOutgoing ? this.account.publicKeys.masterOutgoingViewingPublicKey : undefined, payload, txHash, noteHashes,