diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-12-07T00·19+0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-12-07T00·19+0000 |
commit | 813a7c65c99951a946e8342713884d46af1f2966 (patch) | |
tree | 71f9c42d997105cf913fadd9d1f285e6d756a26b /src/libstore | |
parent | 6a8e60913ac470c704510a733d40d3fab3ecb00d (diff) |
* Sanity check.
Diffstat (limited to 'src/libstore')
-rw-r--r-- | src/libstore/build.cc | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/libstore/build.cc b/src/libstore/build.cc index 53284c89032f..b4eded1b9dd5 100644 --- a/src/libstore/build.cc +++ b/src/libstore/build.cc @@ -406,7 +406,7 @@ void UserLock::acquire() if (!pw) throw Error(format("the user `%1%' in the group `%2%' does not exist") % *i % buildUsersGroup); - + fnUserLock = (format("%1%/userpool/%2%") % nixStateDir % pw->pw_uid).str(); if (lockedPaths.find(fnUserLock) != lockedPaths.end()) @@ -421,6 +421,12 @@ void UserLock::acquire() fdUserLock = fd.borrow(); lockedPaths.insert(fnUserLock); uid = pw->pw_uid; + + /* Sanity check... */ + if (uid == getuid() || uid == geteuid()) + throw Error(format("the Nix user should not be a member of `%1%'") + % buildUsersGroup); + return; } } |