Skip to content

Commit

Permalink
chore: Move jsdocs to interfaces (#1356)
Browse files Browse the repository at this point in the history
Our current eslint setup was enforcing all `public` methods in _classes_
to have a jsdoc, but not interfaces. As a result, most of our interfaces
(where we want to have docs the most) were undocumented, and the classes
that implement them carried the documentation instead.

This PR changes the eslint config so we enforce all interface methods to
have documentation. All classes that implement them automatically
inherit their docs (in vscode intellisense and in typedoc), so we don't
need to repeat the docs there and can clean those up. Unfortunately,
`require-jsdoc` cannot detect this automatically (see
gajus/eslint-plugin-jsdoc#768), so we tweak
the config so that jsdoc is not required for methods of classes that
implement an interface (not perfect, but good enough). This new esquery
filter required bumping the version of tslint.

Another issue with our config is that methods that are public by default
(ie without an accessibility modifier) do not have jsdoc enforced. I
tried enabling that but got 148 missing docs - so I'll leave that out
for now, and is commented in the eslintrc file.
  • Loading branch information
spalladino authored Aug 1, 2023
1 parent 0793d4a commit 7f7519d
Show file tree
Hide file tree
Showing 40 changed files with 698 additions and 580 deletions.
43 changes: 43 additions & 0 deletions yarn-project/acir-simulator/src/client/db_oracle.ts
Original file line number Diff line number Diff line change
Expand Up @@ -71,9 +71,52 @@ export interface CommitmentDataOracleInputs {
* The database oracle interface.
*/
export interface DBOracle extends CommitmentsDB {
/**
* Retrieve the public key associated to a given address.
* @param address - Address to fetch the pubkey for.
* @returns A public key and the corresponding partial contract address, such that the hash of the two resolves to the input address.
*/
getPublicKey(address: AztecAddress): Promise<[PublicKey, PartialContractAddress]>;

/**
* Retrieve the secret key associated with a specific public key.
* The function only allows access to the secret keys of the transaction creator,
* and throws an error if the address does not match the public key address of the key pair.
*
* @param contractAddress - The contract address. Ignored here. But we might want to return different keys for different contracts.
* @param pubKey - The public key of an account.
* @returns A Promise that resolves to the secret key as a Buffer.
* @throws An Error if the input address does not match the public key address of the key pair.
*/
getSecretKey(contractAddress: AztecAddress, pubKey: PublicKey): Promise<PrivateKey>;

/**
* Retrieves a set of notes stored in the database for a given contract address and storage slot.
* The query result is paginated using 'limit' and 'offset' values.
* Returns an object containing an array of note data, including preimage, nonce, and index for each note.
*
* @param contractAddress - The AztecAddress instance representing the contract address.
* @param storageSlot - The Fr instance representing the storage slot of the notes.
* @returns A Promise that resolves to an array of note data.
*/
getNotes(contractAddress: AztecAddress, storageSlot: Fr): Promise<NoteData[]>;

/**
* Retrieve the ABI information of a specific function within a contract.
* The function is identified by its selector, which is a unique identifier generated from the function signature.
*
* @param contractAddress - The contract address.
* @param functionSelector - The Buffer containing the function selector bytes.
* @returns A Promise that resolves to a FunctionAbi object containing the ABI information of the target function.
*/
getFunctionABI(contractAddress: AztecAddress, functionSelector: Buffer): Promise<FunctionAbi>;

/**
* Retrieves the portal contract address associated with the given contract address.
* Throws an error if the input contract address is not found or invalid.
*
* @param contractAddress - The address of the contract whose portal address is to be fetched.
* @returns A Promise that resolves to an EthAddress instance, representing the portal contract address.
*/
getPortalContractAddress(contractAddress: AztecAddress): Promise<EthAddress>;
}
19 changes: 19 additions & 0 deletions yarn-project/acir-simulator/src/public/db.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ export interface PublicStateDB {
* @param contract - Owner of the storage.
* @param slot - Slot to read in the contract storage.
* @param newValue - The new value to store.
* @returns Nothing.
*/
storageWrite(contract: AztecAddress, slot: Fr, newValue: Fr): Promise<void>;
}
Expand Down Expand Up @@ -55,7 +56,25 @@ export interface PublicContractsDB {

/** Database interface for providing access to commitment tree and l1 to l2 messages tree (append only data trees). */
export interface CommitmentsDB {
/**
* Gets a confirmed L1 to L2 message for the given message key.
* TODO(Maddiaa): Can be combined with aztec-node method that does the same thing.
* @param msgKey - The message Key.
* @returns - The l1 to l2 message object
*/
getL1ToL2Message(msgKey: Fr): Promise<MessageLoadOracleInputs>;

/**
* Gets a message index and sibling path to some commitment in the private data tree.
* @param address - The contract address owning storage.
* @param commitment - The preimage of the siloed data.
* @returns - The Commitment data oracle object
*/
getCommitmentOracle(address: AztecAddress, commitment: Fr): Promise<CommitmentDataOracleInputs>;

/**
* Gets the current tree roots from the merkle db.
* @returns current tree roots.
*/
getTreeRoots(): PrivateHistoricTreeRoots;
}
139 changes: 0 additions & 139 deletions yarn-project/aztec-rpc/src/aztec_rpc_server/aztec_rpc_server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,14 +86,6 @@ export class AztecRPCServer implements AztecRPC {
this.log.info('Stopped');
}

/**
* Registers an account backed by an account contract.
*
* @param privKey - Private key of the corresponding user master public key.
* @param address - Address of the account contract.
* @param partialContractAddress - The partially computed address of the account contract.
* @returns The address of the account contract.
*/
public async addAccount(privKey: PrivateKey, address: AztecAddress, partialContractAddress: PartialContractAddress) {
const pubKey = this.keyStore.addAccount(privKey);
// TODO(#1007): ECDSA contract breaks this check, since the ecdsa public key does not match the one derived from the keystore.
Expand All @@ -111,13 +103,6 @@ export class AztecRPCServer implements AztecRPC {
return address;
}

/**
* Adds public key and partial address to a database.
* @param address - Address of the account to add public key and partial address for.
* @param publicKey - Public key of the corresponding user.
* @param partialAddress - The partially computed address of the account contract.
* @returns A Promise that resolves once the public key has been added to the database.
*/
public async addPublicKeyAndPartialAddress(
address: AztecAddress,
publicKey: PublicKey,
Expand All @@ -127,13 +112,6 @@ export class AztecRPCServer implements AztecRPC {
this.log.info(`Added public key for ${address.toString()}`);
}

/**
* Add an array of deployed contracts to the database.
* Each contract should contain ABI, address, and portalContract information.
*
* @param contracts - An array of DeployedContract objects containing contract ABI, address, and portalContract.
* @returns A Promise that resolves once all the contracts have been added to the database.
*/
public async addContracts(contracts: DeployedContract[]) {
const contractDaos = contracts.map(c => toContractDao(c.abi, c.address, c.portalContract));
await Promise.all(contractDaos.map(c => this.db.addContract(c)));
Expand All @@ -144,23 +122,10 @@ export class AztecRPCServer implements AztecRPC {
}
}

/**
* Retrieves the list of Aztec addresses added to this rpc server
* The addresses are returned as a promise that resolves to an array of AztecAddress objects.
*
* @returns A promise that resolves to an array of AztecAddress instances.
*/
public async getAccounts(): Promise<AztecAddress[]> {
return await this.db.getAccounts();
}

/**
* Retrieve the public key associated with an address.
* Throws an error if the account is not found in the key store.
*
* @param address - The AztecAddress instance representing the account to get public key for.
* @returns A Promise resolving to the PublicKey instance representing the public key.
*/
public async getPublicKey(address: AztecAddress): Promise<PublicKey> {
const result = await this.db.getPublicKeyAndPartialAddress(address);
if (!result) {
Expand All @@ -169,13 +134,6 @@ export class AztecRPCServer implements AztecRPC {
return Promise.resolve(result[0]);
}

/**
* Retrieve the public key and partial contract address associated with an address.
* Throws an error if the account is not found in the key store.
*
* @param address - The AztecAddress instance representing the account to get public key and partial address for.
* @returns A Promise resolving to the PublicKey instance representing the public key.
*/
public async getPublicKeyAndPartialAddress(address: AztecAddress): Promise<[PublicKey, PartialContractAddress]> {
const result = await this.db.getPublicKeyAndPartialAddress(address);
if (!result) {
Expand All @@ -184,51 +142,22 @@ export class AztecRPCServer implements AztecRPC {
return Promise.resolve(result);
}

/**
* Retrieves the preimage data at a specified contract address and storage slot.
* The returned data is an array of note preimage items, with each item containing its value.
*
* @param contract - The AztecAddress of the target contract.
* @param storageSlot - The Fr representing the storage slot to be fetched.
* @returns A promise that resolves to an array of note preimage items, each containing its value.
*/
public async getPreimagesAt(contract: AztecAddress, storageSlot: Fr) {
const noteSpendingInfo = await this.db.getNoteSpendingInfo(contract, storageSlot);
return noteSpendingInfo.map(d => d.notePreimage.items.map(item => item.value));
}

/**
* Retrieves the public storage data at a specified contract address and storage slot.
* The returned data is data at the storage slot or throws an error if the contract is not deployed.
*
* @param contract - The AztecAddress of the target contract.
* @param storageSlot - The Fr representing the storage slot to be fetched.
* @returns A buffer containing the public storage data at the storage slot.
*/
public async getPublicStorageAt(contract: AztecAddress, storageSlot: Fr) {
if (!(await this.isContractDeployed(contract))) {
throw new Error(`Contract ${contract.toString()} is not deployed`);
}
return await this.node.getPublicStorageAt(contract, storageSlot.value);
}

/**
* Is an L2 contract deployed at this address?
* @param contractAddress - The contract data address.
* @returns Whether the contract was deployed.
*/
public async isContractDeployed(contractAddress: AztecAddress): Promise<boolean> {
return !!(await this.node.getContractInfo(contractAddress));
}

/**
* Create a transaction for a contract function call with the provided arguments.
* Throws an error if the contract or function is unknown.
*
* @param txRequest - An authenticated tx request ready for simulation
* @param optionalFromAddress - The address to simulate from
* @returns A Tx ready to send to the p2p pool for execution.
*/
public async simulateTx(txRequest: TxExecutionRequest) {
if (!txRequest.functionData.isPrivate) {
throw new Error(`Public entrypoints are not allowed`);
Expand Down Expand Up @@ -256,30 +185,13 @@ export class AztecRPCServer implements AztecRPC {
return tx;
}

/**
* Send a transaction.
* @param tx - The transaction.
* @returns A hash of the transaction, used to identify it.
*/
public async sendTx(tx: Tx): Promise<TxHash> {
const txHash = await tx.getTxHash();
this.log.info(`Sending transaction ${txHash}`);
await this.node.sendTx(tx);
return txHash;
}

/**
* Simulate the execution of a view (read-only) function on a deployed contract without actually modifying state.
* This is useful to inspect contract state, for example fetching a variable value or calling a getter function.
* The function takes function name and arguments as parameters, along with the contract address
* and optionally the sender's address.
*
* @param functionName - The name of the function to be called in the contract.
* @param args - The arguments to be provided to the function.
* @param to - The address of the contract to be called.
* @param from - (Optional) The caller of the transaction.
* @returns The result of the view function call, structured based on the function ABI.
*/
public async viewTx(functionName: string, args: any[], to: AztecAddress, from?: AztecAddress) {
const txRequest = await this.#getExecutionRequest(functionName, args, to, from ?? AztecAddress.ZERO);

Expand All @@ -289,11 +201,6 @@ export class AztecRPCServer implements AztecRPC {
return executionResult;
}

/**
* Fetches a transaction receipt for a tx.
* @param txHash - The transaction hash.
* @returns A receipt of the transaction.
*/
public async getTxReceipt(txHash: TxHash): Promise<TxReceipt> {
const localTx = await this.#getTxByHash(txHash);
const partialReceipt = new TxReceipt(
Expand Down Expand Up @@ -331,40 +238,18 @@ export class AztecRPCServer implements AztecRPC {
return partialReceipt;
}

/**
* Get latest L2 block number.
* @returns The latest block number.
*/
async getBlockNum(): Promise<number> {
return await this.node.getBlockHeight();
}

/**
* Lookup the L2 contract data for this contract.
* Contains the ethereum portal address and bytecode.
* @param contractAddress - The contract data address.
* @returns The complete contract data including portal address & bytecode (if we didn't throw an error).
*/
public async getContractData(contractAddress: AztecAddress): Promise<ContractPublicData | undefined> {
return await this.node.getContractData(contractAddress);
}

/**
* Lookup the L2 contract info for this contract.
* Contains the ethereum portal address .
* @param contractAddress - The contract data address.
* @returns The contract's address & portal address.
*/
public async getContractInfo(contractAddress: AztecAddress): Promise<ContractData | undefined> {
return await this.node.getContractInfo(contractAddress);
}

/**
* Gets L2 block unencrypted logs.
* @param from - Number of the L2 block to which corresponds the first unencrypted logs to be returned.
* @param take - The number of unencrypted logs to return.
* @returns The requested unencrypted logs.
*/
public async getUnencryptedLogs(from: number, take: number): Promise<L2BlockL2Logs[]> {
return await this.node.getLogs(from, take, LogType.UNENCRYPTED);
}
Expand Down Expand Up @@ -393,10 +278,6 @@ export class AztecRPCServer implements AztecRPC {
};
}

/**
* Returns the information about the server's node
* @returns - The node information.
*/
public async getNodeInfo(): Promise<NodeInfo> {
const [version, chainId] = await Promise.all([this.node.getVersion(), this.node.getChainId()]);

Expand Down Expand Up @@ -458,16 +339,6 @@ export class AztecRPCServer implements AztecRPC {
};
}

/**
* Simulate the execution of a transaction request.
* This function computes the expected state changes resulting from the transaction
* without actually submitting it to the blockchain. The result will be used for creating the kernel proofs,
* as well as for estimating gas costs.
*
* @param txRequest - The transaction request object containing the necessary data for simulation.
* @param contractDataOracle - Optional parameter, an instance of ContractDataOracle class for retrieving contract data.
* @returns A promise that resolves to an object containing the simulation results, including expected output notes and any error messages.
*/
async #simulate(txRequest: TxExecutionRequest, contractDataOracle?: ContractDataOracle) {
// TODO - Pause syncing while simulating.
if (!contractDataOracle) {
Expand Down Expand Up @@ -567,20 +438,10 @@ export class AztecRPCServer implements AztecRPC {
);
}

/**
* Return true if the top level block synchronisation is up to date
* This indicates that blocks and transactions are synched even if notes are not
* @returns True if there are no outstanding blocks to be synched
*/
public async isSynchronised() {
return await this.synchroniser.isSynchronised();
}

/**
* Returns true if the account specified by the given address is synched to the latest block
* @param account - The aztec address for which to query the sync status
* @returns True if the account is fully synched, false otherwise
*/
public async isAccountSynchronised(account: AztecAddress) {
return await this.synchroniser.isAccountSynchronised(account);
}
Expand Down
Loading

0 comments on commit 7f7519d

Please sign in to comment.