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
// Copyright 2015-2018 Benjamin Fry <benjaminfry@me.com> // // Licensed under the Apache License, Version 2.0, <LICENSE-APACHE or // http://apache.org/licenses/LICENSE-2.0> or the MIT license <LICENSE-MIT or // http://opensource.org/licenses/MIT>, at your option. This file may not be // copied, modified, or distributed except according to those terms. use std::net::SocketAddr; use crate::error::ProtoResult; use crate::op::Message; /// A DNS message in serialized form, with either the target address or source address pub struct SerialMessage { // TODO: change to Bytes? this would be more compatible with some underlying libraries message: Vec<u8>, addr: SocketAddr, } impl SerialMessage { /// Construct a new SerialMessage and the source or destination address pub fn new(message: Vec<u8>, addr: SocketAddr) -> Self { SerialMessage { message, addr } } /// Get a reference to the bytes pub fn bytes(&self) -> &[u8] { &self.message } /// Get the source or destination address (context dependent) pub fn addr(&self) -> SocketAddr { self.addr } /// Unwrap the the Bytes and address pub fn unwrap(self) -> (Vec<u8>, SocketAddr) { (self.message, self.addr) } /// Deserializes the inner data into a Message pub fn to_message(&self) -> ProtoResult<Message> { Message::from_vec(&self.message) } }