From b24673100feeaf6ac981461d749bfdcdeda982af Mon Sep 17 00:00:00 2001 From: Mike Ryan Date: Sat, 25 May 2019 14:43:19 -0700 Subject: [PATCH] resolve hostname using getaddrinfo --- comms.c | 35 +++++++++++++++++++---------------- 1 file changed, 19 insertions(+), 16 deletions(-) diff --git a/comms.c b/comms.c index 9c609a4..86a552d 100644 --- a/comms.c +++ b/comms.c @@ -5,6 +5,7 @@ #include #include #include +#include #include #include "comms.h" @@ -106,36 +107,35 @@ char *hs100_send(char *servaddr, char *msg) size_t s_len; int sock; uint8_t *s, *recvbuf; - struct sockaddr_in address; + struct addrinfo hints, *res; uint32_t msglen; size_t recvsize; - char *recvmsg; + char *recvmsg = NULL; s = hs100_encode(&s_len, msg); if (s == NULL) return NULL; - sock = socket(AF_INET, SOCK_STREAM, 0); + memset(&hints, 0, sizeof(hints)); + hints.ai_family = PF_INET; + hints.ai_socktype = SOCK_STREAM; + hints.ai_flags = AI_NUMERICSERV; // numeric port + + if (getaddrinfo(servaddr, "9999", &hints, &res) != 0) + return NULL; + + sock = socket(res->ai_family, res->ai_socktype, res->ai_protocol); if (sock < 0) - return NULL; + goto out; - memset(&address, '0', sizeof(struct sockaddr_in)); - - address.sin_family = AF_INET; - address.sin_port = htons(9999); - - if (inet_pton(AF_INET, servaddr, &address.sin_addr) <= 0) - return NULL; - - if (connect(sock, (struct sockaddr *)&address, - sizeof(struct sockaddr_in)) < 0) - return NULL; + if (connect(sock, res->ai_addr, res->ai_addrlen) < 0) + goto out; send(sock, s, s_len, 0); free(s); recvsize = recv(sock, &msglen, sizeof(msglen), MSG_PEEK); if (recvsize != sizeof(msglen)) { - return NULL; + goto out; } msglen = ntohl(msglen) + 4; recvbuf = calloc(1, (size_t) msglen); @@ -143,5 +143,8 @@ char *hs100_send(char *servaddr, char *msg) close(sock); recvmsg = hs100_decode(recvbuf, msglen); free(recvbuf); + +out: + freeaddrinfo(res); return recvmsg; }