dns.rs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #[macro_use]
  2. extern crate log;
  3. extern crate byteorder;
  4. extern crate env_logger;
  5. extern crate getopts;
  6. extern crate smoltcp;
  7. mod utils;
  8. use smoltcp::iface::{InterfaceBuilder, NeighborCache, Routes, SocketSet};
  9. use smoltcp::phy::Device;
  10. use smoltcp::phy::{wait as phy_wait, Medium};
  11. use smoltcp::socket::dns::{self, GetQueryResultError};
  12. use smoltcp::time::Instant;
  13. use smoltcp::wire::{
  14. DnsQueryType, EthernetAddress, HardwareAddress, IpAddress, IpCidr, Ipv4Address, Ipv6Address,
  15. };
  16. use std::collections::BTreeMap;
  17. use std::os::unix::io::AsRawFd;
  18. fn main() {
  19. utils::setup_logging("warn");
  20. let (mut opts, mut free) = utils::create_options();
  21. utils::add_tuntap_options(&mut opts, &mut free);
  22. utils::add_middleware_options(&mut opts, &mut free);
  23. free.push("ADDRESS");
  24. let mut matches = utils::parse_options(&opts, free);
  25. let device = utils::parse_tuntap_options(&mut matches);
  26. let fd = device.as_raw_fd();
  27. let mut device =
  28. utils::parse_middleware_options(&mut matches, device, /*loopback=*/ false);
  29. let name = &matches.free[0];
  30. let neighbor_cache = NeighborCache::new(BTreeMap::new());
  31. let servers = &[
  32. Ipv4Address::new(8, 8, 4, 4).into(),
  33. Ipv4Address::new(8, 8, 8, 8).into(),
  34. ];
  35. let dns_socket = dns::Socket::new(servers, vec![]);
  36. let ethernet_addr = EthernetAddress([0x02, 0x00, 0x00, 0x00, 0x00, 0x02]);
  37. let src_ipv6 = IpAddress::v6(0xfdaa, 0, 0, 0, 0, 0, 0, 1);
  38. let mut ip_addrs = heapless::Vec::<IpCidr, 5>::new();
  39. ip_addrs
  40. .push(IpCidr::new(IpAddress::v4(192, 168, 69, 1), 24))
  41. .unwrap();
  42. ip_addrs.push(IpCidr::new(src_ipv6, 64)).unwrap();
  43. ip_addrs
  44. .push(IpCidr::new(IpAddress::v6(0xfe80, 0, 0, 0, 0, 0, 0, 1), 64))
  45. .unwrap();
  46. let default_v4_gw = Ipv4Address::new(192, 168, 69, 100);
  47. let default_v6_gw = Ipv6Address::new(0xfe80, 0, 0, 0, 0, 0, 0, 0x100);
  48. let mut routes_storage = [None; 2];
  49. let mut routes = Routes::new(&mut routes_storage[..]);
  50. routes.add_default_ipv4_route(default_v4_gw).unwrap();
  51. routes.add_default_ipv6_route(default_v6_gw).unwrap();
  52. let medium = device.capabilities().medium;
  53. let mut builder = InterfaceBuilder::new().ip_addrs(ip_addrs).routes(routes);
  54. if medium == Medium::Ethernet {
  55. builder = builder
  56. .hardware_addr(HardwareAddress::Ethernet(ethernet_addr))
  57. .neighbor_cache(neighbor_cache);
  58. }
  59. let mut iface = builder.finalize(&mut device);
  60. let mut sockets = SocketSet::new(vec![]);
  61. let dns_handle = sockets.add(dns_socket);
  62. let socket = sockets.get_mut::<dns::Socket>(dns_handle);
  63. let query = socket
  64. .start_query(iface.context(), name, DnsQueryType::A)
  65. .unwrap();
  66. loop {
  67. let timestamp = Instant::now();
  68. debug!("timestamp {:?}", timestamp);
  69. match iface.poll(timestamp, &mut device, &mut sockets) {
  70. Ok(_) => {}
  71. Err(e) => {
  72. debug!("poll error: {}", e);
  73. }
  74. }
  75. match sockets
  76. .get_mut::<dns::Socket>(dns_handle)
  77. .get_query_result(query)
  78. {
  79. Ok(addrs) => {
  80. println!("Query done: {:?}", addrs);
  81. break;
  82. }
  83. Err(GetQueryResultError::Pending) => {} // not done yet
  84. Err(e) => panic!("query failed: {:?}", e),
  85. }
  86. phy_wait(fd, iface.poll_delay(timestamp, &sockets)).expect("wait error");
  87. }
  88. }