mirror of
https://github.com/NixOS/nix
synced 2025-06-28 17:51:15 +02:00
Merge pull request #11025 from NixOS/backport-11022-to-2.19-maintenance
[Backport 2.19-maintenance] Use proper struct sockpeercred for SO_PEERCRED for OpenBSD
This commit is contained in:
commit
ead814bfa3
1 changed files with 8 additions and 4 deletions
|
@ -202,7 +202,11 @@ static PeerInfo getPeerInfo(int remote)
|
||||||
|
|
||||||
#if defined(SO_PEERCRED)
|
#if defined(SO_PEERCRED)
|
||||||
|
|
||||||
ucred cred;
|
# if defined(__OpenBSD__)
|
||||||
|
struct sockpeercred cred;
|
||||||
|
# else
|
||||||
|
ucred cred;
|
||||||
|
# endif
|
||||||
socklen_t credLen = sizeof(cred);
|
socklen_t credLen = sizeof(cred);
|
||||||
if (getsockopt(remote, SOL_SOCKET, SO_PEERCRED, &cred, &credLen) == -1)
|
if (getsockopt(remote, SOL_SOCKET, SO_PEERCRED, &cred, &credLen) == -1)
|
||||||
throw SysError("getting peer credentials");
|
throw SysError("getting peer credentials");
|
||||||
|
@ -210,9 +214,9 @@ static PeerInfo getPeerInfo(int remote)
|
||||||
|
|
||||||
#elif defined(LOCAL_PEERCRED)
|
#elif defined(LOCAL_PEERCRED)
|
||||||
|
|
||||||
#if !defined(SOL_LOCAL)
|
# if !defined(SOL_LOCAL)
|
||||||
#define SOL_LOCAL 0
|
# define SOL_LOCAL 0
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
xucred cred;
|
xucred cred;
|
||||||
socklen_t credLen = sizeof(cred);
|
socklen_t credLen = sizeof(cred);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue