]>
Commit | Line | Data |
---|---|---|
db9ecf05 | 1 | /* SPDX-License-Identifier: LGPL-2.1-or-later */ |
74b2466e LP |
2 | #pragma once |
3 | ||
74b2466e | 4 | #include "list.h" |
be28f72d | 5 | #include "ratelimit.h" |
74b2466e | 6 | |
be28f72d | 7 | typedef struct DnsQueryCandidate DnsQueryCandidate; |
74b2466e LP |
8 | typedef struct DnsScope DnsScope; |
9 | ||
322345fd | 10 | #include "resolved-dns-cache.h" |
24710c48 | 11 | #include "resolved-dns-dnssec.h" |
71d35b6b | 12 | #include "resolved-dns-packet.h" |
176a9a2c | 13 | #include "resolved-dns-query.h" |
07f264e4 | 14 | #include "resolved-dns-search-domain.h" |
71d35b6b | 15 | #include "resolved-dns-server.h" |
07f264e4 | 16 | #include "resolved-dns-stream.h" |
623a4c97 | 17 | #include "resolved-dns-zone.h" |
74b2466e | 18 | |
74b2466e LP |
19 | typedef enum DnsScopeMatch { |
20 | DNS_SCOPE_NO, | |
21 | DNS_SCOPE_MAYBE, | |
a97a3b25 LP |
22 | DNS_SCOPE_YES_BASE, /* Add the number of matching labels to this */ |
23 | DNS_SCOPE_YES_END = DNS_SCOPE_YES_BASE + DNS_N_LABELS_MAX, | |
74b2466e | 24 | _DNS_SCOPE_MATCH_MAX, |
2d93c20e | 25 | _DNS_SCOPE_MATCH_INVALID = -EINVAL, |
74b2466e LP |
26 | } DnsScopeMatch; |
27 | ||
28 | struct DnsScope { | |
29 | Manager *manager; | |
30 | ||
1716f6dc | 31 | DnsProtocol protocol; |
0dd25fb9 | 32 | int family; |
89307df3 LP |
33 | |
34 | /* Copied at scope creation time from the link/manager */ | |
24710c48 | 35 | DnssecMode dnssec_mode; |
c9299be2 | 36 | DnsOverTlsMode dns_over_tls_mode; |
74b2466e LP |
37 | |
38 | Link *link; | |
39 | ||
322345fd | 40 | DnsCache cache; |
623a4c97 | 41 | DnsZone zone; |
322345fd | 42 | |
1e43061b | 43 | OrderedHashmap *conflict_queue; |
a4076574 LP |
44 | sd_event_source *conflict_event_source; |
45 | ||
53fda2bb DR |
46 | sd_event_source *announce_event_source; |
47 | ||
aea2429d LP |
48 | RateLimit ratelimit; |
49 | ||
9df3ba6c TG |
50 | usec_t resend_timeout; |
51 | usec_t max_rtt; | |
52 | ||
801ad6a6 | 53 | LIST_HEAD(DnsQueryCandidate, query_candidates); |
74b2466e | 54 | |
775ae354 LP |
55 | /* Note that we keep track of ongoing transactions in two ways: once in a hashmap, indexed by the rr |
56 | * key, and once in a linked list. We use the hashmap to quickly find transactions we can reuse for a | |
57 | * key. But note that there might be multiple transactions for the same key (because the associated | |
58 | * query flags might differ in incompatible ways: e.g. we may not reuse a non-validating transaction | |
59 | * as validating. Hence we maintain a per-key list of transactions, which we iterate through to find | |
60 | * one we can reuse with matching flags. */ | |
f9ebb22a LP |
61 | Hashmap *transactions_by_key; |
62 | LIST_HEAD(DnsTransaction, transactions); | |
63 | ||
74b2466e | 64 | LIST_FIELDS(DnsScope, scopes); |
ebfdf45a ZJS |
65 | |
66 | bool announced; | |
74b2466e LP |
67 | }; |
68 | ||
0dd25fb9 | 69 | int dns_scope_new(Manager *m, DnsScope **ret, Link *l, DnsProtocol p, int family); |
74b2466e LP |
70 | DnsScope* dns_scope_free(DnsScope *s); |
71 | ||
9df3ba6c TG |
72 | void dns_scope_packet_received(DnsScope *s, usec_t rtt); |
73 | void dns_scope_packet_lost(DnsScope *s, usec_t usec); | |
74 | ||
d79677ab | 75 | int dns_scope_emit_udp(DnsScope *s, int fd, int af, DnsPacket *p); |
91ccab1e | 76 | int dns_scope_socket_tcp(DnsScope *s, int family, const union in_addr_union *address, DnsServer *server, uint16_t port, union sockaddr_union *ret_socket_address); |
da9de738 | 77 | int dns_scope_socket_udp(DnsScope *s, DnsServer *server); |
ad867662 | 78 | |
d0eae64c | 79 | DnsScopeMatch dns_scope_good_domain(DnsScope *s, DnsQuery *q, uint64_t query_flags); |
011696f7 | 80 | bool dns_scope_good_key(DnsScope *s, const DnsResourceKey *key); |
74b2466e | 81 | |
2c27fbca | 82 | DnsServer *dns_scope_get_dns_server(DnsScope *s); |
44db02d0 | 83 | unsigned dns_scope_get_n_dns_servers(DnsScope *s); |
5e8bc852 | 84 | void dns_scope_next_dns_server(DnsScope *s, DnsServer *if_current); |
1716f6dc LP |
85 | |
86 | int dns_scope_llmnr_membership(DnsScope *s, bool b); | |
0db4c90a | 87 | int dns_scope_mdns_membership(DnsScope *s, bool b); |
623a4c97 | 88 | |
3b991089 | 89 | int dns_scope_make_reply_packet(DnsScope *s, uint16_t id, int rcode, DnsQuestion *q, DnsAnswer *answer, DnsAnswer *soa, bool tentative, DnsPacket **ret); |
623a4c97 | 90 | void dns_scope_process_query(DnsScope *s, DnsStream *stream, DnsPacket *p); |
ec2c5e43 | 91 | |
775ae354 | 92 | DnsTransaction *dns_scope_find_transaction(DnsScope *scope, DnsResourceKey *key, uint64_t query_flags); |
a4076574 LP |
93 | |
94 | int dns_scope_notify_conflict(DnsScope *scope, DnsResourceRecord *rr); | |
95 | void dns_scope_check_conflicts(DnsScope *scope, DnsPacket *p); | |
4d506d6b LP |
96 | |
97 | void dns_scope_dump(DnsScope *s, FILE *f); | |
a51c1048 LP |
98 | |
99 | DnsSearchDomain *dns_scope_get_search_domains(DnsScope *s); | |
801ad6a6 | 100 | |
3b5bd7d6 | 101 | bool dns_scope_name_wants_search_domain(DnsScope *s, const char *name); |
edbcc1fd LP |
102 | |
103 | bool dns_scope_network_good(DnsScope *s); | |
97ebebbc LP |
104 | |
105 | int dns_scope_ifindex(DnsScope *s); | |
53fda2bb | 106 | |
1a63fc54 | 107 | int dns_scope_announce(DnsScope *scope, bool goodbye); |
6db6a464 DR |
108 | |
109 | int dns_scope_add_dnssd_services(DnsScope *scope); | |
6db6a464 | 110 | int dns_scope_remove_dnssd_services(DnsScope *scope); |
f76fa088 | 111 | |
ca5394d2 | 112 | bool dns_scope_is_default_route(DnsScope *scope); |
e0930aa6 LP |
113 | |
114 | int dns_scope_dump_cache_to_json(DnsScope *scope, JsonVariant **ret); |