From c69f5b9be3f72b95d6ffc8d3f4b6365206e5f001 Mon Sep 17 00:00:00 2001 From: dev0 Date: Wed, 18 Oct 2023 23:47:18 +1100 Subject: [PATCH] better handle dns --- clash_lib/src/app/dns/server/mod.rs | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/clash_lib/src/app/dns/server/mod.rs b/clash_lib/src/app/dns/server/mod.rs index bfcc4cddf..cfaae0331 100644 --- a/clash_lib/src/app/dns/server/mod.rs +++ b/clash_lib/src/app/dns/server/mod.rs @@ -70,6 +70,7 @@ impl DnsHandler { let mut m = Message::new(); m.set_op_code(request.op_code()); m.set_message_type(request.message_type()); + m.set_recursion_desired(request.recursion_desired()); m.add_query(request.query().original().clone()); m.add_additionals(request.additionals().into_iter().map(Clone::clone)); m.add_name_servers(request.name_servers().into_iter().map(Clone::clone)); @@ -93,10 +94,20 @@ impl DnsHandler { let mut rv = builder.build(header, m.answers(), m.name_servers(), &[], m.additionals()); - if let Some(edns) = m.extensions() { - rv.set_edns(edns.clone()); + if let Some(edns) = request.edns() { + if edns.dnssec_ok() { + if let Some(edns) = m.extensions() { + rv.set_edns(edns.clone()); + } + } } + debug!( + "answering dns query {} with answer {:?}", + request.query().name(), + m.answers(), + ); + Ok(response_handle.send_response(rv).await?) } Err(e) => { @@ -115,9 +126,10 @@ impl RequestHandler for DnsHandler { response_handle: R, ) -> ResponseInfo { debug!( - "got dns request {}-{} from {}", + "got dns request [{}][{}][{}] from {}", request.protocol(), - request.message_type(), + request.query().query_type(), + request.query().name(), request.src() );