mirror of
https://github.com/ZeusWPI/ZNS.git
synced 2025-01-08 07:49:46 +01:00
Handle parser errors
This commit is contained in:
parent
9f8ecac4f0
commit
79b040f5f9
1 changed files with 30 additions and 11 deletions
|
@ -5,8 +5,9 @@ use std::sync::Arc;
|
|||
use tokio::net::UdpSocket;
|
||||
|
||||
use crate::db::models::{get_from_database, insert_into_database};
|
||||
use crate::errors::ParseError;
|
||||
use crate::parser::FromBytes;
|
||||
use crate::structs::{Class, Message, Type, RCODE, RR, Opcode};
|
||||
use crate::structs::{Class, Header, Message, Opcode, Type, RCODE};
|
||||
use crate::utils::vec_equal;
|
||||
|
||||
const MAX_DATAGRAM_SIZE: usize = 4096;
|
||||
|
@ -15,7 +16,6 @@ fn set_response_flags(flags: u16, rcode: RCODE) -> u16 {
|
|||
(flags | 0b1_0000_1_0_0_0_000_0000 | rcode as u16) & 0b1_1111_1_0_1_0_111_1111
|
||||
}
|
||||
|
||||
|
||||
fn get_opcode(flags: &u16) -> Result<Opcode, String> {
|
||||
Opcode::try_from((flags & 0b0111100000000000) >> 11)
|
||||
}
|
||||
|
@ -55,10 +55,7 @@ async fn handle_update(message: Message) -> Message {
|
|||
// Check Zone authority
|
||||
let zone = &message.question[0];
|
||||
let zlen = zone.qname.len();
|
||||
if !(zlen >= 2
|
||||
&& zone.qname[zlen - 1] == "gent"
|
||||
&& zone.qname[zlen - 2] == "zeus")
|
||||
{
|
||||
if !(zlen >= 2 && zone.qname[zlen - 1] == "gent" && zone.qname[zlen - 2] == "zeus") {
|
||||
response.header.flags = set_response_flags(response.header.flags, RCODE::NOTAUTH);
|
||||
return response;
|
||||
}
|
||||
|
@ -89,7 +86,6 @@ async fn handle_update(message: Message) -> Message {
|
|||
response.header.flags = set_response_flags(response.header.flags, RCODE::FORMERR);
|
||||
return response;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
for rr in message.authority {
|
||||
|
@ -108,6 +104,32 @@ async fn handle_update(message: Message) -> Message {
|
|||
response
|
||||
}
|
||||
|
||||
fn handle_parse_error(bytes: &[u8], err: ParseError) -> Message {
|
||||
eprintln!("{}", err);
|
||||
let mut header = Header::from_bytes(bytes, &mut 0).unwrap_or(Header {
|
||||
id: 0,
|
||||
flags: 0,
|
||||
qdcount: 0,
|
||||
ancount: 0,
|
||||
nscount: 0,
|
||||
arcount: 0,
|
||||
});
|
||||
|
||||
header.qdcount = 0;
|
||||
header.ancount = 0;
|
||||
header.nscount = 0;
|
||||
header.arcount = 0;
|
||||
header.flags = set_response_flags(header.flags, RCODE::FORMERR);
|
||||
|
||||
Message {
|
||||
header,
|
||||
question: vec![],
|
||||
answer: vec![],
|
||||
authority: vec![],
|
||||
additional: vec![],
|
||||
}
|
||||
}
|
||||
|
||||
async fn get_response(bytes: &[u8]) -> Message {
|
||||
let mut i: usize = 0;
|
||||
match Message::from_bytes(bytes, &mut i) {
|
||||
|
@ -118,10 +140,7 @@ async fn get_response(bytes: &[u8]) -> Message {
|
|||
},
|
||||
Err(_) => todo!(),
|
||||
},
|
||||
Err(err) => {
|
||||
println!("{}", err);
|
||||
unimplemented!() //TODO: implement this
|
||||
}
|
||||
Err(err) => handle_parse_error(bytes, err),
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue