mirror of
https://github.com/ZeusWPI/ZNS.git
synced 2024-10-29 21:14:27 +01:00
better error printing
This commit is contained in:
parent
c1ab0cc953
commit
6ed4de8b44
3 changed files with 21 additions and 9 deletions
|
@ -21,7 +21,11 @@ pub async fn authenticate(
|
|||
//TODO: panic? subtract
|
||||
let username = &zone[zone.len() - Config::get().authoritative_zone.len() - 1];
|
||||
|
||||
let ssh_verified = validate_ssh(username, sig).await.is_ok_and(|b| b);
|
||||
let ssh_verified = validate_ssh(username, sig)
|
||||
.await
|
||||
.map_err(|e| ZNSError::Servfail {
|
||||
message: e.to_string(),
|
||||
})?;
|
||||
|
||||
if ssh_verified {
|
||||
Ok(true)
|
||||
|
@ -49,7 +53,13 @@ async fn validate_ssh(username: &String, sig: &Sig) -> Result<bool, reqwest::Err
|
|||
.json::<Vec<String>>()
|
||||
.await?
|
||||
.iter()
|
||||
.any(|key| sig.verify_ssh(&key).is_ok_and(|b| b)))
|
||||
.any(|key| match sig.verify_ssh(&key) {
|
||||
Ok(value) => value,
|
||||
Err(e) => {
|
||||
eprintln!("{}", e);
|
||||
false
|
||||
}
|
||||
}))
|
||||
}
|
||||
|
||||
async fn validate_dnskey(
|
||||
|
@ -66,7 +76,12 @@ async fn validate_dnskey(
|
|||
.iter()
|
||||
.any(|rr| {
|
||||
let mut reader = Reader::new(&rr.rdata);
|
||||
DNSKeyRData::from_bytes(&mut reader)
|
||||
.is_ok_and(|dnskey| sig.verify_dnskey(dnskey).is_ok_and(|b| b))
|
||||
DNSKeyRData::from_bytes(&mut reader).is_ok_and(|dnskey| match sig.verify_dnskey(dnskey) {
|
||||
Ok(value) => value,
|
||||
Err(e) => {
|
||||
eprintln!("{}", e);
|
||||
false
|
||||
}
|
||||
})
|
||||
}))
|
||||
}
|
||||
|
|
|
@ -54,10 +54,7 @@ impl ResponseHandler for UpdateHandler {
|
|||
if last.is_some() && last.unwrap()._type == Type::Type(RRType::SIG) {
|
||||
let sig = Sig::new(last.unwrap(), raw)?;
|
||||
|
||||
if !authenticate::authenticate(&sig, &zone.qname, connection)
|
||||
.await
|
||||
.is_ok_and(|x| x)
|
||||
{
|
||||
if !authenticate::authenticate(&sig, &zone.qname, connection).await? {
|
||||
return Err(ZNSError::Refused {
|
||||
message: "Unable to verify authentication".to_string(),
|
||||
});
|
||||
|
|
|
@ -10,7 +10,7 @@ pub enum ZNSError {
|
|||
Reader { message: String },
|
||||
#[error("Key Error: {message:?}")]
|
||||
Key { message: String },
|
||||
#[error("Server error")]
|
||||
#[error("Server error: {message:?}")]
|
||||
Servfail { message: String },
|
||||
#[error("DNS Query Format Error: {message:?}")]
|
||||
Formerr { message: String },
|
||||
|
|
Loading…
Reference in a new issue