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
use crate::resources::{RData, RecordType};
use serde::Serialize;
use std::hash::{Hash, Hasher};
use trust_dns_resolver::Name;
#[derive(Debug, Eq, Clone, Serialize)]
pub struct Record {
name: Name,
#[serde(rename = "type")]
record_type: RecordType,
ttl: u32,
data: RData,
}
impl PartialEq for Record {
fn eq(&self, other: &Self) -> bool {
self.name == other.name && self.record_type == other.record_type && self.data == other.data
}
}
impl Hash for Record {
fn hash<H: Hasher>(&self, state: &mut H) {
self.name().hash(state);
self.record_type().hash(state);
self.data().hash(state);
}
}
impl Record {
pub fn name(&self) -> &Name {
&self.name
}
pub fn associated_name(&self) -> &Name {
match self.data {
RData::A(_) => self.name(),
RData::AAAA(_) => self.name(),
RData::ANAME(ref x) => x,
RData::CAA => self.name(),
RData::CNAME(ref x) => x,
RData::MX(ref x) => x.exchange(),
RData::NAPTR => self.name(),
RData::NULL(_) => self.name(),
RData::NS(ref x) => x,
RData::OPENPGPKEY => self.name(),
RData::OPT => self.name(),
RData::PTR(ref x) => x,
RData::SOA(ref x) => x.mname(),
RData::SRV(ref x) => x.target(),
RData::SSHFP => self.name(),
RData::TLSA => self.name(),
RData::TXT(_) => self.name(),
RData::DNSSEC => self.name(),
RData::Unknown(_) => self.name(),
RData::ZERO => self.name(),
}
}
pub fn record_type(&self) -> RecordType {
self.record_type
}
pub fn ttl(&self) -> u32 {
self.ttl
}
pub fn data(&self) -> &RData {
&self.data
}
}
#[doc(hidden)]
impl From<&trust_dns_resolver::proto::rr::Record> for Record {
fn from(record: &trust_dns_resolver::proto::rr::Record) -> Self {
Record {
name: record.name().clone(),
record_type: record.rr_type().into(),
ttl: record.ttl(),
data: record.rdata().clone().into(),
}
}
}