- (djm) [openbsd-compat/port-linux.c] Check whether SELinux is enabled
[openssh-git.git] / openbsd-compat / bsd-getpeereid.c
blob5f7e677e5cdf3e75fc73d3b6c462346aae4ec572
1 /*
2 * Copyright (c) 2002,2004 Damien Miller <djm@mindrot.org>
4 * Permission to use, copy, modify, and distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 #include "includes.h"
19 #if !defined(HAVE_GETPEEREID)
21 #include <sys/types.h>
22 #include <sys/socket.h>
24 #include <unistd.h>
26 #if defined(SO_PEERCRED)
27 int
28 getpeereid(int s, uid_t *euid, gid_t *gid)
30 struct ucred cred;
31 socklen_t len = sizeof(cred);
33 if (getsockopt(s, SOL_SOCKET, SO_PEERCRED, &cred, &len) < 0)
34 return (-1);
35 *euid = cred.uid;
36 *gid = cred.gid;
38 return (0);
40 #elif defined(HAVE_GETPEERUCRED)
42 #ifdef HAVE_UCRED_H
43 # include <ucred.h>
44 #endif
46 int
47 getpeereid(int s, uid_t *euid, gid_t *gid)
49 ucred_t *ucred = NULL;
51 if (getpeerucred(s, &ucred) == -1)
52 return (-1);
53 if ((*euid = ucred_geteuid(ucred)) == -1)
54 return (-1);
55 if ((*gid = ucred_getrgid(ucred)) == -1)
56 return (-1);
58 ucred_free(ucred);
60 return (0);
62 #else
63 int
64 getpeereid(int s, uid_t *euid, gid_t *gid)
66 *euid = geteuid();
67 *gid = getgid();
69 return (0);
71 #endif /* defined(SO_PEERCRED) */
73 #endif /* !defined(HAVE_GETPEEREID) */