Hi silvioprog, Have you considered simply using
IN6_IS_ADDR_V4MAPPED on the v6 address, and if it matches, extracting the mapped v4 address? Happy hacking! Christian On 11/28/19 4:35 AM, silvioprog wrote: > Hi. > > I have a function which checks if the sa_family is AF_INET or AF_INET6 > and formats the client address as IPv4 (e.g. 127.0.0.1) or IPv6 (e.g. > ::1) into a string. However, when I enable the dual stack in MHD, it > always returns AF_INET6 in sa_family even when passing -4 as parameter > in curl. > > I'm using MHD_get_connection_info(..., > MHD_CONNECTION_INFO_CLIENT_ADDRESS)->client_addr to get the client > address and the formatting function is in attachment below. > > Is there any flag to force MHD to return AF_INET when the client > connects explicitly as IPv4? > > Thank you! > > // Attachment: function to format the client address as IPv4 or IPv6 > int get_ip(const void *socket, char *buf, size_t size) { > const struct sockaddr *sa; > if (!socket || !buf || (ssize_t) size < 0) > return EINVAL; > sa = socket; > switch (sa->sa_family) { > case AF_INET: > if (!inet_ntop(AF_INET, &(((struct sockaddr_in *) sa)->sin_addr), buf, > size)) > return errno; > break; > case AF_INET6: > if (!inet_ntop(AF_INET6, &(((struct sockaddr_in6 *) > sa)->sin6_addr), buf, > size)) > return errno; > break; > default: > return EINVAL; > } > return 0; > } > > -- > Silvio Clécio
signature.asc
Description: OpenPGP digital signature