Skip to content

Commit

Permalink
Use getaddrinfo() to fill struct sockaddr_un. It now supports
Browse files Browse the repository at this point in the history
SOCK_DGRAM and SOCK_SEQPACKET in addition to SOCK_STREAM.
  • Loading branch information
hrs-allbsd committed Oct 3, 2015
1 parent 4c60a05 commit 1c9fbb5
Showing 1 changed file with 25 additions and 16 deletions.
41 changes: 25 additions & 16 deletions bin/cat/cat.c
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ __FBSDID("$FreeBSD$");
#include <sys/socket.h>
#include <sys/un.h>
#include <errno.h>
#include <netdb.h>
#endif

#include <ctype.h>
Expand Down Expand Up @@ -302,31 +303,39 @@ raw_cat(int rfd)
static int
udom_open(const char *path, int flags)
{
struct sockaddr_un sou;
int fd;
unsigned int len;

bzero(&sou, sizeof(sou));
struct addrinfo hints, *res, *res0;
char rpath[PATH_MAX];
int fd, error;

/*
* Construct the unix domain socket address and attempt to connect
* Construct the unix domain socket address and attempt to connect.
*/
fd = socket(AF_UNIX, SOCK_STREAM, 0);
if (fd >= 0) {
sou.sun_family = AF_UNIX;
if ((len = strlcpy(sou.sun_path, path,
sizeof(sou.sun_path))) >= sizeof(sou.sun_path)) {
close(fd);
errno = ENAMETOOLONG;
bzero(&hints, sizeof(hints));
hints.ai_family = AF_LOCAL;
if (realpath(path, rpath) == NULL)
return (-1);
error = getaddrinfo(rpath, NULL, &hints, &res0);
if (error) {
warn("%s", gai_strerror(error));
errno = EINVAL;
return (-1);
}
for (res = res0; res != NULL; res = res->ai_next) {
fd = socket(res->ai_family, res->ai_socktype,
res->ai_protocol);
if (fd < 0) {
freeaddrinfo(res0);
return (-1);
}
len = offsetof(struct sockaddr_un, sun_path[len+1]);

if (connect(fd, (void *)&sou, len) < 0) {
error = connect(fd, res->ai_addr, res->ai_addrlen);
if (error == 0)
break;
else {
close(fd);
fd = -1;
}
}
freeaddrinfo(res0);

/*
* handle the open flags by shutting down appropriate directions
Expand Down

0 comments on commit 1c9fbb5

Please sign in to comment.