Skip to content

Commit

Permalink
chore: Delete old serialization methods (#9951)
Browse files Browse the repository at this point in the history
Cleans up several toJSON and fromJSON methods that are no longer needed
since we moved to schemas. Also drops hex serialization for most complex
entities, such as circuit inputs and outputs, and replaces it with
base64.
  • Loading branch information
spalladino authored Nov 26, 2024
1 parent da265b6 commit 10d3f6f
Show file tree
Hide file tree
Showing 157 changed files with 1,054 additions and 1,308 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Body, type InBlock, L2Block, type TxEffect, type TxHash, TxReceipt } from '@aztec/circuit-types';
import { Body, type InBlock, L2Block, L2BlockHash, type TxEffect, type TxHash, TxReceipt } from '@aztec/circuit-types';
import { AppendOnlyTreeSnapshot, type AztecAddress, Header, INITIAL_L2_BLOCK_NUM } from '@aztec/circuits.js';
import { createDebugLogger } from '@aztec/foundation/log';
import { type AztecKVStore, type AztecMap, type AztecSingleton, type Range } from '@aztec/kv-store';
Expand Down Expand Up @@ -211,7 +211,7 @@ export class BlockStore {
TxReceipt.statusFromRevertCode(tx.revertCode),
'',
tx.transactionFee.toBigInt(),
block.data.hash().toBuffer(),
L2BlockHash.fromField(block.data.hash()),
block.data.number,
);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
type InBlock,
type InboxLeaf,
type L2Block,
L2BlockHash,
type L2BlockL2Logs,
type LogFilter,
LogId,
Expand Down Expand Up @@ -450,7 +451,7 @@ export class MemoryArchiverStore implements ArchiverDataStore {
TxReceipt.statusFromRevertCode(txEffect.revertCode),
'',
txEffect.transactionFee.toBigInt(),
block.data.hash().toBuffer(),
L2BlockHash.fromField(block.data.hash()),
block.data.number,
),
);
Expand Down
3 changes: 2 additions & 1 deletion yarn-project/archiver/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { jsonStringify } from '@aztec/foundation/json-rpc';
import { createDebugLogger } from '@aztec/foundation/log';
import { fileURLToPath } from '@aztec/foundation/url';
import { NoopTelemetryClient } from '@aztec/telemetry-client/noop';
Expand Down Expand Up @@ -25,7 +26,7 @@ async function main() {
const config = getArchiverConfigFromEnv();
const { l1RpcUrl: rpcUrl, l1Contracts } = config;

log.info(`Starting archiver in main(): ${JSON.stringify(config)}`);
log.info(`Starting archiver in main(): ${jsonStringify(config)}`);
const publicClient = createPublicClient({
chain: localhost,
transport: http(rpcUrl),
Expand Down
12 changes: 10 additions & 2 deletions yarn-project/archiver/src/test/mock_l2_block_source.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,12 @@
import { L2Block, type L2BlockSource, type L2Tips, type TxHash, TxReceipt, TxStatus } from '@aztec/circuit-types';
import {
L2Block,
L2BlockHash,
type L2BlockSource,
type L2Tips,
type TxHash,
TxReceipt,
TxStatus,
} from '@aztec/circuit-types';
import { EthAddress, type Header } from '@aztec/circuits.js';
import { DefaultL1ContractsConfig } from '@aztec/ethereum';
import { createDebugLogger } from '@aztec/foundation/log';
Expand Down Expand Up @@ -144,7 +152,7 @@ export class MockL2BlockSource implements L2BlockSource {
TxStatus.SUCCESS,
'',
txEffect.transactionFee.toBigInt(),
block.hash().toBuffer(),
L2BlockHash.fromField(block.hash()),
block.number,
),
);
Expand Down
2 changes: 2 additions & 0 deletions yarn-project/aztec-node/src/aztec-node/server.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -143,12 +143,14 @@ describe('aztec node', () => {
maxBlockNumber: new MaxBlockNumber(true, new Fr(1)),
getSize: () => 1,
toBuffer: () => Fr.ZERO.toBuffer(),
toString: () => Fr.ZERO.toString(),
};

validMaxBlockNumberMetadata.data.rollupValidationRequests = {
maxBlockNumber: new MaxBlockNumber(true, new Fr(5)),
getSize: () => 1,
toBuffer: () => Fr.ZERO.toBuffer(),
toString: () => Fr.ZERO.toString(),
};

lastBlockNumber = 3;
Expand Down
45 changes: 16 additions & 29 deletions yarn-project/aztec.js/src/rpc_clients/node/index.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
import { type PXE } from '@aztec/circuit-types';
import { jsonStringify } from '@aztec/foundation/json-rpc';
import { type DebugLogger } from '@aztec/foundation/log';
import { NoRetryError, makeBackoff, retry } from '@aztec/foundation/retry';

import axios, { type AxiosError, type AxiosResponse } from 'axios';
import { Axios, type AxiosError } from 'axios';
import { inspect } from 'util';

import { createPXEClient } from '../pxe_client.js';

Expand All @@ -15,34 +17,19 @@ import { createPXEClient } from '../pxe_client.js';
* @returns The response data.
*/
async function axiosFetch(host: string, rpcMethod: string, body: any, useApiEndpoints: boolean) {
let resp: AxiosResponse;
if (useApiEndpoints) {
resp = await axios
.post(`${host}/${rpcMethod}`, body, {
headers: { 'content-type': 'application/json' },
})
.catch((error: AxiosError) => {
if (error.response) {
return error.response;
}
throw error;
});
} else {
resp = await axios
.post(
host,
{ ...body, method: rpcMethod },
{
headers: { 'content-type': 'application/json' },
},
)
.catch((error: AxiosError) => {
if (error.response) {
return error.response;
}
throw error;
});
}
const request = new Axios({
headers: { 'content-type': 'application/json' },
transformRequest: [(data: any) => jsonStringify(data)],
transformResponse: [(data: any) => JSON.parse(data)],
});
const [url, content] = useApiEndpoints ? [`${host}/${rpcMethod}`, body] : [host, { ...body, method: rpcMethod }];
const resp = await request.post(url, content).catch((error: AxiosError) => {
if (error.response) {
return error.response;
}
const errorMessage = `Error fetching from host ${host} with method ${rpcMethod}: ${inspect(error)}`;
throw new Error(errorMessage);
});

const isOK = resp.status >= 200 && resp.status < 300;
if (isOK) {
Expand Down
3 changes: 2 additions & 1 deletion yarn-project/aztec/src/examples/util.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { EthAddress } from '@aztec/aztec.js';
import { jsonStringify } from '@aztec/foundation/json-rpc';

import type { Abi, Narrow } from 'abitype';
import { type Account, type Chain, type Hex, type HttpTransport, type PublicClient, type WalletClient } from 'viem';
Expand Down Expand Up @@ -28,7 +29,7 @@ export async function deployL1Contract(
const receipt = await publicClient.waitForTransactionReceipt({ hash });
const contractAddress = receipt.contractAddress;
if (!contractAddress) {
throw new Error(`No contract address found in receipt: ${JSON.stringify(receipt)}`);
throw new Error(`No contract address found in receipt: ${jsonStringify(receipt)}`);
}

return EthAddress.fromString(receipt.contractAddress!);
Expand Down
6 changes: 3 additions & 3 deletions yarn-project/bot/src/factory.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export class BotFactory {
this.log.info(`Initializing account at ${account.getAddress().toString()}`);
const sentTx = account.deploy();
const txHash = await sentTx.getTxHash();
this.log.info(`Sent tx with hash ${txHash.to0xString()}`);
this.log.info(`Sent tx with hash ${txHash.toString()}`);
if (this.config.flushSetupTransactions) {
this.log.verbose('Flushing transactions');
await this.node!.flushTxs();
Expand Down Expand Up @@ -117,7 +117,7 @@ export class BotFactory {
this.log.info(`Deploying token contract at ${address.toString()}`);
const sentTx = deploy.send(deployOpts);
const txHash = await sentTx.getTxHash();
this.log.info(`Sent tx with hash ${txHash.to0xString()}`);
this.log.info(`Sent tx with hash ${txHash.toString()}`);
if (this.config.flushSetupTransactions) {
this.log.verbose('Flushing transactions');
await this.node!.flushTxs();
Expand Down Expand Up @@ -164,7 +164,7 @@ export class BotFactory {
}
const sentTx = new BatchCall(token.wallet, calls).send();
const txHash = await sentTx.getTxHash();
this.log.info(`Sent tx with hash ${txHash.to0xString()}`);
this.log.info(`Sent tx with hash ${txHash.toString()}`);
if (this.config.flushSetupTransactions) {
this.log.verbose('Flushing transactions');
await this.node!.flushTxs();
Expand Down
6 changes: 3 additions & 3 deletions yarn-project/circuit-types/src/auth_witness.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { Vector } from '@aztec/circuits.js';
import { Fr } from '@aztec/foundation/fields';
import { hexSchemaFor } from '@aztec/foundation/schemas';
import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';

/**
* An authentication witness. Used to authorize an action by a user.
Expand Down Expand Up @@ -37,12 +38,11 @@ export class AuthWitness {
}

toString() {
return '0x' + this.toBuffer().toString('hex');
return bufferToHex(this.toBuffer());
}

static fromString(str: string) {
const hex = str.replace(/^0x/, '');
return AuthWitness.fromBuffer(Buffer.from(hex, 'hex'));
return AuthWitness.fromBuffer(hexToBuffer(str));
}

static random() {
Expand Down
7 changes: 2 additions & 5 deletions yarn-project/circuit-types/src/body.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { type ZodFor } from '@aztec/foundation/schemas';
import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
import { computeUnbalancedMerkleRoot } from '@aztec/foundation/trees';

Expand All @@ -21,18 +22,14 @@ export class Body {
});
}

static get schema() {
static get schema(): ZodFor<Body> {
return z
.object({
txEffects: z.array(TxEffect.schema),
})
.transform(({ txEffects }) => new Body(txEffects));
}

toJSON() {
return { txEffects: this.txEffects };
}

/**
* Serializes a block body
* @returns A serialized L2 block body.
Expand Down
16 changes: 0 additions & 16 deletions yarn-project/circuit-types/src/interfaces/nullifier_tree.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,20 +54,4 @@ export class NullifierMembershipWitness {
public toFields(): Fr[] {
return [new Fr(this.index), ...this.leafPreimage.toFields(), ...this.siblingPath.toFields()];
}

public toJSON() {
return {
index: '0x' + this.index.toString(16),
leafPreimage: this.leafPreimage.toJSON(),
siblingPath: this.siblingPath.toString(),
};
}

static fromJSON(json: any): NullifierMembershipWitness {
return new NullifierMembershipWitness(
BigInt(json.index),
NullifierLeafPreimage.fromJSON(json.leafPreimage),
SiblingPath.fromString<typeof NULLIFIER_TREE_HEIGHT>(json.siblingPath),
);
}
}
15 changes: 4 additions & 11 deletions yarn-project/circuit-types/src/l2_block.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { AppendOnlyTreeSnapshot, Header, STRING_ENCODING } from '@aztec/circuits.js';
import { AppendOnlyTreeSnapshot, Header } from '@aztec/circuits.js';
import { sha256, sha256ToField } from '@aztec/foundation/crypto';
import { Fr } from '@aztec/foundation/fields';
import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';

import { z } from 'zod';

Expand Down Expand Up @@ -31,14 +32,6 @@ export class L2Block {
.transform(({ archive, header, body }) => new L2Block(archive, header, body));
}

toJSON() {
return {
archive: this.archive,
header: this.header,
body: this.body,
};
}

/**
* Deserializes a block from a buffer
* @returns A deserialized L2 block.
Expand Down Expand Up @@ -66,15 +59,15 @@ export class L2Block {
* @returns Deserialized L2 block.
*/
static fromString(str: string): L2Block {
return L2Block.fromBuffer(Buffer.from(str, STRING_ENCODING));
return L2Block.fromBuffer(hexToBuffer(str));
}

/**
* Serializes a block to a string.
* @returns A serialized L2 block as a string.
*/
toString(): string {
return this.toBuffer().toString(STRING_ENCODING);
return bufferToHex(this.toBuffer());
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ describe('L2BlockStream', () => {

const makeBlock = (number: number) => ({ number } as L2Block);

const makeHeader = (number: number) => mock<Header>({ hash: () => new Fr(number) });
const makeHeader = (number: number) => mock<Header>({ hash: () => new Fr(number) } as Header);

const setRemoteTips = (latest_: number, proven?: number, finalized?: number) => {
proven = proven ?? 0;
Expand Down
15 changes: 1 addition & 14 deletions yarn-project/circuit-types/src/logs/encrypted_l2_log.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,23 +25,10 @@ export class EncryptedL2Log {

static get schema() {
return z
.object({ data: schemas.BufferHex, maskedContractAddress: schemas.Fr })
.object({ data: schemas.Buffer, maskedContractAddress: schemas.Fr })
.transform(({ data, maskedContractAddress }) => new EncryptedL2Log(data, maskedContractAddress));
}

/** Returns a JSON-friendly representation of the log. */
public toJSON(): object {
return {
data: this.data.toString('hex'),
maskedContractAddress: this.maskedContractAddress.toString(),
};
}

/** Converts a plain JSON object into an instance. */
public static fromJSON(obj: any) {
return new EncryptedL2Log(Buffer.from(obj.data, 'hex'), Fr.fromString(obj.maskedContractAddress));
}

/**
* Deserializes log from a buffer.
* @param buffer - The buffer containing the log.
Expand Down
14 changes: 1 addition & 13 deletions yarn-project/circuit-types/src/logs/encrypted_l2_note_log.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,20 +25,8 @@ export class EncryptedL2NoteLog {
return this.data;
}

/** Returns a JSON-friendly representation of the log. */
public toJSON(): object {
return { data: this.data.toString('hex') };
}

static get schema() {
return z
.object({ data: schemas.HexString })
.transform(({ data }) => new EncryptedL2NoteLog(Buffer.from(data, 'hex')));
}

/** Converts a plain JSON object into an instance. */
public static fromJSON(obj: any) {
return new EncryptedL2NoteLog(Buffer.from(obj.data, 'hex'));
return z.object({ data: schemas.Buffer }).transform(({ data }) => new EncryptedL2NoteLog(data));
}

/**
Expand Down
26 changes: 1 addition & 25 deletions yarn-project/circuit-types/src/logs/event_metadata.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { type AbiType, AbiTypeSchema, EventSelector, decodeFromAbi } from '@aztec/foundation/abi';
import { type AbiType, AbiTypeSchema, type EventSelector, decodeFromAbi } from '@aztec/foundation/abi';
import { Fr } from '@aztec/foundation/fields';
import { schemas } from '@aztec/foundation/schemas';

Expand Down Expand Up @@ -49,37 +49,13 @@ export class EventMetadata<T> {
};
}

/**
* Serializes the metadata to a JSON-friendly format
*/
public toJSON() {
return {
type: 'event_metadata', // TODO(palla/schemas): Remove this type property
eventSelector: this.eventSelector,
abiType: this.abiType,
fieldNames: this.fieldNames,
};
}

static get schema() {
return z
.object({
eventSelector: schemas.EventSelector,
abiType: AbiTypeSchema,
fieldNames: z.array(z.string()),
type: z.literal('event_metadata').optional(),
})
.transform(obj => new EventMetadata(obj));
}

/**
* Creates an EventMetadata instance from a JSON representation
*/
public static fromJSON(json: any): EventMetadata<any> {
return new EventMetadata({
eventSelector: EventSelector.fromString(json.eventSelector),
abiType: json.abiType,
fieldNames: json.fieldNames,
});
}
}
Loading

0 comments on commit 10d3f6f

Please sign in to comment.