1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
use crate::decode::Decoder; use crate::rr::{Class, Type, RR}; use crate::{DecodeError, DecodeResult, DomainName}; use num_traits::FromPrimitive; pub(super) struct Header { pub(super) domain_name: DomainName, pub(super) class: u16, pub(super) ttl: u32, } impl Header { pub(super) fn get_class(&self) -> DecodeResult<Class> { if let Some(class) = Class::from_u16(self.class) { Ok(class) } else { Err(DecodeError::ClassError(self.class)) } } } impl<'a, 'b: 'a> Decoder<'b, 'b> { fn rr_data(&'a mut self) -> DecodeResult<Decoder<'a, 'b>> { let rd_length = self.u16()?; let r_data = self.sub(rd_length)?; Ok(r_data) } pub fn rr(&'a mut self) -> DecodeResult<RR> { let (type_, header) = self.rr_header()?; let mut r_data = self.rr_data()?; let rr = match type_ { Type::A => RR::A(r_data.rr_a(header)?), Type::NS => RR::NS(r_data.rr_ns(header)?), Type::MD => RR::MD(r_data.rr_md(header)?), Type::MF => RR::MF(r_data.rr_mf(header)?), Type::CNAME => RR::CNAME(r_data.rr_cname(header)?), Type::SOA => RR::SOA(r_data.rr_soa(header)?), Type::MB => RR::MB(r_data.rr_mb(header)?), Type::MG => RR::MG(r_data.rr_mg(header)?), Type::MR => RR::MR(r_data.rr_mr(header)?), Type::NULL => RR::NULL(r_data.rr_null(header)?), Type::WKS => RR::WKS(r_data.rr_wks(header)?), Type::PTR => RR::PTR(r_data.rr_ptr(header)?), Type::HINFO => RR::HINFO(r_data.rr_hinfo(header)?), Type::MINFO => RR::MINFO(r_data.rr_minfo(header)?), Type::MX => RR::MX(r_data.rr_mx(header)?), Type::TXT => RR::TXT(r_data.rr_txt(header)?), Type::RP => RR::RP(r_data.rr_rp(header)?), Type::AFSDB => RR::AFSDB(r_data.rr_afsdb(header)?), Type::X25 => RR::X25(r_data.rr_x25(header)?), Type::ISDN => RR::ISDN(r_data.rr_isdn(header)?), Type::RT => RR::RT(r_data.rr_rt(header)?), Type::NSAP => RR::NSAP(r_data.rr_nsap(header)?), Type::GPOS => RR::GPOS(r_data.rr_gpos(header)?), Type::LOC => RR::LOC(r_data.rr_loc(header)?), Type::PX => RR::PX(r_data.rr_px(header)?), Type::KX => RR::KX(r_data.rr_kx(header)?), Type::SRV => RR::SRV(r_data.rr_srv(header)?), Type::AAAA => RR::AAAA(r_data.rr_aaaa(header)?), Type::SSHFP => RR::SSHFP(r_data.rr_sshfp(header)?), Type::DNAME => RR::DNAME(r_data.rr_dname(header)?), Type::OPT => RR::OPT(r_data.rr_opt(header)?), Type::URI => RR::URI(r_data.rr_uri(header)?), Type::EID => RR::EID(r_data.rr_eid(header)?), Type::NIMLOC => RR::NIMLOC(r_data.rr_nimloc(header)?), _ => return Err(DecodeError::NotYetImplemented), }; r_data.finished()?; Ok(rr) } } impl<'a, 'b: 'a> Decoder<'a, 'b> { fn rr_header(&mut self) -> DecodeResult<(Type, Header)> { let domain_name = self.domain_name()?; let type_ = self.rr_type()?; let class = self.u16()?; let ttl = self.u32()?; let header = Header { domain_name, class, ttl, }; Ok((type_, header)) } pub fn rr_class(&mut self) -> DecodeResult<Class> { let buffer = self.u16()?; if let Some(class) = Class::from_u16(buffer) { Ok(class) } else { Err(DecodeError::ClassError(buffer)) } } pub fn rr_type(&mut self) -> DecodeResult<Type> { let buffer = self.u16()?; if let Some(type_) = Type::from_u16(buffer) { Ok(type_) } else { Err(DecodeError::TypeError(buffer)) } } } impl_decode!(Class, rr_class); impl_decode!(Type, rr_type); impl_decode!(RR, rr);