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