Skip to content

Commit

Permalink
signer: Pass policy rejections back to the scheduler
Browse files Browse the repository at this point in the history
There was a `?` that would prematurely bubble the error up, past the
point we'd send a rejection notice to the scheduler. So handle those
errors with more care, and we can see when policies fail on the server
side, to adjust, tweak and right-size the policies, and act as a
regression test suite.
  • Loading branch information
cdecker committed Jul 18, 2024
1 parent b62deb8 commit b5de1cd
Showing 1 changed file with 13 additions and 4 deletions.
17 changes: 13 additions & 4 deletions libs/gl-client/src/signer/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -316,7 +316,7 @@ impl Signer {
}

// Currently we only use a 0 unique_id and a pubkey field to allow
// for delegation in the future but we could also set the public
// for delegation in the future but we could also set the public
// key as the unique_id in the future and add a method that allows
// to create new empty runes.
let unique_id = rune.get_id();
Expand Down Expand Up @@ -527,7 +527,7 @@ impl Signer {
log::trace!("State updated");

// Match over root and client handler.
let response = match req.context {
let response = match req.context.clone() {
Some(HsmRequestContext { dbid: 0, .. }) | None => {
// This is the main daemon talking to us.
root_handler.handle(msg)
Expand All @@ -539,15 +539,24 @@ impl Signer {
.for_new_client(1 as u64, pk, c.dbid)
.handle(msg)
}
};

if let Err(e) = response {
report::Reporter::report(crate::pb::scheduler::SignerRejection {
msg: format!("{:?}", e),
request: Some(req.clone()),
git_version: GITHASH.to_string(),
})
.await;
return Err(Error::Other(anyhow!("processing request: {e:?}")));
}
.map_err(|e| Error::Other(anyhow!("processing request: {e:?}")))?;

let response = response.unwrap();
let signer_state: Vec<crate::pb::SignerStateEntry> = {
debug!("Serializing state changes to report to node");
let state = self.state.lock().unwrap();
state.clone().into()
};

Ok(HsmResponse {
raw: response.0.as_vec(),
request_id: req.request_id,
Expand Down

0 comments on commit b5de1cd

Please sign in to comment.