diff options
Diffstat (limited to 'libvncclient')
-rw-r--r-- | libvncclient/rfbproto.c | 29 | ||||
-rw-r--r-- | libvncclient/sockets.c | 29 |
2 files changed, 53 insertions, 5 deletions
diff --git a/libvncclient/rfbproto.c b/libvncclient/rfbproto.c index 07584f6..5a83e47 100644 --- a/libvncclient/rfbproto.c +++ b/libvncclient/rfbproto.c @@ -29,6 +29,8 @@ #endif #ifndef WIN32 #include <unistd.h> +#include <sys/types.h> +#include <sys/stat.h> #else #define strncasecmp _strnicmp #endif @@ -342,6 +344,15 @@ DefaultSupportedMessagesTightVNC(rfbClient* client) SetServer2Client(client, rfbTextChat); } +static rfbBool +IsUnixSocket(const char *name) +{ + struct stat sb; + if(stat(name, &sb) && (sb.st_mode & S_IFMT) == S_IFSOCK) + return TRUE; + return FALSE; +} + /* * ConnectToRFBServer. */ @@ -378,13 +389,21 @@ ConnectToRFBServer(rfbClient* client,const char *hostname, int port) return TRUE; } - if (!StringToIPAddr(hostname, &host)) { - rfbClientLog("Couldn't convert '%s' to host address\n", hostname); - return FALSE; +#ifndef WIN32 + if(IsUnixSocket(hostname)) + /* serverHost is a UNIX socket. */ + client->sock = ConnectClientToUnixSock(hostname); + else +#endif + { + /* serverHost is a hostname */ + if (!StringToIPAddr(hostname, &host)) { + rfbClientLog("Couldn't convert '%s' to host address\n", hostname); + return FALSE; + } + client->sock = ConnectClientToTcpAddr(host, port); } - client->sock = ConnectClientToTcpAddr(host, port); - if (client->sock < 0) { rfbClientLog("Unable to connect to VNC server\n"); return FALSE; diff --git a/libvncclient/sockets.c b/libvncclient/sockets.c index 7f350e2..5cfc743 100644 --- a/libvncclient/sockets.c +++ b/libvncclient/sockets.c @@ -38,6 +38,7 @@ #else #include <sys/socket.h> #include <netinet/in.h> +#include <sys/un.h> #include <netinet/tcp.h> #include <arpa/inet.h> #include <netdb.h> @@ -297,6 +298,34 @@ ConnectClientToTcpAddr(unsigned int host, int port) return sock; } +int +ConnectClientToUnixSock(const char *sockFile) +{ +#ifdef WIN32 + rfbClientErr("Windows doesn't support UNIX sockets\n"); + return -1; +#else + int sock; + struct sockaddr_un addr; + addr.sun_family = AF_UNIX; + strcpy(addr.sun_path, sockFile); + + sock = socket(AF_UNIX, SOCK_STREAM, 0); + if (sock < 0) { + rfbClientErr("ConnectToUnixSock: socket (%s)\n",strerror(errno)); + return -1; + } + + if (connect(sock, (struct sockaddr *)&addr, sizeof(addr.sun_family) + strlen(addr.sun_path)) < 0) { + rfbClientErr("ConnectToUnixSock: connect\n"); + close(sock); + return -1; + } + + return sock; +#endif +} + /* |