1 /* SPDX-License-Identifier: LGPL-2.1+ */
5 Copyright 2014 Lennart Poettering
12 typedef struct DnsQueryCandidate DnsQueryCandidate
;
13 typedef struct DnsQuery DnsQuery
;
15 #include "resolved-dns-answer.h"
16 #include "resolved-dns-question.h"
17 #include "resolved-dns-stream.h"
18 #include "resolved-dns-search-domain.h"
20 struct DnsQueryCandidate
{
24 DnsSearchDomain
*search_domain
;
29 LIST_FIELDS(DnsQueryCandidate
, candidates_by_query
);
30 LIST_FIELDS(DnsQueryCandidate
, candidates_by_scope
);
36 /* When resolving a service, we first create a TXT+SRV query,
37 * and then for the hostnames we discover auxiliary A+AAAA
38 * queries. This pointer always points from the auxiliary
39 * queries back to the TXT+SRV query. */
40 DnsQuery
*auxiliary_for
;
41 LIST_HEAD(DnsQuery
, auxiliary_queries
);
42 unsigned n_auxiliary_queries
;
45 /* The question, formatted in IDNA for use on classic DNS, and as UTF8 for use in LLMNR or mDNS. Note that even
46 * on classic DNS some labels might use UTF8 encoding. Specifically, DNS-SD service names (in contrast to their
47 * domain suffixes) use UTF-8 encoding even on DNS. Thus, the difference between these two fields is mostly
48 * relevant only for explicit *hostname* lookups as well as the domain suffixes of service lookups. */
49 DnsQuestion
*question_idna
;
50 DnsQuestion
*question_utf8
;
55 /* If true, A or AAAA RR lookups will be suppressed on links with no routable address of the matching address
57 bool suppress_unroutable_family
;
59 /* If true, the RR TTLs of the answer will be clamped by their current left validity in the cache */
62 DnsTransactionState state
;
63 unsigned n_cname_redirects
;
65 LIST_HEAD(DnsQueryCandidate
, candidates
);
66 sd_event_source
*timeout_event_source
;
71 DnssecResult answer_dnssec_result
;
72 bool answer_authenticated
;
73 DnsProtocol answer_protocol
;
75 DnsSearchDomain
*answer_search_domain
;
76 int answer_errno
; /* if state is DNS_TRANSACTION_ERRNO */
77 bool previous_redirect_unauthenticated
;
79 /* Bus client information */
80 sd_bus_message
*request
;
82 bool request_address_valid
;
83 union in_addr_union request_address
;
84 unsigned block_all_complete
;
85 char *request_address_string
;
87 /* DNS stub information */
88 DnsPacket
*request_dns_packet
;
89 DnsStream
*request_dns_stream
;
90 DnsPacket
*reply_dns_packet
;
92 /* Completion callback */
93 void (*complete
)(DnsQuery
* q
);
96 sd_bus_track
*bus_track
;
98 LIST_FIELDS(DnsQuery
, queries
);
99 LIST_FIELDS(DnsQuery
, auxiliary_queries
);
108 DnsQueryCandidate
* dns_query_candidate_free(DnsQueryCandidate
*c
);
109 void dns_query_candidate_notify(DnsQueryCandidate
*c
);
111 int dns_query_new(Manager
*m
, DnsQuery
**q
, DnsQuestion
*question_utf8
, DnsQuestion
*question_idna
, int family
, uint64_t flags
);
112 DnsQuery
*dns_query_free(DnsQuery
*q
);
114 int dns_query_make_auxiliary(DnsQuery
*q
, DnsQuery
*auxiliary_for
);
116 int dns_query_go(DnsQuery
*q
);
117 void dns_query_ready(DnsQuery
*q
);
119 int dns_query_process_cname(DnsQuery
*q
);
121 int dns_query_bus_track(DnsQuery
*q
, sd_bus_message
*m
);
123 DnsQuestion
* dns_query_question_for_protocol(DnsQuery
*q
, DnsProtocol protocol
);
125 const char *dns_query_string(DnsQuery
*q
);
127 DEFINE_TRIVIAL_CLEANUP_FUNC(DnsQuery
*, dns_query_free
);
129 bool dns_query_fully_authenticated(DnsQuery
*q
);