|
unbound 0.1
|
Send queries to outside servers and wait for answers from servers. More...
#include <outside_network.h>
Data Fields | |
| struct comm_base * | base |
| Base for select calls. | |
| time_t * | now_secs |
| pointer to time in seconds | |
| struct timeval * | now_tv |
| pointer to time in microseconds | |
| struct sldns_buffer * | udp_buff |
| buffer shared by UDP connections, since there is only one datagram at any time. | |
| size_t | svcd_overhead |
| serviced_callbacks malloc overhead when processing multiple identical serviced queries to the same server. | |
| int | use_caps_for_id |
| use x20 bits to encode additional ID random bits | |
| int | want_to_quit |
| outside network wants to quit. | |
| size_t | unwanted_replies |
| number of unwanted replies received (for statistics) | |
| size_t | unwanted_total |
| cumulative total of unwanted replies (for defense) | |
| size_t | unwanted_threshold |
| threshold when to take defensive action. | |
| void(* | unwanted_action )(void *) |
| what action to take, called when defensive action is needed | |
| void * | unwanted_param |
| user param for action | |
| struct port_comm * | unused_fds |
| linked list of available commpoints, unused file descriptors, for use as outgoing UDP ports. | |
| int | do_udp |
| if udp is done | |
| int | delayclose |
| if udp is delay-closed (delayed answers do not meet closed port) | |
| struct timeval | delay_tv |
| timeout for delayclose | |
| int | udp_connect |
| if we perform udp-connect, connect() for UDP socket to mitigate ICMP side channel leakage | |
| size_t | num_udp_outgoing |
| number of udp packets sent. | |
| struct port_if * | ip4_ifs |
| array of outgoing IP4 interfaces | |
| int | num_ip4 |
| number of outgoing IP4 interfaces | |
| struct port_if * | ip6_ifs |
| array of outgoing IP6 interfaces | |
| int | num_ip6 |
| number of outgoing IP6 interfaces | |
| struct pending * | udp_wait_first |
| pending udp queries waiting to be sent out, waiting for fd | |
| struct pending * | udp_wait_last |
| last pending udp query in list | |
| rbtree_type * | pending |
| pending udp answers. | |
| rbtree_type * | serviced |
| serviced queries, sorted by qbuf, addr, dnssec | |
| struct infra_cache * | infra |
| host cache, pointer but not owned by outnet. | |
| struct ub_randstate * | rnd |
| where to get random numbers | |
| void * | sslctx |
| ssl context to create ssl wrapped TCP with DNS connections | |
| int | tls_use_sni |
| if SNI will be used for TLS connections | |
| int | tcp_mss |
| maximum segment size of tcp socket | |
| int | ip_dscp |
| IP_TOS socket option requested on the sockets. | |
| struct pending_tcp ** | tcp_conns |
| Array of tcp pending used for outgoing TCP connections. | |
| size_t | num_tcp |
| number of tcp communication points. | |
| size_t | num_tcp_outgoing |
| number of tcp communication points in use. | |
| size_t | max_reuse_tcp_queries |
| max number of queries on a reuse connection | |
| int | tcp_reuse_timeout |
| timeout for REUSE entries in milliseconds. | |
| int | tcp_auth_query_timeout |
| timeout in milliseconds for TCP queries to auth servers. | |
| rbtree_type | tcp_reuse |
| tree of still-open and waiting tcp connections for reuse. | |
| size_t | tcp_reuse_max |
| max number of tcp_reuse entries we want to keep open | |
| struct reuse_tcp * | tcp_reuse_first |
| first and last(oldest) in lru list of reuse connections. | |
| struct reuse_tcp * | tcp_reuse_last |
| struct pending_tcp * | tcp_free |
| list of tcp comm points that are free for use | |
| struct waiting_tcp * | tcp_wait_first |
| list of tcp queries waiting for a buffer | |
| struct waiting_tcp * | tcp_wait_last |
| last of waiting query list | |
Send queries to outside servers and wait for answers from servers.
Contains answer-listen sockets.
| int outside_network::want_to_quit |
outside network wants to quit.
Stop queued msgs from sent.
Referenced by auth_xfer_probe_lookup_callback(), auth_xfer_probe_timer_callback(), auth_xfer_probe_udp_callback(), auth_xfer_timer(), auth_xfer_transfer_http_callback(), auth_xfer_transfer_lookup_callback(), auth_xfer_transfer_tcp_callback(), auth_xfer_transfer_timer_callback(), auth_zonemd_dnskey_lookup_callback(), libworker_bg_done_cb(), outnet_send_wait_udp(), outside_network_create(), outside_network_delete(), outside_network_quit_prepare(), and use_free_buffer().
| size_t outside_network::unwanted_threshold |
threshold when to take defensive action.
If 0 then never.
Referenced by outnet_udp_cb(), and outside_network_create().
| struct port_comm* outside_network::unused_fds |
linked list of available commpoints, unused file descriptors, for use as outgoing UDP ports.
cp.fd=-1 in them.
Referenced by outnet_get_mem(), outnet_send_wait_udp(), outside_network_create(), outside_network_delete(), pending_udp_query(), portcomm_loweruse(), and select_ifport().
| rbtree_type* outside_network::pending |
pending udp answers.
sorted by id, addr
Referenced by iterator_set_ip46_support(), outnet_get_mem(), outnet_udp_cb(), outside_network_create(), outside_network_delete(), pending_delete(), and select_id().
| struct pending_tcp** outside_network::tcp_conns |
Array of tcp pending used for outgoing TCP connections.
Each can be used to establish a TCP connection with a server. The file descriptors are -1 if they are free, and need to be opened for the tcp connection. Can be used for ip4 and ip6.
Referenced by check_removal(), check_snip(), create_pending_tcp(), create_pending_tcp(), outnet_get_mem(), outside_network_delete(), and tcp_reuse_tree_list_test().
| rbtree_type outside_network::tcp_reuse |
tree of still-open and waiting tcp connections for reuse.
can be closed and reopened to get a new tcp connection. or reused to the same destination again. with timeout to close. Entries are of type struct reuse_tcp. The entries are both active and empty connections.
Referenced by check_snip(), check_tree_and_list(), empty_tree(), outnet_tcp_cb(), outside_network_create(), outside_network_delete(), reuse_tcp_find(), reuse_tcp_insert(), reuse_tcp_remove_serviced_keep(), reuse_tcp_remove_tree_list(), and tcp_reuse_tree_list_test().
| struct reuse_tcp* outside_network::tcp_reuse_first |
first and last(oldest) in lru list of reuse connections.
the oldest can be closed to get a new free pending_tcp if needed The list contains empty connections, that wait for timeout or a new query that can use the existing connection.
Referenced by check_removal(), check_snip(), check_tree_and_list(), empty_tree(), outnet_waiting_tcp_list_add_first(), outside_network_delete(), reuse_tcp_insert(), reuse_tcp_lru_snip(), reuse_tcp_lru_touch(), reuse_tcp_remove_tree_list(), tcp_reuse_tree_list_test(), and use_free_buffer().