| /* SPDX-License-Identifier: LGPL-2.1-or-later */ |
| #pragma once |
| |
| #include <sys/stat.h> |
| |
| #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); |