xref: /freebsd-src/contrib/ldns/ldns/net.h (revision 5afab0e5e56fe90a378fb57249600e7924e1cab2)
16709dfe5SDag-Erling Smørgrav /*
26709dfe5SDag-Erling Smørgrav  * net.h
36709dfe5SDag-Erling Smørgrav  *
46709dfe5SDag-Erling Smørgrav  * DNS Resolver definitions
56709dfe5SDag-Erling Smørgrav  *
66709dfe5SDag-Erling Smørgrav  * a Net::DNS like library for C
76709dfe5SDag-Erling Smørgrav  *
86709dfe5SDag-Erling Smørgrav  * (c) NLnet Labs, 2005-2006
96709dfe5SDag-Erling Smørgrav  *
106709dfe5SDag-Erling Smørgrav  * See the file LICENSE for the license
116709dfe5SDag-Erling Smørgrav  */
126709dfe5SDag-Erling Smørgrav 
136709dfe5SDag-Erling Smørgrav #ifndef LDNS_NET_H
146709dfe5SDag-Erling Smørgrav #define LDNS_NET_H
156709dfe5SDag-Erling Smørgrav 
166709dfe5SDag-Erling Smørgrav #include <ldns/ldns.h>
176709dfe5SDag-Erling Smørgrav #include <sys/socket.h>
186709dfe5SDag-Erling Smørgrav 
196709dfe5SDag-Erling Smørgrav #ifdef __cplusplus
206709dfe5SDag-Erling Smørgrav extern "C" {
216709dfe5SDag-Erling Smørgrav #endif
226709dfe5SDag-Erling Smørgrav 
236709dfe5SDag-Erling Smørgrav #define LDNS_DEFAULT_TIMEOUT_SEC 5
246709dfe5SDag-Erling Smørgrav #define LDNS_DEFAULT_TIMEOUT_USEC 0
256709dfe5SDag-Erling Smørgrav 
266709dfe5SDag-Erling Smørgrav /**
276709dfe5SDag-Erling Smørgrav  * \file
286709dfe5SDag-Erling Smørgrav  *
296709dfe5SDag-Erling Smørgrav  * Contains functions to send and receive packets over a network.
306709dfe5SDag-Erling Smørgrav  */
316709dfe5SDag-Erling Smørgrav 
326709dfe5SDag-Erling Smørgrav /**
33*5afab0e5SDag-Erling Smørgrav  * Sends a buffer to an ip using udp and return the response as a ldns_pkt
346709dfe5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
356709dfe5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
366709dfe5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
376709dfe5SDag-Erling Smørgrav  * \param[in] timeout the timeout value for the network
386709dfe5SDag-Erling Smørgrav  * \param[out] answersize size of the packet
396709dfe5SDag-Erling Smørgrav  * \param[out] result packet with the answer
406709dfe5SDag-Erling Smørgrav  * \return status
416709dfe5SDag-Erling Smørgrav  */
426709dfe5SDag-Erling Smørgrav ldns_status ldns_udp_send(uint8_t **result, ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout, size_t *answersize);
436709dfe5SDag-Erling Smørgrav 
446709dfe5SDag-Erling Smørgrav /**
456709dfe5SDag-Erling Smørgrav  * Send an udp query and don't wait for an answer but return
466709dfe5SDag-Erling Smørgrav  * the socket
476709dfe5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
486709dfe5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
496709dfe5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
506709dfe5SDag-Erling Smørgrav  * \param[in] timeout *unused*, was the timeout value for the network
51*5afab0e5SDag-Erling Smørgrav  * \return the socket used or -1 on failure
52*5afab0e5SDag-Erling Smørgrav  */
53*5afab0e5SDag-Erling Smørgrav int ldns_udp_bgsend2(ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
54*5afab0e5SDag-Erling Smørgrav 
55*5afab0e5SDag-Erling Smørgrav /**
56*5afab0e5SDag-Erling Smørgrav  * Send an udp query and don't wait for an answer but return
57*5afab0e5SDag-Erling Smørgrav  * the socket
58*5afab0e5SDag-Erling Smørgrav  * This function has the flaw that it returns 0 on failure, but 0 could be a
59*5afab0e5SDag-Erling Smørgrav  * valid socket.  Please use ldns_udp_bgsend2 instead of this function.
60*5afab0e5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
61*5afab0e5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
62*5afab0e5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
63*5afab0e5SDag-Erling Smørgrav  * \param[in] timeout *unused*, was the timeout value for the network
64*5afab0e5SDag-Erling Smørgrav  * \return the socket used or 0 on failure
656709dfe5SDag-Erling Smørgrav  */
666709dfe5SDag-Erling Smørgrav int ldns_udp_bgsend(ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
676709dfe5SDag-Erling Smørgrav 
686709dfe5SDag-Erling Smørgrav /**
696709dfe5SDag-Erling Smørgrav  * Send an tcp query and don't wait for an answer but return
706709dfe5SDag-Erling Smørgrav  * the socket
716709dfe5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
726709dfe5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
736709dfe5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
746709dfe5SDag-Erling Smørgrav  * \param[in] timeout the timeout value for the connect attempt
75*5afab0e5SDag-Erling Smørgrav  * \return the socket used or -1 on failure
76*5afab0e5SDag-Erling Smørgrav  */
77*5afab0e5SDag-Erling Smørgrav int ldns_tcp_bgsend2(ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
78*5afab0e5SDag-Erling Smørgrav 
79*5afab0e5SDag-Erling Smørgrav /**
80*5afab0e5SDag-Erling Smørgrav  * Send an tcp query and don't wait for an answer but return
81*5afab0e5SDag-Erling Smørgrav  * the socket
82*5afab0e5SDag-Erling Smørgrav  * This function has the flaw that it returns 0 on failure, but 0 could be a
83*5afab0e5SDag-Erling Smørgrav  * valid socket.  Please use ldns_tcp_bgsend2 instead of this function.
84*5afab0e5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
85*5afab0e5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
86*5afab0e5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
87*5afab0e5SDag-Erling Smørgrav  * \param[in] timeout the timeout value for the connect attempt
88*5afab0e5SDag-Erling Smørgrav  * \return the socket used or 0 on failure
896709dfe5SDag-Erling Smørgrav  */
906709dfe5SDag-Erling Smørgrav int ldns_tcp_bgsend(ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
916709dfe5SDag-Erling Smørgrav 
926709dfe5SDag-Erling Smørgrav /**
93*5afab0e5SDag-Erling Smørgrav  * Sends a buffer to an ip using tcp and return the response as a ldns_pkt
946709dfe5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
956709dfe5SDag-Erling Smørgrav  * \param[in] qbin the ldns_buffer to be send
966709dfe5SDag-Erling Smørgrav  * \param[in] to the ip addr to send to
976709dfe5SDag-Erling Smørgrav  * \param[in] tolen length of the ip addr
986709dfe5SDag-Erling Smørgrav  * \param[in] timeout the timeout value for the network
996709dfe5SDag-Erling Smørgrav  * \param[out] answersize size of the packet
1006709dfe5SDag-Erling Smørgrav  * \param[out] result packet with the answer
1016709dfe5SDag-Erling Smørgrav  * \return status
1026709dfe5SDag-Erling Smørgrav  */
1036709dfe5SDag-Erling Smørgrav ldns_status ldns_tcp_send(uint8_t **result, ldns_buffer *qbin, const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout, size_t *answersize);
1046709dfe5SDag-Erling Smørgrav 
1056709dfe5SDag-Erling Smørgrav /**
1066709dfe5SDag-Erling Smørgrav  * Sends ptk to the nameserver at the resolver object. Returns the data
1076709dfe5SDag-Erling Smørgrav  * as a ldns_pkt
1086709dfe5SDag-Erling Smørgrav  *
1096709dfe5SDag-Erling Smørgrav  * \param[out] pkt packet received from the nameserver
1106709dfe5SDag-Erling Smørgrav  * \param[in] r the resolver to use
1116709dfe5SDag-Erling Smørgrav  * \param[in] query_pkt the query to send
1126709dfe5SDag-Erling Smørgrav  * \return status
1136709dfe5SDag-Erling Smørgrav  */
1146709dfe5SDag-Erling Smørgrav ldns_status ldns_send(ldns_pkt **pkt, ldns_resolver *r, const ldns_pkt *query_pkt);
1156709dfe5SDag-Erling Smørgrav 
1166709dfe5SDag-Erling Smørgrav /**
1176709dfe5SDag-Erling Smørgrav  * Sends and ldns_buffer (presumably containing a packet to the nameserver at the resolver object. Returns the data
1186709dfe5SDag-Erling Smørgrav  * as a ldns_pkt
1196709dfe5SDag-Erling Smørgrav  *
1206709dfe5SDag-Erling Smørgrav  * \param[out] pkt packet received from the nameserver
1216709dfe5SDag-Erling Smørgrav  * \param[in] r the resolver to use
1226709dfe5SDag-Erling Smørgrav  * \param[in] qb the buffer to send
1236709dfe5SDag-Erling Smørgrav  * \param[in] tsig_mac the tsig MAC to authenticate the response with (NULL to do no TSIG authentication)
1246709dfe5SDag-Erling Smørgrav  * \return status
1256709dfe5SDag-Erling Smørgrav  */
1266709dfe5SDag-Erling Smørgrav ldns_status ldns_send_buffer(ldns_pkt **pkt, ldns_resolver *r, ldns_buffer *qb, ldns_rdf *tsig_mac);
1276709dfe5SDag-Erling Smørgrav 
1286709dfe5SDag-Erling Smørgrav /**
1296709dfe5SDag-Erling Smørgrav  * Create a tcp socket to the specified address
1306709dfe5SDag-Erling Smørgrav  * \param[in] to ip and family
1316709dfe5SDag-Erling Smørgrav  * \param[in] tolen length of to
1326709dfe5SDag-Erling Smørgrav  * \param[in] timeout timeout for the connect attempt
133*5afab0e5SDag-Erling Smørgrav  * \return a socket descriptor or -1 on failure
134*5afab0e5SDag-Erling Smørgrav  */
135*5afab0e5SDag-Erling Smørgrav int ldns_tcp_connect2(const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
136*5afab0e5SDag-Erling Smørgrav 
137*5afab0e5SDag-Erling Smørgrav /**
138*5afab0e5SDag-Erling Smørgrav  * Create a tcp socket to the specified address
139*5afab0e5SDag-Erling Smørgrav  * This function has the flaw that it returns 0 on failure, but 0 could be a
140*5afab0e5SDag-Erling Smørgrav  * valid socket.  Please use ldns_tcp_connect2 instead of this function.
141*5afab0e5SDag-Erling Smørgrav  * \param[in] to ip and family
142*5afab0e5SDag-Erling Smørgrav  * \param[in] tolen length of to
143*5afab0e5SDag-Erling Smørgrav  * \param[in] timeout timeout for the connect attempt
144*5afab0e5SDag-Erling Smørgrav  * \return a socket descriptor or 0 on failure
1456709dfe5SDag-Erling Smørgrav  */
1466709dfe5SDag-Erling Smørgrav int ldns_tcp_connect(const struct sockaddr_storage *to, socklen_t tolen, struct timeval timeout);
1476709dfe5SDag-Erling Smørgrav 
1486709dfe5SDag-Erling Smørgrav /**
1496709dfe5SDag-Erling Smørgrav  * Create a udp socket to the specified address
1506709dfe5SDag-Erling Smørgrav  * \param[in] to ip and family
1516709dfe5SDag-Erling Smørgrav  * \param[in] timeout *unused*, was timeout for the socket
152*5afab0e5SDag-Erling Smørgrav  * \return a socket descriptor or -1 on failure
153*5afab0e5SDag-Erling Smørgrav  */
154*5afab0e5SDag-Erling Smørgrav int ldns_udp_connect2(const struct sockaddr_storage *to, struct timeval timeout);
155*5afab0e5SDag-Erling Smørgrav 
156*5afab0e5SDag-Erling Smørgrav /**
157*5afab0e5SDag-Erling Smørgrav  * Create a udp socket to the specified address
158*5afab0e5SDag-Erling Smørgrav  * This function has the flaw that it returns 0 on failure, but 0 could be a
159*5afab0e5SDag-Erling Smørgrav  * valid socket.  Please use ldns_udp_connect2 instead of this function.
160*5afab0e5SDag-Erling Smørgrav  * \param[in] to ip and family
161*5afab0e5SDag-Erling Smørgrav  * \param[in] timeout *unused*, was timeout for the socket
162*5afab0e5SDag-Erling Smørgrav  * \return a socket descriptor or 0 on failure
1636709dfe5SDag-Erling Smørgrav  */
1646709dfe5SDag-Erling Smørgrav int ldns_udp_connect(const struct sockaddr_storage *to, struct timeval timeout);
1656709dfe5SDag-Erling Smørgrav 
1666709dfe5SDag-Erling Smørgrav /**
1676709dfe5SDag-Erling Smørgrav  * send a query via tcp to a server. Don't want for the answer
1686709dfe5SDag-Erling Smørgrav  *
1696709dfe5SDag-Erling Smørgrav  * \param[in] qbin the buffer to send
1706709dfe5SDag-Erling Smørgrav  * \param[in] sockfd the socket to use
1716709dfe5SDag-Erling Smørgrav  * \param[in] to which ip to send it
1726709dfe5SDag-Erling Smørgrav  * \param[in] tolen socketlen
1736709dfe5SDag-Erling Smørgrav  * \return number of bytes sent
1746709dfe5SDag-Erling Smørgrav  */
1756709dfe5SDag-Erling Smørgrav ssize_t ldns_tcp_send_query(ldns_buffer *qbin, int sockfd, const struct sockaddr_storage *to, socklen_t tolen);
1766709dfe5SDag-Erling Smørgrav 
1776709dfe5SDag-Erling Smørgrav /**
1786709dfe5SDag-Erling Smørgrav  * send a query via udp to a server. Don;t want for the answer
1796709dfe5SDag-Erling Smørgrav  *
1806709dfe5SDag-Erling Smørgrav  * \param[in] qbin the buffer to send
1816709dfe5SDag-Erling Smørgrav  * \param[in] sockfd the socket to use
1826709dfe5SDag-Erling Smørgrav  * \param[in] to which ip to send it
1836709dfe5SDag-Erling Smørgrav  * \param[in] tolen socketlen
1846709dfe5SDag-Erling Smørgrav  * \return number of bytes sent
1856709dfe5SDag-Erling Smørgrav  */
1866709dfe5SDag-Erling Smørgrav ssize_t ldns_udp_send_query(ldns_buffer *qbin, int sockfd, const struct sockaddr_storage *to, socklen_t tolen);
1876709dfe5SDag-Erling Smørgrav 
1886709dfe5SDag-Erling Smørgrav /**
1896709dfe5SDag-Erling Smørgrav  * Gives back a raw packet from the wire and reads the header data from the given
1906709dfe5SDag-Erling Smørgrav  * socket. Allocates the data (of size size) itself, so don't forget to free
1916709dfe5SDag-Erling Smørgrav  *
1926709dfe5SDag-Erling Smørgrav  * \param[in] sockfd the socket to read from
1936709dfe5SDag-Erling Smørgrav  * \param[out] size the number of bytes that are read
1946709dfe5SDag-Erling Smørgrav  * \param[in] timeout the time allowed between packets.
1956709dfe5SDag-Erling Smørgrav  * \return the data read
1966709dfe5SDag-Erling Smørgrav  */
1976709dfe5SDag-Erling Smørgrav uint8_t *ldns_tcp_read_wire_timeout(int sockfd, size_t *size, struct timeval timeout);
1986709dfe5SDag-Erling Smørgrav 
1996709dfe5SDag-Erling Smørgrav /**
2006709dfe5SDag-Erling Smørgrav  * This routine may block. Use ldns_tcp_read_wire_timeout, it checks timeouts.
2016709dfe5SDag-Erling Smørgrav  * Gives back a raw packet from the wire and reads the header data from the given
2026709dfe5SDag-Erling Smørgrav  * socket. Allocates the data (of size size) itself, so don't forget to free
2036709dfe5SDag-Erling Smørgrav  *
2046709dfe5SDag-Erling Smørgrav  * \param[in] sockfd the socket to read from
2056709dfe5SDag-Erling Smørgrav  * \param[out] size the number of bytes that are read
2066709dfe5SDag-Erling Smørgrav  * \return the data read
2076709dfe5SDag-Erling Smørgrav  */
2086709dfe5SDag-Erling Smørgrav uint8_t *ldns_tcp_read_wire(int sockfd, size_t *size);
2096709dfe5SDag-Erling Smørgrav 
2106709dfe5SDag-Erling Smørgrav /**
2116709dfe5SDag-Erling Smørgrav  * Gives back a raw packet from the wire and reads the header data from the given
2126709dfe5SDag-Erling Smørgrav  * socket. Allocates the data (of size size) itself, so don't forget to free
2136709dfe5SDag-Erling Smørgrav  *
2146709dfe5SDag-Erling Smørgrav  * \param[in] sockfd the socket to read from
2156709dfe5SDag-Erling Smørgrav  * \param[in] fr the address of the client (if applicable)
216986ba33cSDag-Erling Smørgrav  * \param[in] *frlen the length of the client's addr (if applicable)
2176709dfe5SDag-Erling Smørgrav  * \param[out] size the number of bytes that are read
2186709dfe5SDag-Erling Smørgrav  * \return the data read
2196709dfe5SDag-Erling Smørgrav  */
2206709dfe5SDag-Erling Smørgrav uint8_t *ldns_udp_read_wire(int sockfd, size_t *size, struct sockaddr_storage *fr, socklen_t *frlen);
2216709dfe5SDag-Erling Smørgrav 
2226709dfe5SDag-Erling Smørgrav /**
2236709dfe5SDag-Erling Smørgrav  * returns the native sockaddr representation from the rdf.
2246709dfe5SDag-Erling Smørgrav  * \param[in] rd the ldns_rdf to operate on
2256709dfe5SDag-Erling Smørgrav  * \param[in] port what port to use. 0 means; use default (53)
2266709dfe5SDag-Erling Smørgrav  * \param[out] size what is the size of the sockaddr_storage
2276709dfe5SDag-Erling Smørgrav  * \return struct sockaddr* the address in the format so other
2286709dfe5SDag-Erling Smørgrav  * functions can use it (sendto)
2296709dfe5SDag-Erling Smørgrav  */
2306709dfe5SDag-Erling Smørgrav struct sockaddr_storage * ldns_rdf2native_sockaddr_storage(const ldns_rdf *rd, uint16_t port, size_t *size);
2316709dfe5SDag-Erling Smørgrav 
2326709dfe5SDag-Erling Smørgrav /**
2336709dfe5SDag-Erling Smørgrav  * returns an rdf with the sockaddr info. works for ip4 and ip6
2346709dfe5SDag-Erling Smørgrav  * \param[in] sock the struct sockaddr_storage to convert
2356709dfe5SDag-Erling Smørgrav  * \param[in] port what port was used. When NULL this is not set
236*5afab0e5SDag-Erling Smørgrav  * \return ldns_rdf* with the address
2376709dfe5SDag-Erling Smørgrav  */
238986ba33cSDag-Erling Smørgrav ldns_rdf * ldns_sockaddr_storage2rdf(const struct sockaddr_storage *sock, uint16_t *port);
2396709dfe5SDag-Erling Smørgrav 
2406709dfe5SDag-Erling Smørgrav /**
2416709dfe5SDag-Erling Smørgrav  * Prepares the resolver for an axfr query
2426709dfe5SDag-Erling Smørgrav  * The query is sent and the answers can be read with ldns_axfr_next
2436709dfe5SDag-Erling Smørgrav  * \param[in] resolver the resolver to use
244*5afab0e5SDag-Erling Smørgrav  * \param[in] domain the domain to axfr
2456709dfe5SDag-Erling Smørgrav  * \param[in] c the class to use
2466709dfe5SDag-Erling Smørgrav  * \return ldns_status the status of the transfer
2476709dfe5SDag-Erling Smørgrav  */
248986ba33cSDag-Erling Smørgrav ldns_status ldns_axfr_start(ldns_resolver *resolver, const ldns_rdf *domain, ldns_rr_class c);
2496709dfe5SDag-Erling Smørgrav 
2506709dfe5SDag-Erling Smørgrav #ifdef __cplusplus
2516709dfe5SDag-Erling Smørgrav }
2526709dfe5SDag-Erling Smørgrav #endif
2536709dfe5SDag-Erling Smørgrav 
2546709dfe5SDag-Erling Smørgrav #endif  /* LDNS_NET_H */
255