|
unbound
0.1
|
Implementation of net_help.h. More...
#include "config.h"#include <ldns/ldns.h>#include "util/net_help.h"#include "util/log.h"#include "util/data/dname.h"#include "util/module.h"#include "util/regional.h"#include <fcntl.h>#include <openssl/ssl.h>#include <openssl/err.h>Defines | |
| #define | MAX_ADDR_STRLEN 128 /* characters */ |
| max length of an IP address (the address portion) that we allow | |
Functions | |
| int | str_is_ip6 (const char *str) |
| See if string is ip4 or ip6. | |
| int | fd_set_nonblock (int s) |
| Set fd nonblocking. | |
| int | fd_set_block (int s) |
| Set fd (back to) blocking. | |
| int | is_pow2 (size_t num) |
| See if number is a power of 2. | |
| void * | memdup (void *data, size_t len) |
| Allocate memory and copy over contents. | |
| void | log_addr (enum verbosity_value v, const char *str, struct sockaddr_storage *addr, socklen_t addrlen) |
| Prints the sockaddr in readable format with log_info. | |
| int | extstrtoaddr (const char *str, struct sockaddr_storage *addr, socklen_t *addrlen) |
| Convert address string, with "@port" appendix, to sockaddr. | |
| int | ipstrtoaddr (const char *ip, int port, struct sockaddr_storage *addr, socklen_t *addrlen) |
| Convert ip address string and port to sockaddr. | |
| int | netblockstrtoaddr (const char *str, int port, struct sockaddr_storage *addr, socklen_t *addrlen, int *net) |
| Convert ip netblock (ip/netsize) string and port to sockaddr. | |
| void | log_nametypeclass (enum verbosity_value v, const char *str, uint8_t *name, uint16_t type, uint16_t dclass) |
| Print string with neat domain name, type and class. | |
| void | log_name_addr (enum verbosity_value v, const char *str, uint8_t *zone, struct sockaddr_storage *addr, socklen_t addrlen) |
| Prints zone name and sockaddr in readable format with log_info. | |
| int | sockaddr_cmp (struct sockaddr_storage *addr1, socklen_t len1, struct sockaddr_storage *addr2, socklen_t len2) |
| Compare two sockaddrs. | |
| int | sockaddr_cmp_addr (struct sockaddr_storage *addr1, socklen_t len1, struct sockaddr_storage *addr2, socklen_t len2) |
| Compare two sockaddrs. | |
| int | addr_is_ip6 (struct sockaddr_storage *addr, socklen_t len) |
| Checkout address family. | |
| void | addr_mask (struct sockaddr_storage *addr, socklen_t len, int net) |
| Make sure the sockaddr ends in zeroes. | |
| int | addr_in_common (struct sockaddr_storage *addr1, int net1, struct sockaddr_storage *addr2, int net2, socklen_t addrlen) |
| See how many bits are shared, equal, between two addrs. | |
| void | addr_to_str (struct sockaddr_storage *addr, socklen_t addrlen, char *buf, size_t len) |
| Put address into string, works for IPv4 and IPv6. | |
| int | addr_is_ip4mapped (struct sockaddr_storage *addr, socklen_t addrlen) |
| See if sockaddr is an ipv6 mapped ipv4 address, "::ffff:0.0.0.0". | |
| int | addr_is_broadcast (struct sockaddr_storage *addr, socklen_t addrlen) |
| See if sockaddr is 255.255.255.255. | |
| int | addr_is_any (struct sockaddr_storage *addr, socklen_t addrlen) |
| See if sockaddr is 0.0.0.0 or ::0. | |
| void | sock_list_insert (struct sock_list **list, struct sockaddr_storage *addr, socklen_t len, struct regional *region) |
| Insert new socket list item. | |
| void | sock_list_prepend (struct sock_list **list, struct sock_list *add) |
| Append one list to another. | |
| int | sock_list_find (struct sock_list *list, struct sockaddr_storage *addr, socklen_t len) |
| Find addr in list. | |
| void | sock_list_merge (struct sock_list **list, struct regional *region, struct sock_list *add) |
| Merge socklist into another socket list. | |
| void | log_crypto_err (const char *str) |
| Log libcrypto error with descriptive string. | |
| void * | listen_sslctx_create (char *key, char *pem, char *verifypem) |
| create SSL listen context | |
| void * | connect_sslctx_create (char *key, char *pem, char *verifypem) |
| create SSL connect context | |
| void * | incoming_ssl_fd (void *sslctx, int fd) |
| accept a new fd and wrap it in a BIO in SSL | |
| void * | outgoing_ssl_fd (void *sslctx, int fd) |
| connect a new fd and wrap it in a BIO in SSL | |
Variables | |
| uint16_t | EDNS_ADVERTISED_SIZE = 4096 |
| default value for EDNS ADVERTISED size | |
Implementation of net_help.h.
| int str_is_ip6 | ( | const char * | str | ) |
See if string is ip4 or ip6.
| str,: | IP specification. |
Referenced by calc_num46(), ipstrtoaddr(), listening_ports_open(), net_test(), netblockstrtoaddr(), outside_network_create(), service(), and ub_ctx_hosts().
| int fd_set_nonblock | ( | int | s | ) |
Set fd nonblocking.
| s,: | file descriptor. |
References log_err().
Referenced by comm_point_perform_accept(), create_tcp_accept_sock(), create_udp_sock(), find_create_proxy(), outnet_tcp_take_into_use(), service(), service_tcp_listen(), tube_create(), tube_read_msg(), and tube_write_msg().
| int fd_set_block | ( | int | s | ) |
Set fd (back to) blocking.
| s,: | file descriptor. |
References log_err().
Referenced by handle_req(), tube_read_msg(), and tube_write_msg().
| int is_pow2 | ( | size_t | num | ) |
See if number is a power of 2.
| num,: | the value. |
Referenced by net_test().
| void* memdup | ( | void * | data, |
| size_t | len | ||
| ) |
Allocate memory and copy over contents.
| data,: | what to copy over. |
| len,: | length of data. |
Referenced by add_bg_result(), autr_tp_create(), context_deserialize_answer(), dns_cache_store(), fill_res(), get_rr_content(), get_rr_nameclass(), key_entry_copy(), libworker_fillup_fg(), lz_setup_implicit(), move_into_cache(), neg_insert_data(), neg_setup_data_node(), neg_setup_zone_node(), new_entry(), packed_rrset_copy_alloc(), parse_arg_name(), parse_dname(), pending_udp_query(), qlist_add_line(), repinfo_copy_rrsets(), serviced_callbacks(), serviced_create(), setup_if(), setup_qinfo_edns(), tcp_relay_read(), ub_packed_rrset_heap_key(), worker_create(), and write_q().
| void log_addr | ( | enum verbosity_value | v, |
| const char * | str, | ||
| struct sockaddr_storage * | addr, | ||
| socklen_t | addrlen | ||
| ) |
Prints the sockaddr in readable format with log_info.
Debug helper.
| v,: | at what verbosity level to print this. |
| str,: | descriptive string printed with it. |
| addr,: | the sockaddr to print. Can be ip4 or ip6. |
| addrlen,: | length of addr. |
References verbose(), and verbosity.
Referenced by comm_point_perform_accept(), comm_point_send_udp_msg(), comm_point_send_udp_msg_if(), comm_point_tcp_handle_read(), comm_point_tcp_handle_write(), contact_server(), create_tcp_accept_sock(), create_udp_sock(), delegpt_log(), do_infra_rtt(), do_proxy(), iter_filter_unsuitable(), iter_merge_retry_counts(), outnet_tcp_cb(), outnet_tcp_take_into_use(), outnet_udp_cb(), pending_find_match(), pick_outgoing_tcp(), processQueryTargets(), run_scenario(), service_recv(), service_send(), service_tcp_listen(), service_tcp_relay(), serviced_callbacks(), serviced_tcp_callback(), serviced_udp_callback(), sock_list_logentry(), ssl_handshake(), tcp_proxy_delete(), and worker_handle_request().
| int extstrtoaddr | ( | const char * | str, |
| struct sockaddr_storage * | addr, | ||
| socklen_t * | addrlen | ||
| ) |
Convert address string, with "@port" appendix, to sockaddr.
Uses DNS port by default.
| str,: | the string |
| addr,: | where to store sockaddr. |
| addrlen,: | length of stored sockaddr is returned. |
References ipstrtoaddr(), and MAX_ADDR_STRLEN.
Referenced by ah(), contact_server(), interfacechecks(), main(), open_svr(), parse_delegpt(), read_fwds_addr(), read_stubs_addr(), replay_moment_read(), replay_range_read(), service(), ub_ctx_set_fwd(), and warn_hosts().
| int ipstrtoaddr | ( | const char * | ip, |
| int | port, | ||
| struct sockaddr_storage * | addr, | ||
| socklen_t * | addrlen | ||
| ) |
Convert ip address string and port to sockaddr.
| ip,: | ip4 or ip6 address string. |
| port,: | port number, host format. |
| addr,: | where to store sockaddr. |
| addrlen,: | length of stored sockaddr is returned. |
References MAX_ADDR_STRLEN, and str_is_ip6().
Referenced by cfg_ptr_reverse(), contact_server(), do_flush_infra(), extstrtoaddr(), infra_test(), interfacechecks(), net_test(), netblockstrtoaddr(), service(), and setup_if().
| int netblockstrtoaddr | ( | const char * | ip, |
| int | port, | ||
| struct sockaddr_storage * | addr, | ||
| socklen_t * | addrlen, | ||
| int * | net | ||
| ) |
Convert ip netblock (ip/netsize) string and port to sockaddr.
*SLOW*, does a malloc internally to avoid writing over 'ip' string.
| ip,: | ip4 or ip6 address string. |
| port,: | port number, host format. |
| addr,: | where to store sockaddr. |
| addrlen,: | length of stored sockaddr is returned. |
| net,: | netblock size is returned. |
References addr_mask(), ipstrtoaddr(), log_err(), and str_is_ip6().
Referenced by acl_list_str_cfg(), aclchecks(), donotq_str_cfg(), and read_addrs().
| void log_nametypeclass | ( | enum verbosity_value | v, |
| const char * | str, | ||
| uint8_t * | name, | ||
| uint16_t | type, | ||
| uint16_t | dclass | ||
| ) |
Print string with neat domain name, type and class.
| v,: | at what verbosity level to print this. |
| str,: | string of message. |
| name,: | domain name uncompressed wireformat. |
| type,: | host format RR type. |
| dclass,: | host format RR class. |
References dname_str(), log_info(), and verbosity.
Referenced by add_item(), anchor_store_new_rr(), anchors_assemble_rrsets(), autr_process_prime(), autr_tp_remove(), cache_fill_missing(), check_zone_invariants(), dnskey_verify_rrset_sig(), generate_a_aaaa_check(), generate_dnskey_prefetch(), generate_ns_check(), generate_parentside_target_query(), generate_target_query(), get_random_data(), iter_mark_cycle_targets(), iter_mark_pside_cycle_targets(), iter_scrub_ds(), local_zone_out(), local_zones_print(), log_query_info(), log_rrset_key(), lz_setup_implicit(), mesh_make_new_space(), neg_insert_data(), nsec3_do_prove_nameerror(), nsec3_prove_closest_encloser(), nsec3_prove_nameerror(), prime_stub(), primeResponseToKE(), processCollectClass(), processDLVLookup(), processFindKey(), processInit(), processPrimeResponse(), processValidate(), remove_item(), remove_rrset(), scrub_message(), update_events(), val_check_nonsecure(), val_dlv_init(), val_neg_addreferral(), val_neg_addreply(), val_neg_dlvlookup(), val_nsec_check_dlv(), val_verify_rrset(), validate_any_response(), validate_cname_response(), validate_msg_signatures(), validate_positive_response(), verifytest_file(), verifytest_rrset(), and worker_handle_request().
| void log_name_addr | ( | enum verbosity_value | v, |
| const char * | str, | ||
| uint8_t * | zone, | ||
| struct sockaddr_storage * | addr, | ||
| socklen_t | addrlen | ||
| ) |
Prints zone name and sockaddr in readable format with log_info.
Debug.
| v,: | at what verbosity level to print this. |
| str,: | descriptive string printed with it. |
| zone,: | DNS domain name, uncompressed wireformat. |
| addr,: | the sockaddr to print. Can be ip4 or ip6. |
| addrlen,: | length of addr. |
References dname_str(), verbose(), and verbosity.
Referenced by process_response(), processQueryTargets(), and serviced_udp_callback().
| int sockaddr_cmp | ( | struct sockaddr_storage * | addr1, |
| socklen_t | len1, | ||
| struct sockaddr_storage * | addr2, | ||
| socklen_t | len2 | ||
| ) |
Compare two sockaddrs.
Imposes an ordering on the addresses. Compares address and port.
| addr1,: | address 1. |
| len1,: | lengths of addr1. |
| addr2,: | address 2. |
| len2,: | lengths of addr2. |
References INET6_SIZE, INET_SIZE, and log_assert.
Referenced by answer_check_it(), find_create_proxy(), infra_compfunc(), infra_del_host(), pending_cmp(), pending_find_match(), pending_matches_current(), pending_udp_query(), and serviced_cmp().
| int sockaddr_cmp_addr | ( | struct sockaddr_storage * | addr1, |
| socklen_t | len1, | ||
| struct sockaddr_storage * | addr2, | ||
| socklen_t | len2 | ||
| ) |
Compare two sockaddrs.
Compares address, not the port.
| addr1,: | address 1. |
| len1,: | lengths of addr1. |
| addr2,: | address 2. |
| len2,: | lengths of addr2. |
References INET6_SIZE, INET_SIZE, and log_assert.
Referenced by addr_tree_compare(), delegpt_find_addr(), net_test(), and sock_list_find().
| int addr_is_ip6 | ( | struct sockaddr_storage * | addr, |
| socklen_t | len | ||
| ) |
Checkout address family.
| addr,: | the sockaddr to examine. |
| len,: | the length of addr. |
Referenced by addr_in_common(), addr_is_ip4mapped(), addr_mask(), addr_to_str(), addr_tree_lookup(), cfg_ptr_reverse(), contact_server(), delegpt_add_target(), hash_addr(), iter_filter_unsuitable(), open_svr(), outnet_tcp_take_into_use(), perfsetup(), pick_outgoing_tcp(), proxy_list_clear(), randomize_and_send_udp(), server_stats_insquery(), service_recv(), service_tcp_listen(), serviced_encode(), udp_sockport(), and warn_hosts().
| void addr_mask | ( | struct sockaddr_storage * | addr, |
| socklen_t | len, | ||
| int | net | ||
| ) |
Make sure the sockaddr ends in zeroes.
For tree insertion and subsequent comparison.
| addr,: | the ip4 or ip6 addr. |
| len,: | length of addr. |
| net,: | number of bits to leave untouched, the rest of the netblock address is zeroed. |
References addr_is_ip6().
Referenced by net_test(), and netblockstrtoaddr().
| int addr_in_common | ( | struct sockaddr_storage * | addr1, |
| int | net1, | ||
| struct sockaddr_storage * | addr2, | ||
| int | net2, | ||
| socklen_t | addrlen | ||
| ) |
See how many bits are shared, equal, between two addrs.
| addr1,: | first addr. |
| net1,: | netblock size of first addr. |
| addr2,: | second addr. |
| net2,: | netblock size of second addr. |
| addrlen,: | length of first addr and of second addr. They must be of the same length (i.e. same type IP4, IP6). |
References addr_is_ip6(), log_assert, and match().
Referenced by addr_tree_init_parents(), addr_tree_lookup(), and net_test().
| void addr_to_str | ( | struct sockaddr_storage * | addr, |
| socklen_t | addrlen, | ||
| char * | buf, | ||
| size_t | len | ||
| ) |
Put address into string, works for IPv4 and IPv6.
| addr,: | address |
| addrlen,: | length of address |
| buf,: | result string stored here |
| len,: | length of buf. On failure a string with "error" is stored inside. |
References addr_is_ip6().
Referenced by dump_infra_host(), errinf_origin(), get_mesh_status(), print_dp_details(), ssl_print_name_dp(), and worker_handle_request().
| int addr_is_ip4mapped | ( | struct sockaddr_storage * | addr, |
| socklen_t | addrlen | ||
| ) |
See if sockaddr is an ipv6 mapped ipv4 address, "::ffff:0.0.0.0".
| addr,: | address |
| addrlen,: | length of address |
References addr_is_ip6().
Referenced by net_test(), and udp_send_errno_needs_log().
| int addr_is_broadcast | ( | struct sockaddr_storage * | addr, |
| socklen_t | addrlen | ||
| ) |
See if sockaddr is 255.255.255.255.
| addr,: | address |
| addrlen,: | length of address |
Referenced by udp_send_errno_needs_log().
| int addr_is_any | ( | struct sockaddr_storage * | addr, |
| socklen_t | addrlen | ||
| ) |
See if sockaddr is 0.0.0.0 or ::0.
| addr,: | address |
| addrlen,: | length of address |
Referenced by net_test(), and pick_outgoing_tcp().
| void sock_list_insert | ( | struct sock_list ** | list, |
| struct sockaddr_storage * | addr, | ||
| socklen_t | len, | ||
| struct regional * | region | ||
| ) |
Insert new socket list item.
If fails logs error.
| list,: | pointer to pointer to first item. |
| addr,: | address or NULL if 'cache'. |
| len,: | length of addr, or 0 if 'cache'. |
| region,: | where to allocate |
References sock_list::addr, sock_list::len, log_assert, log_err(), sock_list::next, and regional_alloc().
Referenced by generate_parentside_target_query(), mesh_new_prefetch(), processInitRequest(), processInitRequest3(), processQueryResponse(), sock_list_merge(), and val_blacklist().
| void sock_list_prepend | ( | struct sock_list ** | list, |
| struct sock_list * | add | ||
| ) |
Append one list to another.
Must both be from same qstate(regional).
| list,: | pointer to result list that is modified. |
| add,: | item(s) to add. They are prepended to list. |
References sock_list::next.
Referenced by val_blacklist().
| int sock_list_find | ( | struct sock_list * | list, |
| struct sockaddr_storage * | addr, | ||
| socklen_t | len | ||
| ) |
Find addr in list.
| list,: | to search in |
| addr,: | address to look for. |
| len,: | length. Can be 0, look for 'cache entry'. |
References sock_list::addr, sock_list::len, sock_list::next, and sockaddr_cmp_addr().
Referenced by iter_fill_rtt(), and sock_list_merge().
| void sock_list_merge | ( | struct sock_list ** | list, |
| struct regional * | region, | ||
| struct sock_list * | add | ||
| ) |
Merge socklist into another socket list.
Allocates the new entries freshly and copies them over, so also performs a region switchover. Allocation failures are logged.
| list,: | the destination list (checked for duplicates) |
| region,: | where to allocate |
| add,: | the list of entries to add. |
References sock_list::addr, sock_list::len, sock_list::next, sock_list_find(), and sock_list_insert().
Referenced by generate_request(), and val_blacklist().
| void log_crypto_err | ( | const char * | str | ) |
Log libcrypto error with descriptive string.
Calls log_err().
| str,: | what failed. |
References log_err().
Referenced by connect_sslctx_create(), daemon_remote_create(), handle_req(), incoming_ssl_fd(), listen_sslctx_create(), outgoing_ssl_fd(), recv_one(), send_em(), ssl_handle_read(), ssl_handle_write(), ssl_handshake(), ssl_print_text(), ssl_read_line(), and write_q().
| void* listen_sslctx_create | ( | char * | key, |
| char * | pem, | ||
| char * | verifypem | ||
| ) |
create SSL listen context
| key,: | private key file. |
| pem,: | public key cert. |
| verifypem,: | if nonNULL, verifylocation file. return SSL_CTX* or NULL on failure (logged). |
References log_crypto_err(), and log_err().
Referenced by perform_setup().
| void* connect_sslctx_create | ( | char * | key, |
| char * | pem, | ||
| char * | verifypem | ||
| ) |
create SSL connect context
| key,: | if nonNULL (also pem nonNULL), the client private key. |
| pem,: | client public key (or NULL if key is NULL). |
| verifypem,: | if nonNULL used for verifylocation file. |
References log_crypto_err(), and log_err().
Referenced by libworker_setup(), perform_setup(), and send_em().
| void* incoming_ssl_fd | ( | void * | sslctx, |
| int | fd | ||
| ) |
accept a new fd and wrap it in a BIO in SSL
| sslctx,: | the SSL_CTX to use (from listen_sslctx_create()). |
| fd,: | from accept, nonblocking. |
References log_crypto_err().
Referenced by comm_point_tcp_accept_callback().
| void* outgoing_ssl_fd | ( | void * | sslctx, |
| int | fd | ||
| ) |
connect a new fd and wrap it in a BIO in SSL
| sslctx,: | the SSL_CTX to use (from connect_sslctx_create()) |
| fd,: | from connect. |
References log_crypto_err().
Referenced by outnet_tcp_take_into_use(), and send_em().
| uint16_t EDNS_ADVERTISED_SIZE = 4096 |
default value for EDNS ADVERTISED size
Advertised size of EDNS capabilities.
Referenced by answer_from_cache(), answer_norec_from_cache(), chaos_replystr(), config_apply(), error_encode(), local_encode(), mesh_do_callback(), mesh_send_reply(), qlist_parse_line(), serviced_encode(), and worker_handle_request().
1.7.6.1