Compare commits

..

No commits in common. "fdc8a7e33884c549b34f96eb2f705a1c4d26f082" and "6dc0060980eb806f0a4743d57b90e917c8f787ca" have entirely different histories.

9 changed files with 20 additions and 95 deletions

View File

@ -6,8 +6,7 @@ use clap::Parser;
use log::{info, LevelFilter}; use log::{info, LevelFilter};
use rand::RngCore; use rand::RngCore;
use simplelog::*; use simplelog::*;
use dnstplib::message::{DNSQuestion, DNSRequest, DNSHeader, QClass, QType, Direction, Opcode, ResponseCode};
use dnstplib::message::DNSRequest;
use dnstplib::net::{DNSSocket, NetworkMessage}; use dnstplib::net::{DNSSocket, NetworkMessage};
use dnstplib::processor::ResponseProcesor; use dnstplib::processor::ResponseProcesor;

View File

@ -16,7 +16,7 @@ impl Debug for ARdata {
impl RData for ARdata { impl RData for ARdata {
fn to_bytes(&self) -> Vec<u8> { fn to_bytes(&self) -> Vec<u8> {
self.rdata.octets().to_vec() return self.rdata.octets().to_vec();
} }
} }

View File

@ -1,30 +0,0 @@
use std::fmt::{Debug, Formatter};
use std::net::{Ipv4Addr, Ipv6Addr};
use crate::message::answer::RData;
pub struct AAAARdata {
pub rdata: Ipv6Addr
}
impl Debug for AAAARdata {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
f.debug_struct("IP")
.field("data", &self.rdata)
.finish()
}
}
impl RData for AAAARdata {
fn to_bytes(&self) -> Vec<u8> {
self.rdata.octets().to_vec()
}
}
impl AAAARdata {
pub fn from(rdata: Ipv6Addr) -> AAAARdata
{
AAAARdata {
rdata
}
}
}

View File

@ -4,13 +4,6 @@ pub use raw_rdata::RawRData;
mod a_rdata; mod a_rdata;
pub use a_rdata::ARdata; pub use a_rdata::ARdata;
mod aaaa_rdata;
pub use aaaa_rdata::AAAARdata;
mod txt_rdata;
pub use txt_rdata::TXTRdata;
#[cfg(test)] #[cfg(test)]
mod tests; mod tests;
@ -24,7 +17,7 @@ pub trait RData: Debug {
} }
#[derive(Debug)] #[derive(Debug)]
pub struct ResourceRecord { pub struct DNSAnswer {
pub name_offset: u16, pub name_offset: u16,
pub answer_type: QType, pub answer_type: QType,
pub class: QClass, pub class: QClass,
@ -33,7 +26,7 @@ pub struct ResourceRecord {
pub r_data: Box<dyn RData> pub r_data: Box<dyn RData>
} }
impl ResourceRecord { impl DNSAnswer {
pub fn to_bytes(&self) -> Vec<u8> pub fn to_bytes(&self) -> Vec<u8>
{ {
@ -63,9 +56,9 @@ impl ResourceRecord {
return ret return ret
} }
pub fn from_query(query: &DNSQuestion, name_offset: u16, data: Box<dyn RData>, ttl: Option<u32>) -> ResourceRecord pub fn from_query(query: &DNSQuestion, name_offset: u16, data: Box<dyn RData>, ttl: Option<u32>) -> DNSAnswer
{ {
ResourceRecord { DNSAnswer {
name_offset, name_offset,
answer_type: query.qtype, answer_type: query.qtype,
class: query.qclass, class: query.qclass,
@ -76,7 +69,7 @@ impl ResourceRecord {
} }
} }
pub fn records_to_bytes(answers: &Vec<ResourceRecord>) -> Vec<u8> pub fn answers_to_bytes(answers: &Vec<DNSAnswer>) -> Vec<u8>
{ {
let mut ret = Vec::with_capacity(20); let mut ret = Vec::with_capacity(20);
@ -89,13 +82,13 @@ pub fn records_to_bytes(answers: &Vec<ResourceRecord>) -> Vec<u8>
} }
#[derive(Ord, PartialOrd, Eq, PartialEq, Debug)] #[derive(Ord, PartialOrd, Eq, PartialEq, Debug)]
pub enum RecordParseError { pub enum AnswerParseError {
ShortLength(usize), ShortLength(usize),
QTypeParse(u8), QTypeParse(u8),
QClassParse(u8) QClassParse(u8)
} }
pub fn answers_from_bytes(bytes: Vec<u8>, total_answers: u16) -> Result<(i32, Vec<ResourceRecord>), RecordParseError> pub fn answers_from_bytes(bytes: Vec<u8>, total_answers: u16) -> Result<(i32, Vec<DNSAnswer>), AnswerParseError>
{ {
Ok((0, vec![])) Ok((0, vec![]))
} }

View File

@ -15,7 +15,7 @@ impl Debug for RawRData {
impl RData for RawRData { impl RData for RawRData {
fn to_bytes(&self) -> Vec<u8> { fn to_bytes(&self) -> Vec<u8> {
self.rdata.clone() return self.rdata.clone();
} }
} }

View File

@ -5,7 +5,7 @@ use super::*;
#[test] #[test]
#[ignore] #[ignore]
fn one_answer_back_and_forth() { fn one_answer_back_and_forth() {
let q = ResourceRecord { let q = DNSAnswer {
// name_offset: "google.com".to_string(), // name_offset: "google.com".to_string(),
name_offset: 12, name_offset: 12,
answer_type: QType::A, answer_type: QType::A,

View File

@ -1,29 +0,0 @@
use std::fmt::{Debug, Formatter};
use crate::message::answer::RData;
pub struct TXTRdata {
pub rdata: String
}
impl Debug for TXTRdata {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
f.debug_struct("TXT")
.field("data", &self.rdata)
.finish()
}
}
impl RData for TXTRdata {
fn to_bytes(&self) -> Vec<u8> {
self.rdata.into_bytes()
}
}
impl TXTRdata {
pub fn from(rdata: String) -> TXTRdata
{
TXTRdata {
rdata
}
}
}

View File

@ -1,4 +1,4 @@
//! Structures making up the DNS workflow including requests, responses and headers
pub mod header; pub mod header;
pub mod question; pub mod question;
pub mod request; pub mod request;
@ -6,7 +6,7 @@ pub mod answer;
pub mod response; pub mod response;
pub use question::{DNSQuestion, QClass, QType, QuestionParseError, questions_to_bytes, questions_from_bytes}; pub use question::{DNSQuestion, QClass, QType, QuestionParseError, questions_to_bytes, questions_from_bytes};
pub use answer::{ResourceRecord, RawRData, RData, ARdata, AAAARdata, TXTRdata, RecordParseError, records_to_bytes, answers_from_bytes}; pub use answer::{DNSAnswer, RawRData, RData, ARdata, AnswerParseError, answers_to_bytes, answers_from_bytes};
pub use header::{DNSHeader, Direction, Opcode, ResponseCode, HEADER_SIZE}; pub use header::{DNSHeader, Direction, Opcode, ResponseCode, HEADER_SIZE};
pub use request::DNSRequest; pub use request::DNSRequest;
pub use response::DNSResponse; pub use response::DNSResponse;

View File

@ -1,13 +1,11 @@
use std::net::{Ipv4Addr, SocketAddr}; use std::net::{Ipv4Addr, SocketAddr};
use crate::message::{Direction, DNSHeader, DNSRequest, ResponseCode, records_to_bytes, ARdata, ResourceRecord, DNSQuestion, questions_to_bytes}; use crate::message::{Direction, DNSHeader, DNSRequest, ResponseCode, answers_to_bytes, ARdata, DNSAnswer, DNSQuestion, questions_to_bytes};
#[derive(Debug)] #[derive(Debug)]
pub struct DNSResponse { pub struct DNSResponse {
pub header: DNSHeader, pub header: DNSHeader,
pub questions: Vec<DNSQuestion>, pub questions: Vec<DNSQuestion>,
pub answers: Vec<ResourceRecord>, pub answers: Vec<DNSAnswer>,
pub authorities: Vec<ResourceRecord>,
pub additionals: Vec<ResourceRecord>,
pub peer: SocketAddr pub peer: SocketAddr
} }
@ -17,14 +15,10 @@ impl DNSResponse {
{ {
let mut header_bytes = self.header.to_bytes().to_vec(); let mut header_bytes = self.header.to_bytes().to_vec();
let mut body_bytes = questions_to_bytes(&self.questions); let mut body_bytes = questions_to_bytes(&self.questions);
let mut answer_bytes = records_to_bytes(&self.answers); let mut answer_bytes = answers_to_bytes(&self.answers);
let mut authority_bytes = records_to_bytes(&self.authorities);
let mut additional_bytes = records_to_bytes(&self.additionals);
header_bytes.append(&mut body_bytes); header_bytes.append(&mut body_bytes);
header_bytes.append(&mut answer_bytes); header_bytes.append(&mut answer_bytes);
header_bytes.append(&mut authority_bytes);
header_bytes.append(&mut additional_bytes);
return header_bytes return header_bytes
} }
@ -35,18 +29,16 @@ impl DNSResponse {
header: request.header.clone(), header: request.header.clone(),
questions: request.questions.clone(), questions: request.questions.clone(),
answers: vec![], answers: vec![],
authorities: vec![],
additionals: vec![],
peer: request.peer peer: request.peer
}; };
response.answers = request.questions response.answers = request.questions
.iter() .iter()
.map(|x| .map(|x|
ResourceRecord::from_query(x, DNSAnswer::from_query(x,
12, 12,
Box::from(ARdata::from(ip(x))), Box::from(ARdata::from(ip(x))),
None)) None))
.collect(); .collect();
response.header.direction = Direction::Response; response.header.direction = Direction::Response;