4 * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
5 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
10 #ifndef HAVE_GETPEEREID
12 #include <sys/types.h>
13 #include <ac/unistd.h>
15 #include <ac/socket.h>
20 #include <grp.h> /* for NGROUPS on Tru64 5.1 */
22 #include <sys/ucred.h>
25 #if !defined(SO_PEERCRED) && !defined(LOCAL_PEERCRED) && \
26 defined(HAVE_SENDMSG) && defined(HAVE_MSGHDR_MSG_ACCRIGHTS)
34 int getpeereid( int s, uid_t *euid, gid_t *egid )
37 #if defined( SO_PEERCRED )
38 struct ucred peercred;
39 size_t peercredlen = sizeof peercred;
41 if(( getsockopt( s, SOL_SOCKET, SO_PEERCRED,
42 (void *)&peercred, &peercredlen ) == 0 )
43 && ( peercredlen == sizeof peercred ))
50 #elif defined( LOCAL_PEERCRED )
51 struct xucred peercred;
52 socklen_t peercredlen = sizeof peercred;
54 if(( getsockopt( s, LOCAL_PEERCRED, 1,
55 (void *)&peercred, &peercredlen ) == 0 )
56 && ( peercred.cr_version == XUCRED_VERSION ))
58 *euid = peercred.cr_uid;
59 *egid = peercred.cr_gid;
62 #elif defined( DO_SENDMSG )
65 struct msghdr msg = {0};
68 iov.iov_base = (char*) &dummy;
72 msg.msg_accrights = (char *)fd;
73 msg.msg_accrightslen = sizeof(fd);
74 if( recvmsg( s, &msg, MSG_PEEK) >= 0 && msg.msg_accrightslen == sizeof(int) )
76 /* We must receive a valid descriptor, it must be a pipe,
77 * and it must only be accessible by its owner.
79 dummy = fstat( fd[0], &st );
81 if( dummy == 0 && S_ISFIFO(st.st_mode) &&
82 ((st.st_mode & (S_IRWXG|S_IRWXO)) == 0))
90 #endif /* LDAP_PF_LOCAL */
95 #endif /* HAVE_GETPEEREID */