/* SPDX-License-Identifier: LGPL-2.1-or-later */ #pragma once #include #include "sd-event.h" #include "sd-netlink.h" #include "sd-network.h" #include "hashmap.h" #include "list.h" #include "ordered-set.h" #include "resolve-util.h" #include "varlink.h" typedef struct Manager Manager; #include "resolved-dns-query.h" #include "resolved-dns-search-domain.h" #include "resolved-dns-stream.h" #include "resolved-dns-stub.h" #include "resolved-dns-trust-anchor.h" #include "resolved-link.h" #define MANAGER_SEARCH_DOMAINS_MAX 256 #define MANAGER_DNS_SERVERS_MAX 256 typedef struct EtcHosts { Hashmap *by_address; Hashmap *by_name; Set *no_address; } EtcHosts; struct Manager { sd_event *event; ResolveSupport llmnr_support; ResolveSupport mdns_support; DnssecMode dnssec_mode; DnsOverTlsMode dns_over_tls_mode; DnsCacheMode enable_cache; DnsStubListenerMode dns_stub_listener_mode; #if ENABLE_DNS_OVER_TLS DnsTlsManagerData dnstls_data; #endif /* Network */ Hashmap *links; sd_netlink *rtnl; sd_event_source *rtnl_event_source; sd_network_monitor *network_monitor; sd_event_source *network_event_source; /* DNS query management */ Hashmap *dns_transactions; LIST_HEAD(DnsQuery, dns_queries); unsigned n_dns_queries; LIST_HEAD(DnsStream, dns_streams); unsigned n_dns_streams[_DNS_STREAM_TYPE_MAX]; /* Unicast dns */ LIST_HEAD(DnsServer, dns_servers); LIST_HEAD(DnsServer, fallback_dns_servers); unsigned n_dns_servers; /* counts both main and fallback */ DnsServer *current_dns_server; LIST_HEAD(DnsSearchDomain, search_domains); unsigned n_search_domains; bool need_builtin_fallbacks; bool read_resolv_conf; bool resolve_unicast_single_label; struct stat resolv_conf_stat; DnsTrustAnchor trust_anchor; LIST_HEAD(DnsScope, dns_scopes); DnsScope *unicast_scope; /* LLMNR */ int llmnr_ipv4_udp_fd; int llmnr_ipv6_udp_fd; int llmnr_ipv4_tcp_fd; int llmnr_ipv6_tcp_fd; sd_event_source *llmnr_ipv4_udp_event_source; sd_event_source *llmnr_ipv6_udp_event_source; sd_event_source *llmnr_ipv4_tcp_event_source; sd_event_source *llmnr_ipv6_tcp_event_source; /* mDNS */ int mdns_ipv4_fd; int mdns_ipv6_fd; /* DNS-SD */ Hashmap *dnssd_services; sd_event_source *mdns_ipv4_event_source; sd_event_source *mdns_ipv6_event_source; /* dbus */ sd_bus *bus; /* The hostname we publish on LLMNR and mDNS */ char *full_hostname; char *llmnr_hostname; char *mdns_hostname; DnsResourceKey *llmnr_host_ipv4_key; DnsResourceKey *llmnr_host_ipv6_key; DnsResourceKey *mdns_host_ipv4_key; DnsResourceKey *mdns_host_ipv6_key; /* Watch the system hostname */ int hostname_fd; sd_event_source *hostname_event_source; sd_event_source *sigusr1_event_source; sd_event_source *sigusr2_event_source; sd_event_source *sigrtmin1_event_source; unsigned n_transactions_total; unsigned n_dnssec_verdict[_DNSSEC_VERDICT_MAX]; /* Data from /etc/hosts */ EtcHosts etc_hosts; usec_t etc_hosts_last, etc_hosts_mtime; ino_t etc_hosts_ino; dev_t etc_hosts_dev; bool read_etc_hosts; OrderedSet *dns_extra_stub_listeners; /* Local DNS stub on 127.0.0.53:53 */ sd_event_source *dns_stub_udp_event_source; sd_event_source *dns_stub_tcp_event_source; Hashmap *polkit_registry; VarlinkServer *varlink_server; }; /* Manager */ int manager_new(Manager **ret); Manager* manager_free(Manager *m); int manager_start(Manager *m); uint32_t manager_find_mtu(Manager *m); int manager_write(Manager *m, int fd, DnsPacket *p); int 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); int manager_recv(Manager *m, int fd, DnsProtocol protocol, DnsPacket **ret); int manager_find_ifindex(Manager *m, int family, const union in_addr_union *in_addr); LinkAddress* manager_find_link_address(Manager *m, int family, const union in_addr_union *in_addr); void manager_refresh_rrs(Manager *m); int manager_next_hostname(Manager *m); bool manager_our_packet(Manager *m, DnsPacket *p); DnsScope* manager_find_scope(Manager *m, DnsPacket *p); void manager_verify_all(Manager *m); DEFINE_TRIVIAL_CLEANUP_FUNC(Manager*, manager_free); /* For some reason we need some extra cmsg space on some kernels/archs. One of those days we need to figure out why */ #define EXTRA_CMSG_SPACE 1024 int manager_is_own_hostname(Manager *m, const char *name); int manager_compile_dns_servers(Manager *m, OrderedSet **servers); int manager_compile_search_domains(Manager *m, OrderedSet **domains, int filter_route); DnssecMode manager_get_dnssec_mode(Manager *m); bool manager_dnssec_supported(Manager *m); DnsOverTlsMode manager_get_dns_over_tls_mode(Manager *m); void manager_dnssec_verdict(Manager *m, DnssecVerdict verdict, const DnsResourceKey *key); bool manager_routable(Manager *m); void manager_flush_caches(Manager *m); void manager_reset_server_features(Manager *m); void manager_cleanup_saved_user(Manager *m); bool manager_next_dnssd_names(Manager *m);