]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/resolve/resolved-manager.h
resolve: allow configurable bind address
[thirdparty/systemd.git] / src / resolve / resolved-manager.h
CommitLineData
53e1b683 1/* SPDX-License-Identifier: LGPL-2.1+ */
74b2466e
LP
2#pragma once
3
61c12865
LP
4#include <sys/stat.h>
5
091a364c 6#include "sd-event.h"
1c4baffc 7#include "sd-netlink.h"
71d35b6b
TA
8#include "sd-network.h"
9
74b2466e 10#include "hashmap.h"
71d35b6b 11#include "list.h"
9176a57c 12#include "ordered-set.h"
af49ca27 13#include "resolve-util.h"
9581bb84 14#include "varlink.h"
091a364c 15
091a364c 16typedef struct Manager Manager;
19b50b5b 17
1ae43295 18#include "resolved-conf.h"
19b50b5b 19#include "resolved-dns-query.h"
a51c1048 20#include "resolved-dns-search-domain.h"
19b50b5b 21#include "resolved-dns-stream.h"
0d2cd476 22#include "resolved-dns-trust-anchor.h"
19b50b5b 23#include "resolved-link.h"
4e945a6f 24
b950ee06
LP
25#define MANAGER_SEARCH_DOMAINS_MAX 256
26#define MANAGER_DNS_SERVERS_MAX 256
eed857b7 27
37b7cc8d
ZJS
28typedef struct EtcHosts {
29 Hashmap *by_address;
30 Hashmap *by_name;
fd373593 31 Set *no_address;
37b7cc8d
ZJS
32} EtcHosts;
33
1f05101f
SS
34typedef struct DNSStubListenerExtra {
35 int fd;
36
37 DnsStubListenerMode mode;
38 SocketAddress address;
39 sd_event_source *dns_stub_extra_event_source;
40} DNSStubListenerExtra;
41
091a364c
TG
42struct Manager {
43 sd_event *event;
44
af49ca27
LP
45 ResolveSupport llmnr_support;
46 ResolveSupport mdns_support;
ad6c0475 47 DnssecMode dnssec_mode;
c9299be2 48 DnsOverTlsMode dns_over_tls_mode;
37d7a7d9 49 DnsCacheMode enable_cache;
1ae43295 50 DnsStubListenerMode dns_stub_listener_mode;
1716f6dc 51
e22c5b20
IT
52#if ENABLE_DNS_OVER_TLS
53 DnsTlsManagerData dnstls_data;
54#endif
55
1716f6dc 56 /* Network */
74b2466e
LP
57 Hashmap *links;
58
1c4baffc 59 sd_netlink *rtnl;
74b2466e
LP
60 sd_event_source *rtnl_event_source;
61
091a364c 62 sd_network_monitor *network_monitor;
74b2466e
LP
63 sd_event_source *network_event_source;
64
1716f6dc 65 /* DNS query management */
ec2c5e43 66 Hashmap *dns_transactions;
1716f6dc
LP
67 LIST_HEAD(DnsQuery, dns_queries);
68 unsigned n_dns_queries;
69
623a4c97 70 LIST_HEAD(DnsStream, dns_streams);
652ba568 71 unsigned n_dns_streams[_DNS_STREAM_TYPE_MAX];
623a4c97 72
1716f6dc 73 /* Unicast dns */
74b2466e 74 LIST_HEAD(DnsServer, dns_servers);
4e945a6f 75 LIST_HEAD(DnsServer, fallback_dns_servers);
eed857b7 76 unsigned n_dns_servers; /* counts both main and fallback */
74b2466e
LP
77 DnsServer *current_dns_server;
78
a51c1048 79 LIST_HEAD(DnsSearchDomain, search_domains);
eed857b7 80 unsigned n_search_domains;
a51c1048 81
c2f1e83e
ZJS
82 bool need_builtin_fallbacks;
83 bool read_resolv_conf;
3b5bd7d6 84 bool resolve_unicast_single_label;
a51c1048 85
61c12865 86 struct stat resolv_conf_stat;
5cb36f41 87
0d2cd476
LP
88 DnsTrustAnchor trust_anchor;
89
74b2466e
LP
90 LIST_HEAD(DnsScope, dns_scopes);
91 DnsScope *unicast_scope;
92
1716f6dc
LP
93 /* LLMNR */
94 int llmnr_ipv4_udp_fd;
95 int llmnr_ipv6_udp_fd;
623a4c97
LP
96 int llmnr_ipv4_tcp_fd;
97 int llmnr_ipv6_tcp_fd;
1716f6dc
LP
98
99 sd_event_source *llmnr_ipv4_udp_event_source;
100 sd_event_source *llmnr_ipv6_udp_event_source;
623a4c97
LP
101 sd_event_source *llmnr_ipv4_tcp_event_source;
102 sd_event_source *llmnr_ipv6_tcp_event_source;
1716f6dc 103
bc7702b0
DM
104 /* mDNS */
105 int mdns_ipv4_fd;
106 int mdns_ipv6_fd;
107
6501dd31
DR
108 /* DNS-SD */
109 Hashmap *dnssd_services;
110
bc7702b0
DM
111 sd_event_source *mdns_ipv4_event_source;
112 sd_event_source *mdns_ipv6_event_source;
113
74b2466e
LP
114 /* dbus */
115 sd_bus *bus;
623a4c97
LP
116
117 /* The hostname we publish on LLMNR and mDNS */
e96de0ce 118 char *full_hostname;
78c6a153
LP
119 char *llmnr_hostname;
120 char *mdns_hostname;
121 DnsResourceKey *llmnr_host_ipv4_key;
122 DnsResourceKey *llmnr_host_ipv6_key;
400cb36e
DR
123 DnsResourceKey *mdns_host_ipv4_key;
124 DnsResourceKey *mdns_host_ipv6_key;
eb60f9cd
LP
125
126 /* Watch the system hostname */
127 int hostname_fd;
128 sd_event_source *hostname_event_source;
902bb5d8 129
4d506d6b 130 sd_event_source *sigusr1_event_source;
bc81447e 131 sd_event_source *sigusr2_event_source;
d55b0463 132 sd_event_source *sigrtmin1_event_source;
a150ff5e
LP
133
134 unsigned n_transactions_total;
59c5b597 135 unsigned n_dnssec_verdict[_DNSSEC_VERDICT_MAX];
dd0bc0f1
LP
136
137 /* Data from /etc/hosts */
37b7cc8d 138 EtcHosts etc_hosts;
dd0bc0f1 139 usec_t etc_hosts_last, etc_hosts_mtime;
aa5408e2
GS
140 ino_t etc_hosts_ino;
141 dev_t etc_hosts_dev;
86317087 142 bool read_etc_hosts;
b30bf55d
LP
143
144 /* Local DNS stub on 127.0.0.53:53 */
145 int dns_stub_udp_fd;
146 int dns_stub_tcp_fd;
147
1f05101f
SS
148 OrderedSet *dns_extra_stub_listeners;
149
b30bf55d
LP
150 sd_event_source *dns_stub_udp_event_source;
151 sd_event_source *dns_stub_tcp_event_source;
84b0f133
DR
152
153 Hashmap *polkit_registry;
9581bb84
LP
154
155 VarlinkServer *varlink_server;
091a364c
TG
156};
157
158/* Manager */
159
160int manager_new(Manager **ret);
74b2466e
LP
161Manager* manager_free(Manager *m);
162
edc501d4 163int manager_start(Manager *m);
74b2466e 164
e1c95994 165uint32_t manager_find_mtu(Manager *m);
091a364c 166
72290734 167int manager_write(Manager *m, int fd, DnsPacket *p);
b30bf55d 168int manager_send(Manager *m, int fd, int ifindex, int family, const union in_addr_union *destination, uint16_t port, const union in_addr_union *source, DnsPacket *p);
1716f6dc 169int manager_recv(Manager *m, int fd, DnsProtocol protocol, DnsPacket **ret);
74b2466e 170
623a4c97 171int manager_find_ifindex(Manager *m, int family, const union in_addr_union *in_addr);
4e945a6f 172LinkAddress* manager_find_link_address(Manager *m, int family, const union in_addr_union *in_addr);
ec2c5e43 173
eb60f9cd 174void manager_refresh_rrs(Manager *m);
ec2c5e43 175int manager_next_hostname(Manager *m);
74b2466e 176
a4076574
LP
177bool manager_our_packet(Manager *m, DnsPacket *p);
178DnsScope* manager_find_scope(Manager *m, DnsPacket *p);
091a364c 179
902bb5d8
LP
180void manager_verify_all(Manager *m);
181
091a364c 182DEFINE_TRIVIAL_CLEANUP_FUNC(Manager*, manager_free);
091a364c 183
15dd4515 184/* For some reason we need some extra cmsg space on some kernels/archs. One of those days we need to figure out why */
623a4c97 185#define EXTRA_CMSG_SPACE 1024
4e945a6f 186
78c6a153
LP
187int manager_is_own_hostname(Manager *m, const char *name);
188
9176a57c 189int manager_compile_dns_servers(Manager *m, OrderedSet **servers);
6f7da49d 190int manager_compile_search_domains(Manager *m, OrderedSet **domains, int filter_route);
c69fa7e3
LP
191
192DnssecMode manager_get_dnssec_mode(Manager *m);
193bool manager_dnssec_supported(Manager *m);
59c5b597 194
c9299be2 195DnsOverTlsMode manager_get_dns_over_tls_mode(Manager *m);
5d67a7ae 196
59c5b597 197void manager_dnssec_verdict(Manager *m, DnssecVerdict verdict, const DnsResourceKey *key);
011696f7
LP
198
199bool manager_routable(Manager *m, int family);
ba35662f
LP
200
201void manager_flush_caches(Manager *m);
59c0fd0e 202void manager_reset_server_features(Manager *m);
943ef07c
LP
203
204void manager_cleanup_saved_user(Manager *m);
e7c1b0e4
DR
205
206bool manager_next_dnssd_names(Manager *m);