From 9cf1ade76ae1e0e6aa312816719fa702ad31896f Mon Sep 17 00:00:00 2001 From: Ishan Jain Date: Tue, 12 Dec 2023 05:11:03 +0530 Subject: [PATCH] fixed bug in qname.write_to --- src/main.rs | 2 ++ src/qname.rs | 23 ++++++++++++++++++++++- 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/src/main.rs b/src/main.rs index af62ddb..324e508 100644 --- a/src/main.rs +++ b/src/main.rs @@ -36,6 +36,8 @@ fn main() { let mut data = vec![]; packet.write_to(&mut data); + println!("written packet: {:?}", data); + upstream_socket .send_to(&data, resolver) .expect("error in sending data to upstream"); diff --git a/src/qname.rs b/src/qname.rs index 183856f..778740c 100644 --- a/src/qname.rs +++ b/src/qname.rs @@ -12,7 +12,28 @@ pub struct Qname<'a> { impl<'a> Qname<'a> { pub fn write_to(&self, buf: &mut Vec) { - buf.extend(self.name.iter()); + let mut i = 0; + let mut lookup: &[u8] = &self.name; + + while i < lookup.len() - 1 && lookup[i + 1] != 0 { + let is_pointer = (lookup[i] & 0xc0) == 0xc0; + + if is_pointer { + let offset: u16 = (((lookup[i] & !0xc0) as u16) << 8) | lookup[i + 1] as u16; + i = offset as usize; + lookup = &self.original; + } else { + let length = lookup[i] as usize; + + buf.push(length as u8); + + buf.extend(&lookup[i + 1..i + 1 + length]); + + i += length + 1; + } + } + + buf.push(0x0); } // Assume data _starts_ at the question section