[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
66/376: nix-daemon: Show name of connecting user
From: |
Ludovic Courtès |
Subject: |
66/376: nix-daemon: Show name of connecting user |
Date: |
Wed, 28 Jan 2015 22:04:05 +0000 |
civodul pushed a commit to tag 1.8
in repository guix.
commit 0c730887c4ec4a03fb854490e422c134a1bf8139
Author: Eelco Dolstra <address@hidden>
Date: Thu Jul 17 15:49:33 2014 +0200
nix-daemon: Show name of connecting user
---
src/nix-daemon/nix-daemon.cc | 13 +++++++------
1 files changed, 7 insertions(+), 6 deletions(-)
diff --git a/src/nix-daemon/nix-daemon.cc b/src/nix-daemon/nix-daemon.cc
index f486806..fd030fe 100644
--- a/src/nix-daemon/nix-daemon.cc
+++ b/src/nix-daemon/nix-daemon.cc
@@ -17,6 +17,7 @@
#include <sys/un.h>
#include <fcntl.h>
#include <errno.h>
+#include <pwd.h>
using namespace nix;
@@ -855,23 +856,23 @@ static void daemonLoop()
closeOnExec(remote);
bool trusted = false;
-
pid_t clientPid = -1;
#if defined(SO_PEERCRED)
/* Get the identity of the caller, if possible. */
- uid_t clientUid = -1;
-
ucred cred;
socklen_t credLen = sizeof(cred);
if (getsockopt(remote, SOL_SOCKET, SO_PEERCRED, &cred, &credLen)
== -1)
throw SysError("getting peer credentials");
clientPid = cred.pid;
- clientUid = cred.uid;
- if (clientUid == 0) trusted = true;
- printMsg(lvlInfo, format("accepted connection from pid %1%, uid
%2%") % clientPid % clientUid);
+ struct passwd * pw = getpwuid(cred.uid);
+ string user = pw ? pw->pw_name : int2String(cred.uid);
+
+ if (cred.uid == 0) trusted = true;
+
+ printMsg(lvlInfo, format("accepted connection from pid %1%, user
%2%") % clientPid % user);
#endif
/* Fork a child to handle the connection. */
- 47/376: Replace message "importing path <...>" with "exporting path <...>", (continued)
- 47/376: Replace message "importing path <...>" with "exporting path <...>", Ludovic Courtès, 2015/01/28
- 58/376: Pass *_proxy vars to bootstrap fetchurl, Ludovic Courtès, 2015/01/28
- 51/376: build-remote.pl: Use ‘nix-store --serve’ on the remote side, Ludovic Courtès, 2015/01/28
- 50/376: Fix closure size display, Ludovic Courtès, 2015/01/28
- 63/376: Get rid of a compiler warning, Ludovic Courtès, 2015/01/28
- 43/376: Remove tabs, Ludovic Courtès, 2015/01/28
- 64/376: nix-daemon: Fix compat with older clients, Ludovic Courtès, 2015/01/28
- 57/376: Manual: Typo, Ludovic Courtès, 2015/01/28
- 53/376: build-remote.pl: Fix build log, Ludovic Courtès, 2015/01/28
- 61/376: Handle case collisions on case-insensitive systems, Ludovic Courtès, 2015/01/28
- 66/376: nix-daemon: Show name of connecting user,
Ludovic Courtès <=
- 59/376: Install systemd and Upstart stuff only on Linux, Ludovic Courtès, 2015/01/28
- 60/376: Make dev-shell script work on Darwin, Ludovic Courtès, 2015/01/28
- 68/376: Ugly hack to fix building on old Darwin, Ludovic Courtès, 2015/01/28
- 75/376: nix-store --serve: Monitor for client disconnects, Ludovic Courtès, 2015/01/28
- 70/376: Better fix for strcasecmp on Darwin, Ludovic Courtès, 2015/01/28
- 73/376: startProcess: Make writing error messages from the child more robust, Ludovic Courtès, 2015/01/28
- 67/376: nix-daemon: Add trusted-users and allowed-users options, Ludovic Courtès, 2015/01/28
- 56/376: Remove cruft, Ludovic Courtès, 2015/01/28
- 76/376: nix-daemon: Simplify stderr handling, Ludovic Courtès, 2015/01/28
- 71/376: Revert old useBuildHook behaviour, Ludovic Courtès, 2015/01/28