From d80dbbf26b2fab00666451cb63ce92aa6fb58da7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Bene=C5=A1?= Date: Tue, 26 Mar 2024 18:31:14 +0100 Subject: [PATCH] refactor: timestamp as u64 instead of a Field (#5453) Fixes #5446 --- l1-contracts/src/core/libraries/ConstantsGen.sol | 2 +- noir-projects/aztec-nr/aztec/src/context/avm_context.nr | 4 ++-- noir-projects/aztec-nr/aztec/src/context/interface.nr | 2 +- .../aztec-nr/aztec/src/context/public_context.nr | 2 +- noir-projects/aztec-nr/slow-updates-tree/src/slow_map.nr | 8 ++++---- .../contracts/avm_test_contract/src/main.nr | 2 +- .../noir-contracts/contracts/child_contract/src/main.nr | 2 +- .../contracts/crowdfunding_contract/src/main.nr | 2 +- .../noir-contracts/contracts/lending_contract/src/main.nr | 6 +++--- .../noir-contracts/contracts/test_contract/src/main.nr | 4 ++-- .../crates/types/src/abis/global_variables.nr | 6 +++--- .../noir-protocol-circuits/crates/types/src/constants.nr | 2 +- yarn-project/circuits.js/src/constants.gen.ts | 2 +- .../circuits.js/src/contract/artifact_hash.test.ts | 2 +- 14 files changed, 23 insertions(+), 23 deletions(-) diff --git a/l1-contracts/src/core/libraries/ConstantsGen.sol b/l1-contracts/src/core/libraries/ConstantsGen.sol index 965427c2099..1c31e002eb4 100644 --- a/l1-contracts/src/core/libraries/ConstantsGen.sol +++ b/l1-contracts/src/core/libraries/ConstantsGen.sol @@ -91,7 +91,7 @@ library Constants { uint256 internal constant DEPLOYER_CONTRACT_INSTANCE_DEPLOYED_MAGIC_VALUE = 0x85864497636cf755ae7bde03f267ce01a520981c21c3682aaf82a631; uint256 internal constant DEPLOYER_CONTRACT_ADDRESS = - 0x157b38eb13f082bd359153447e0b6a3e9af803585ec5cb83903faa04415d5d2e; + 0x1ad693effc2a4a40fdf5911ff29e19d2b6cd3cf73e6c3685519a6fb783144dcb; uint256 internal constant L1_TO_L2_MESSAGE_ORACLE_CALL_LENGTH = 17; uint256 internal constant MAX_NOTE_FIELDS_LENGTH = 20; uint256 internal constant GET_NOTE_ORACLE_RETURN_LENGTH = 23; diff --git a/noir-projects/aztec-nr/aztec/src/context/avm_context.nr b/noir-projects/aztec-nr/aztec/src/context/avm_context.nr index 68925164b65..34c3e964000 100644 --- a/noir-projects/aztec-nr/aztec/src/context/avm_context.nr +++ b/noir-projects/aztec-nr/aztec/src/context/avm_context.nr @@ -78,7 +78,7 @@ impl PublicContextInterface for AVMContext { block_number() } - fn timestamp(self) -> Field { + fn timestamp(self) -> u64 { timestamp() } @@ -238,7 +238,7 @@ fn version() -> Field {} fn block_number() -> Field {} #[oracle(avmOpcodeTimestamp)] -fn timestamp() -> Field {} +fn timestamp() -> u64 {} #[oracle(avmOpcodeNoteHashExists)] fn note_hash_exists(note_hash: Field, leaf_index: Field) -> u8 {} diff --git a/noir-projects/aztec-nr/aztec/src/context/interface.nr b/noir-projects/aztec-nr/aztec/src/context/interface.nr index cc18ffba570..c536ad02c08 100644 --- a/noir-projects/aztec-nr/aztec/src/context/interface.nr +++ b/noir-projects/aztec-nr/aztec/src/context/interface.nr @@ -21,7 +21,7 @@ trait ContextInterface { // If you are adding something here, then you should also implement it in the AVMContext. trait PublicContextInterface { fn block_number(self) -> Field; - fn timestamp(self) -> Field; + fn timestamp(self) -> u64; fn coinbase(self) -> EthAddress; fn fee_recipient(self) -> AztecAddress; fn push_nullifier_read_request(&mut self, nullifier: Field); diff --git a/noir-projects/aztec-nr/aztec/src/context/public_context.nr b/noir-projects/aztec-nr/aztec/src/context/public_context.nr index dfca49a3695..1d2789d9a2c 100644 --- a/noir-projects/aztec-nr/aztec/src/context/public_context.nr +++ b/noir-projects/aztec-nr/aztec/src/context/public_context.nr @@ -204,7 +204,7 @@ impl PublicContextInterface for PublicContext { self.inputs.public_global_variables.block_number } - fn timestamp(self) -> Field { + fn timestamp(self) -> u64 { self.inputs.public_global_variables.timestamp } diff --git a/noir-projects/aztec-nr/slow-updates-tree/src/slow_map.nr b/noir-projects/aztec-nr/slow-updates-tree/src/slow_map.nr index 641abcc16b4..ddfaf6bfa03 100644 --- a/noir-projects/aztec-nr/slow-updates-tree/src/slow_map.nr +++ b/noir-projects/aztec-nr/slow-updates-tree/src/slow_map.nr @@ -46,7 +46,7 @@ impl SlowMap { // Reads the "CURRENT" value of the root pub fn current_root(self: Self) -> Field { - let time = self.context.public.unwrap().timestamp() as u64; + let time = self.context.public.unwrap().timestamp(); let root_object = self.read_root(); if time <= root_object.next_change as u64 { root_object.before @@ -66,7 +66,7 @@ impl SlowMap { // docs:start:read_at // Reads the "CURRENT" value of the leaf pub fn read_at(self: Self, key: Field) -> Field { - let time = self.context.public.unwrap().timestamp() as u64; + let time = self.context.public.unwrap().timestamp(); let leaf = self.read_leaf_at(key); if time <= leaf.next_change as u64 { leaf.before @@ -87,7 +87,7 @@ impl SlowMap { // The calling function should ensure that the index is within the tree. // This must be done separately to ensure we are not constraining too tight here. - let time = self.context.public.unwrap().timestamp() as u64; + let time = self.context.public.unwrap().timestamp(); let next_change = compute_next_change(time as Field); let mut root = self.read_root(); @@ -132,7 +132,7 @@ impl SlowMap { // in public, limiting the cost of the update. pub fn update_unsafe_at(self: Self, index: Field, leaf_value: Field, new_root: Field) { // User must ensure that the checks from update_at is performed for safety - let time = self.context.public.unwrap().timestamp() as u64; + let time = self.context.public.unwrap().timestamp(); let next_change = compute_next_change(time as Field); let mut root = self.read_root(); diff --git a/noir-projects/noir-contracts/contracts/avm_test_contract/src/main.nr b/noir-projects/noir-contracts/contracts/avm_test_contract/src/main.nr index 96081c70768..f6f628e848e 100644 --- a/noir-projects/noir-contracts/contracts/avm_test_contract/src/main.nr +++ b/noir-projects/noir-contracts/contracts/avm_test_contract/src/main.nr @@ -223,7 +223,7 @@ contract AvmTest { } #[aztec(public-vm)] - fn get_timestamp() -> pub Field { + fn get_timestamp() -> pub u64 { context.timestamp() } diff --git a/noir-projects/noir-contracts/contracts/child_contract/src/main.nr b/noir-projects/noir-contracts/contracts/child_contract/src/main.nr index e9fdcc07ad8..0ba6c5946cf 100644 --- a/noir-projects/noir-contracts/contracts/child_contract/src/main.nr +++ b/noir-projects/noir-contracts/contracts/child_contract/src/main.nr @@ -33,7 +33,7 @@ contract Child { + context.chain_id() + context.version() + context.block_number() - + context.timestamp(); + + context.timestamp() as Field; return_value } diff --git a/noir-projects/noir-contracts/contracts/crowdfunding_contract/src/main.nr b/noir-projects/noir-contracts/contracts/crowdfunding_contract/src/main.nr index 010bd593b5e..a48a17e3da5 100644 --- a/noir-projects/noir-contracts/contracts/crowdfunding_contract/src/main.nr +++ b/noir-projects/noir-contracts/contracts/crowdfunding_contract/src/main.nr @@ -44,7 +44,7 @@ contract Crowdfunding { #[aztec(internal)] fn _check_deadline() { let deadline = storage.deadline.read(); - assert(context.timestamp() as u64 < deadline, "Deadline has passed"); + assert(context.timestamp() < deadline, "Deadline has passed"); } #[aztec(private)] diff --git a/noir-projects/noir-contracts/contracts/lending_contract/src/main.nr b/noir-projects/noir-contracts/contracts/lending_contract/src/main.nr index 63e568edacd..c43fbf2b3da 100644 --- a/noir-projects/noir-contracts/contracts/lending_contract/src/main.nr +++ b/noir-projects/noir-contracts/contracts/lending_contract/src/main.nr @@ -56,7 +56,7 @@ contract Lending { assert(asset.last_updated_ts == 0); assert(asset.interest_accumulator == U128::from_integer(0)); - let last_updated_ts = context.timestamp() as u64; + let last_updated_ts = context.timestamp(); asset_loc.write( Asset { interest_accumulator: U128::from_integer(1000000000), last_updated_ts, loan_to_value, oracle } @@ -72,7 +72,7 @@ contract Lending { let asset_loc = storage.assets.at(0); let mut asset = asset_loc.read(); - let timestamp = context.timestamp() as u64; + let timestamp = context.timestamp(); let dt = timestamp - asset.last_updated_ts; // Only update if time has passed. @@ -84,7 +84,7 @@ contract Lending { // accumulator *= multiplier, and multiplier >= 1 asset.interest_accumulator = (asset.interest_accumulator * multiplier) / precision; - asset.last_updated_ts = context.timestamp() as u64; + asset.last_updated_ts = context.timestamp(); asset_loc.write(asset); } diff --git a/noir-projects/noir-contracts/contracts/test_contract/src/main.nr b/noir-projects/noir-contracts/contracts/test_contract/src/main.nr index c4f81d0335b..ea921b20d1a 100644 --- a/noir-projects/noir-contracts/contracts/test_contract/src/main.nr +++ b/noir-projects/noir-contracts/contracts/test_contract/src/main.nr @@ -261,7 +261,7 @@ contract Test { // docs:start:is-time-equal #[aztec(public)] - fn is_time_equal(time: Field) -> Field { + fn is_time_equal(time: u64) -> u64 { assert(context.timestamp() == time); time } @@ -334,7 +334,7 @@ contract Test { chain_id: Field, version: Field, block_number: Field, - timestamp: Field, + timestamp: u64, coinbase: EthAddress, fee_recipient: AztecAddress ) { diff --git a/noir-projects/noir-protocol-circuits/crates/types/src/abis/global_variables.nr b/noir-projects/noir-protocol-circuits/crates/types/src/abis/global_variables.nr index 68097f779ee..d636c867a3a 100644 --- a/noir-projects/noir-protocol-circuits/crates/types/src/abis/global_variables.nr +++ b/noir-projects/noir-protocol-circuits/crates/types/src/abis/global_variables.nr @@ -10,7 +10,7 @@ struct GlobalVariables { chain_id : Field, version : Field, block_number : Field, - timestamp : Field, + timestamp : u64, coinbase : EthAddress, fee_recipient : AztecAddress, } @@ -22,7 +22,7 @@ impl Serialize for GlobalVariables { self.chain_id, self.version, self.block_number, - self.timestamp, + self.timestamp as Field, self.coinbase.to_field(), self.fee_recipient.to_field(), ] @@ -35,7 +35,7 @@ impl Deserialize for GlobalVariables { chain_id: serialized[0], version: serialized[1], block_number: serialized[2], - timestamp: serialized[3], + timestamp: serialized[3] as u64, coinbase: EthAddress::from_field(serialized[4]), fee_recipient: AztecAddress::from_field(serialized[5]), } diff --git a/noir-projects/noir-protocol-circuits/crates/types/src/constants.nr b/noir-projects/noir-protocol-circuits/crates/types/src/constants.nr index df98991baca..2fec9bce466 100644 --- a/noir-projects/noir-protocol-circuits/crates/types/src/constants.nr +++ b/noir-projects/noir-protocol-circuits/crates/types/src/constants.nr @@ -131,7 +131,7 @@ global REGISTERER_UNCONSTRAINED_FUNCTION_BROADCASTED_MAGIC_VALUE = 0xe7af8166354 // CONTRACT INSTANCE CONSTANTS // sha224sum 'struct ContractInstanceDeployed' global DEPLOYER_CONTRACT_INSTANCE_DEPLOYED_MAGIC_VALUE = 0x85864497636cf755ae7bde03f267ce01a520981c21c3682aaf82a631; -global DEPLOYER_CONTRACT_ADDRESS = 0x157b38eb13f082bd359153447e0b6a3e9af803585ec5cb83903faa04415d5d2e; +global DEPLOYER_CONTRACT_ADDRESS = 0x1ad693effc2a4a40fdf5911ff29e19d2b6cd3cf73e6c3685519a6fb783144dcb; // NOIR CONSTANTS - constants used only in yarn-packages/noir-contracts // Some are defined here because Noir doesn't yet support globals referencing other globals yet. diff --git a/yarn-project/circuits.js/src/constants.gen.ts b/yarn-project/circuits.js/src/constants.gen.ts index 08beb412d23..e2144817194 100644 --- a/yarn-project/circuits.js/src/constants.gen.ts +++ b/yarn-project/circuits.js/src/constants.gen.ts @@ -76,7 +76,7 @@ export const REGISTERER_UNCONSTRAINED_FUNCTION_BROADCASTED_MAGIC_VALUE = 0xe7af816635466f128568edb04c9fa024f6c87fb9010fdbffa68b3d99n; export const DEPLOYER_CONTRACT_INSTANCE_DEPLOYED_MAGIC_VALUE = 0x85864497636cf755ae7bde03f267ce01a520981c21c3682aaf82a631n; -export const DEPLOYER_CONTRACT_ADDRESS = 0x157b38eb13f082bd359153447e0b6a3e9af803585ec5cb83903faa04415d5d2en; +export const DEPLOYER_CONTRACT_ADDRESS = 0x1ad693effc2a4a40fdf5911ff29e19d2b6cd3cf73e6c3685519a6fb783144dcbn; export const L1_TO_L2_MESSAGE_ORACLE_CALL_LENGTH = 17; export const MAX_NOTE_FIELDS_LENGTH = 20; export const GET_NOTE_ORACLE_RETURN_LENGTH = 23; diff --git a/yarn-project/circuits.js/src/contract/artifact_hash.test.ts b/yarn-project/circuits.js/src/contract/artifact_hash.test.ts index 5b46e96ae4d..a2742bdef8a 100644 --- a/yarn-project/circuits.js/src/contract/artifact_hash.test.ts +++ b/yarn-project/circuits.js/src/contract/artifact_hash.test.ts @@ -5,7 +5,7 @@ describe('ArtifactHash', () => { it('calculates the artifact hash', () => { const artifact = getBenchmarkContractArtifact(); expect(computeArtifactHash(artifact).toString()).toMatchInlineSnapshot( - `"0x01016cb361c5694f739c0fc6143dd871ea2a8cd7a4ee69b090eac319ec2f18ac"`, + `"0x1c4308cf4acda970916ac5dd5ae32106bd782b17d2da4f50090ff5b77032ad02"`, ); }); });