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
//! Business-logic-like structures for processing parsed messages

pub mod request;
pub mod response;

use std::net::SocketAddr;
use log::error;
pub use request::RequestProcesor;
pub use response::ResponseProcesor;
use crate::message::{QuestionParseError, RecordParseError, HeaderParseError, MessageParseError};

pub fn print_error(e: MessageParseError, peer: &SocketAddr)
{
    match e {
        MessageParseError::HeaderParse(he) => {
            match he {
                HeaderParseError::OpcodeParse(oe) => {
                    error!("[{}] failed to parse opcode from received message: [{}]", peer, oe);
                }
                HeaderParseError::ResponseCodeParse(rce) => {
                    error!("[{}] failed to parse response code error from received message: [{}]", peer, rce);
                }
            }
        }
        MessageParseError::QuesionsParse(qe) => {
            match qe {
                QuestionParseError::ShortLength(sl) => {
                    error!("[{}] failed to parse questions of received message, too short: [{} bytes]", peer, sl);
                }
                QuestionParseError::QTypeParse(te) => {
                    error!("[{}] failed to parse questions of received message, qtype error: [{}]", peer, te);
                }
                QuestionParseError::QClassParse(ce) => {
                    error!("[{}] failed to parse questions of received message, qclass error: [{}]", peer, ce);
                }
                QuestionParseError::UTF8Parse => {
                    error!("[{}] failed to parse questions of received message, failed to UTF-8 parse hostname", peer);
                }
                QuestionParseError::URLDecode => {
                    error!("[{}] failed to parse questions of received message, failed to URL decode hostname", peer);
                }
            }
        }
        MessageParseError::RecordParse(rp) => {
            match rp {
                RecordParseError::ShortLength(sl) => {
                    error!("[{}] failed to parse records of received message, too short: [{} bytes]", peer, sl);
                }
                RecordParseError::QTypeParse(te) => {
                    error!("[{}] failed to parse records of received message, qtype error: [{}]", peer, te);
                }
                RecordParseError::QClassParse(ce) => {
                    error!("[{}] failed to parse records of received message, qclass error: [{}]", peer, ce);
                }
            }
        }
        MessageParseError::RecordCount(expected, actual) => {
            error!("[{}] failed to parse records of received message, record count mismatch: [Expected:{}] [Actual:{}]", peer, expected, actual);
        }
    }
}