basic dns server works!

This commit is contained in:
Michael Williams 2019-04-19 13:00:06 +12:00
commit a20da0f699
4 changed files with 1583 additions and 0 deletions

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
/target
**/*.rs.bk

1486
Cargo.lock generated Normal file

File diff suppressed because it is too large Load Diff

16
Cargo.toml Normal file
View File

@ -0,0 +1,16 @@
[package]
name = "peach-dyndns-host"
version = "0.1.0"
authors = ["Michael Williams <michael.williams@enspiral.com>"]
edition = "2018"
[dependencies]
env_logger = "0.6"
futures = "0.1.26"
lazy_static = "1.0"
log = "0.4.1"
serde = { version = "1.0.88", features = ["derive"] }
tokio = "0.1.15"
tokio-tcp = "0.1"
tokio-udp = "0.1"
trust-dns-server = "0.16"

79
src/main.rs Normal file
View File

@ -0,0 +1,79 @@
extern crate futures;
#[macro_use]
extern crate log;
extern crate tokio;
extern crate tokio_tcp;
extern crate trust_dns_server;
use std::io;
use std::net::{IpAddr, Ipv4Addr, SocketAddr};
use std::path::{Path, PathBuf};
use std::time::{Duration};
use futures::{future, Future};
use tokio::runtime::Runtime;
use tokio::runtime::TaskExecutor;
use tokio_tcp::TcpListener;
use tokio_udp::UdpSocket;
use trust_dns_server::proto::rr::Name;
use trust_dns_server::authority::{AuthorityObject, Catalog, ZoneType};
use trust_dns_server::config::{Config, ZoneConfig};
use trust_dns_server::logger;
use trust_dns_server::server::ServerFuture;
use trust_dns_server::store::in_memory::{InMemoryAuthority};
use trust_dns_server::store::StoreConfig;
static DEFAULT_TCP_REQUEST_TIMEOUT: u64 = 5;
fn main() {
logger::debug();
info!("Trust-DNS {} starting", trust_dns_server::version());
let mut io_loop = Runtime::new().expect("error when creating tokio Runtime");
let executor = io_loop.executor();
let mut catalog: Catalog = Catalog::new();
let ip_addr = IpAddr::V4(Ipv4Addr::new(0, 0, 0, 0));
let listen_port: u16 = 12323;
let tcp_request_timeout = Duration::from_secs(DEFAULT_TCP_REQUEST_TIMEOUT);
let sock_addr = SocketAddr::new(ip_addr, listen_port);
let udp_socket = UdpSocket::bind(&sock_addr).unwrap_or_else(|_| panic!("could not bind to udp: {}", sock_addr));
let tcp_listener = TcpListener::bind(&sock_addr).unwrap_or_else(|_| panic!("could not bind to tcp: {}", sock_addr));
let mut server = ServerFuture::new(catalog);
let server_future: Box<Future<Item = (), Error = ()> + Send> =
Box::new(future::lazy(move || {
// load all the listeners
info!("listening for UDP on {:?}", udp_socket);
server.register_socket(udp_socket);
info!("listening for TCP on {:?}", tcp_listener);
server
.register_listener(tcp_listener, tcp_request_timeout)
.expect("could not register TCP listener");
info!("awaiting connections...");
info!("Server starting up");
future::empty()
}));
if let Err(e) = io_loop.block_on(server_future.map_err(|_| {
io::Error::new(
io::ErrorKind::Interrupted,
"Server stopping due to interruption",
)
})) {
error!("failed to listen: {}", e);
}
// we're exiting for some reason...
info!("Trust-DNS {} stopping", trust_dns_server::version());
}