Merge pull request #231 from metalefty/g_sck_get_peer_cred

common: workaround for #146
This commit is contained in:
jsorg71 2015-03-23 21:19:18 -07:00
commit 7f8ec757de

View File

@ -86,6 +86,12 @@ extern char **environ;
#include <linux/unistd.h> #include <linux/unistd.h>
#endif #endif
/* sys/ucred.h needs to be included to use struct xucred
* in FreeBSD and OS X. No need for other BSDs */
#if defined(__FreeBSD__) || defined(__APPLE__)
#include <sys/ucred.h>
#endif
/* for solaris */ /* for solaris */
#if !defined(PF_LOCAL) #if !defined(PF_LOCAL)
#define PF_LOCAL AF_UNIX #define PF_LOCAL AF_UNIX
@ -656,6 +662,28 @@ g_sck_get_peer_cred(int sck, int *pid, int *uid, int *gid)
*gid = credentials.gid; *gid = credentials.gid;
} }
return 0; return 0;
#elif defined(LOCAL_PEERCRED)
/* FreeBSD, OS X reach here*/
struct xucred xucred;
unsigned int xucred_length;
xucred_length = sizeof(xucred);
if (getsockopt(sck, SOL_SOCKET, LOCAL_PEERCRED, &xucred, &xucred_length))
{
return 1;
}
if (pid !=0)
{
*pid = 0; /* can't get pid in FreeBSD, OS X */
}
if (uid != 0)
{
*uid = xucred.cr_uid;
}
if (gid != 0) {
*gid = xucred.cr_gid;
}
return 0;
#else #else
return 1; return 1;
#endif #endif