Skip to content

Commit

Permalink
handle case where a node is added
Browse files Browse the repository at this point in the history
  • Loading branch information
adamspofford-dfinity committed Nov 16, 2023
1 parent 5aa3ba7 commit fddfa44
Showing 1 changed file with 37 additions and 23 deletions.
60 changes: 37 additions & 23 deletions ic-agent/src/agent/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -474,7 +474,7 @@ impl Agent {
request_id: RequestId,
) -> Result<Vec<u8>, AgentError> {
let response = if self.verify_query_signatures {
let (response, subnet) = futures_util::try_join!(
let (response, mut subnet) = futures_util::try_join!(
self.query_endpoint::<QueryResponse>(effective_canister_id, signed_query),
self.get_subnet_by_canister(&effective_canister_id)
)?;
Expand All @@ -494,10 +494,17 @@ impl Agent {
return Err(AgentError::CertificateOutdated(self.ingress_expiry));
}
let signable = response.signable(request_id, signature.timestamp);
let node_key = subnet
.node_keys
.get(&signature.identity)
.ok_or(AgentError::CertificateNotAuthorized())?;
let node_key = if let Some(node_key) = subnet.node_keys.get(&signature.identity) {
node_key
} else {
subnet = self
.fetch_subnet_by_canister(&effective_canister_id)
.await?;
subnet
.node_keys
.get(&signature.identity)
.ok_or(AgentError::CertificateNotAuthorized())?
};
if node_key.len() != 44 {
return Err(AgentError::DerKeyLengthMismatch {
expected: 44,
Expand Down Expand Up @@ -999,24 +1006,31 @@ impl Agent {
if let Some(subnet) = subnet {
Ok(subnet)
} else {
let cert = self
.read_state_raw(vec![vec!["subnet".into()]], *canister)
.await?;
let time = leb128::read::unsigned(&mut lookup_value(&cert.tree, [b"time".as_ref()])?)?;
if (OffsetDateTime::now_utc()
- OffsetDateTime::from_unix_timestamp_nanos(time as _).unwrap())
> self.ingress_expiry
{
Err(AgentError::CertificateOutdated(self.ingress_expiry))
} else {
let (subnet_id, subnet) = lookup_subnet(&cert, &self.root_key.read().unwrap())?;
let subnet = Arc::new(subnet);
self.subnet_key_cache
.lock()
.unwrap()
.insert_subnet(subnet_id, subnet.clone());
Ok(subnet)
}
self.fetch_subnet_by_canister(canister).await
}
}

async fn fetch_subnet_by_canister(
&self,
canister: &Principal,
) -> Result<Arc<Subnet>, AgentError> {
let cert = self
.read_state_raw(vec![vec!["subnet".into()]], *canister)
.await?;
let time = leb128::read::unsigned(&mut lookup_value(&cert.tree, [b"time".as_ref()])?)?;
if (OffsetDateTime::now_utc()
- OffsetDateTime::from_unix_timestamp_nanos(time as _).unwrap())
> self.ingress_expiry
{
Err(AgentError::CertificateOutdated(self.ingress_expiry))
} else {
let (subnet_id, subnet) = lookup_subnet(&cert, &self.root_key.read().unwrap())?;
let subnet = Arc::new(subnet);
self.subnet_key_cache
.lock()
.unwrap()
.insert_subnet(subnet_id, subnet.clone());
Ok(subnet)
}
}
}
Expand Down

0 comments on commit fddfa44

Please sign in to comment.