From a062575d64dda2ef9d5ad0e00e82f8a1599a20be Mon Sep 17 00:00:00 2001 From: Sander Pick Date: Tue, 11 Jun 2024 15:59:59 -0700 Subject: [PATCH 1/3] acc: remove assert Signed-off-by: Sander Pick --- fendermint/actors/accumulator/src/actor.rs | 4 +- fendermint/actors/accumulator/src/shared.rs | 71 +++++++++++++++------ 2 files changed, 51 insertions(+), 24 deletions(-) diff --git a/fendermint/actors/accumulator/src/actor.rs b/fendermint/actors/accumulator/src/actor.rs index 20b67a8f..0a200697 100644 --- a/fendermint/actors/accumulator/src/actor.rs +++ b/fendermint/actors/accumulator/src/actor.rs @@ -22,7 +22,6 @@ pub struct Actor; impl Actor { fn constructor(rt: &impl Runtime, params: ConstructorParams) -> Result<(), ActorError> { rt.validate_immediate_caller_is(std::iter::once(&INIT_ACTOR_ADDR))?; - let state = State::new(rt.store(), params.creator, params.write_access).map_err(|e| { e.downcast_default( ExitCode::USR_ILLEGAL_STATE, @@ -34,7 +33,6 @@ impl Actor { fn push(rt: &impl Runtime, params: PushParams) -> Result { Self::ensure_write_allowed(rt)?; - rt.transaction(|st: &mut State, rt| { st.push(rt.store(), params.0).map_err(|e| { e.downcast_default(ExitCode::USR_ILLEGAL_STATE, "failed to push object") @@ -45,7 +43,7 @@ impl Actor { fn get_leaf_at(rt: &impl Runtime, index: u64) -> Result>, ActorError> { rt.validate_immediate_caller_accept_any()?; let st: State = rt.state()?; - st.get_obj(rt.store(), index) + st.get_leaf_at(rt.store(), index) .map_err(|e| e.downcast_default(ExitCode::USR_ILLEGAL_STATE, "failed to get leaf")) } diff --git a/fendermint/actors/accumulator/src/shared.rs b/fendermint/actors/accumulator/src/shared.rs index 58f02913..c2c6dd66 100644 --- a/fendermint/actors/accumulator/src/shared.rs +++ b/fendermint/actors/accumulator/src/shared.rs @@ -123,14 +123,14 @@ fn bag_peaks(peaks: &Amt) -> anyhow::Result { } /// Given the size of the MMR and an index into the MMR, returns a tuple where the first element -/// represents the path through the subtree that the leaf node lives in, and the second element -/// represents the index of the peak containing the subtree that the leaf node lives in. -fn path_for_eigen_root(leaf_index: u64, leaf_count: u64) -> (u64, u64) { +/// represents the path through the subtree that the leaf node lives in. +/// The second element represents the index of the peak containing the subtree that the leaf node +/// lives in. +fn path_for_eigen_root(leaf_index: u64, leaf_count: u64) -> anyhow::Result<(u64, u64)> { // Ensure `leaf_index` is within bounds. - assert!( - leaf_index < leaf_count, - "`leaf_index` must less than `leaf_count`" - ); + if leaf_index >= leaf_count { + return Err(anyhow::anyhow!("`leaf_index` must less than `leaf_count`")); + } // XOR turns matching bits into zeros and differing bits into ones, so to determine when // the two "paths" converge, we simply look for the most significant 1 bit... let diff = leaf_index ^ leaf_count; @@ -150,7 +150,7 @@ fn path_for_eigen_root(leaf_index: u64, leaf_count: u64) -> (u64, u64) { let local_offset = leaf_index & bitmask; // The local_index is the local_offset plus the merge_height for the local eigentree let local_path = local_offset + merge_height; - (local_path, eigen_index as u64) + Ok((local_path, eigen_index as u64)) } fn get_at( @@ -158,8 +158,8 @@ fn get_at( leaf_index: u64, leaf_count: u64, peaks: &Amt, -) -> anyhow::Result> { - let (path, eigen_index) = path_for_eigen_root(leaf_index, leaf_count); +) -> anyhow::Result { + let (path, eigen_index) = path_for_eigen_root(leaf_index, leaf_count)?; let cid = match peaks.get(eigen_index)? { Some(cid) => cid, None => { @@ -172,7 +172,7 @@ fn get_at( // Special case where eigentree has height of one if path == 1 { return match store.get_cbor::(cid)? { - Some(value) => Ok(Some(value)), + Some(value) => Ok(value), None => Err(anyhow::anyhow!("failed to get leaf for cid {}", cid)), }; } @@ -207,7 +207,11 @@ fn get_at( let bit = (path & 1) as usize; let cid = &pair[bit]; - store.get_cbor::(cid) + let leaf = match store.get_cbor::(cid)? { + Some(root) => root, + None => return Err(anyhow::anyhow!("failed to get leaf for cid {}", cid)), + }; + Ok(leaf) } /// The state represents an MMR with peaks stored in an AMT @@ -299,13 +303,17 @@ impl State { Ok(peaks) } - pub fn get_obj( + pub fn get_leaf_at( &self, store: &BS, index: u64, ) -> anyhow::Result> { let amt = Amt::::load(&self.peaks, store)?; - get_at::(store, index, self.leaf_count, &amt) + let leaf = match get_at::(store, index, self.leaf_count, &amt) { + Ok(leaf) => Some(leaf), + Err(_) => None, + }; + Ok(leaf) } } @@ -418,23 +426,41 @@ mod tests { state.push(&store, vec![0]).unwrap(); assert_eq!(state.peak_count(), 1); assert_eq!(state.leaf_count(), 1); - let item0 = state.get_obj::<_, Vec>(&store, 0u64).unwrap().unwrap(); + let item0 = state + .get_leaf_at::<_, Vec>(&store, 0u64) + .unwrap() + .unwrap(); assert_eq!(item0, vec![0]); state.push(&store, vec![1]).unwrap(); assert_eq!(state.peak_count(), 1); assert_eq!(state.leaf_count(), 2); - let item0 = state.get_obj::<_, Vec>(&store, 0u64).unwrap().unwrap(); - let item1 = state.get_obj::<_, Vec>(&store, 1u64).unwrap().unwrap(); + let item0 = state + .get_leaf_at::<_, Vec>(&store, 0u64) + .unwrap() + .unwrap(); + let item1 = state + .get_leaf_at::<_, Vec>(&store, 1u64) + .unwrap() + .unwrap(); assert_eq!(item0, vec![0]); assert_eq!(item1, vec![1]); state.push(&store, vec![2]).unwrap(); assert_eq!(state.peak_count(), 2); assert_eq!(state.leaf_count(), 3); - let item0 = state.get_obj::<_, Vec>(&store, 0u64).unwrap().unwrap(); - let item1 = state.get_obj::<_, Vec>(&store, 1u64).unwrap().unwrap(); - let item2 = state.get_obj::<_, Vec>(&store, 2u64).unwrap().unwrap(); + let item0 = state + .get_leaf_at::<_, Vec>(&store, 0u64) + .unwrap() + .unwrap(); + let item1 = state + .get_leaf_at::<_, Vec>(&store, 1u64) + .unwrap() + .unwrap(); + let item2 = state + .get_leaf_at::<_, Vec>(&store, 2u64) + .unwrap() + .unwrap(); assert_eq!(item0, vec![0]); assert_eq!(item1, vec![1]); assert_eq!(item2, vec![2]); @@ -451,7 +477,10 @@ mod tests { // As more items are added to the accumulator, ensure each item remains gettable at // each phase of the growth of the inner tree structures. for j in 0..i { - let item = state.get_obj::<_, Vec>(&store, j).unwrap().unwrap(); + let item = state + .get_leaf_at::<_, Vec>(&store, j) + .unwrap() + .unwrap(); assert_eq!(item, vec![j]); } } From bd537fe3c94c1707ed75401ddb6b0d19c5a71079 Mon Sep 17 00:00:00 2001 From: Sander Pick Date: Tue, 11 Jun 2024 16:43:35 -0700 Subject: [PATCH 2/3] infra: remove proxy wallet funding Signed-off-by: Sander Pick --- .../deploy_subnet_under_calibration_net/deploy.sh | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/scripts/deploy_subnet_under_calibration_net/deploy.sh b/scripts/deploy_subnet_under_calibration_net/deploy.sh index de49cc9e..66166b71 100644 --- a/scripts/deploy_subnet_under_calibration_net/deploy.sh +++ b/scripts/deploy_subnet_under_calibration_net/deploy.sh @@ -286,20 +286,6 @@ do child-validator done -# Step 8.4: Fund proxy wallet in the subnet -echo "$DASHES Fund proxy wallets in the subnet" -for i in {0..2} -do - proxy_key=$(cat ${IPC_CONFIG_FOLDER}/evm_keystore_proxy.json | jq .[$i].private_key | tr -d '"' | tr -d '\n') - proxy_address=$(cat ${IPC_CONFIG_FOLDER}/evm_keystore_proxy.json | jq .[$i].address | tr -d '"' | tr -d '\n') - ipc-cli wallet import --wallet-type evm --private-key ${proxy_key} - ipc-cli cross-msg fund --from ${proxy_address} --subnet ${subnet_id} 1 - out=${subnet_folder}/validator-${i}/validator-${i}/keys/proxy_key.sk - ipc-cli wallet export --wallet-type evm --address ${proxy_address} --fendermint | tr -d '\n' > ${out} - chmod 600 ${subnet_folder}/validator-${i}/validator-${i}/keys/proxy_key.sk - ipc-cli wallet remove --wallet-type evm --address ${proxy_address} -done - # Step 9: Test # Step 9.1: Test ETH API endpoint echo "$DASHES Test ETH API endpoints of validator nodes" From 2ba48022d934e118c72f5880e08fccab0d68dbc3 Mon Sep 17 00:00:00 2001 From: Sander Pick Date: Tue, 11 Jun 2024 20:46:28 -0700 Subject: [PATCH 3/3] infra: genesis cmd needs auth token Signed-off-by: Sander Pick --- infra/fendermint/scripts/subnet.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/infra/fendermint/scripts/subnet.toml b/infra/fendermint/scripts/subnet.toml index b47b44ea..1b9b6a41 100644 --- a/infra/fendermint/scripts/subnet.toml +++ b/infra/fendermint/scripts/subnet.toml @@ -172,7 +172,7 @@ script.pre = "mkdir -p ${BASE_DIR}/${NODE_NAME}/${KEYS_SUBDIR}; cp ${PRIVATE_KEY [tasks.subnet-fetch-genesis] extend = "fendermint-tool" -env = { "CMD" = "genesis --genesis-file /data/genesis.json ipc from-parent --subnet-id ${SUBNET_ID} -p ${PARENT_ENDPOINT} --parent-gateway ${PARENT_GATEWAY} --parent-registry ${PARENT_REGISTRY} --base-fee ${BASE_FEE} --power-scale ${POWER_SCALE}" } +env = { "CMD" = "genesis --genesis-file /data/genesis.json ipc from-parent --subnet-id ${SUBNET_ID} -p ${PARENT_ENDPOINT} --parent-auth-token ${PARENT_HTTP_AUTH_TOKEN} --parent-gateway ${PARENT_GATEWAY} --parent-registry ${PARENT_REGISTRY} --base-fee ${BASE_FEE} --power-scale ${POWER_SCALE}" } [tasks.subnet-genesis-set-eam-permissions] extend = "fendermint-tool"