mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2025-01-19 01:26:47 +02:00
* Fix for a problem with BSD's group ownership semantics when the user
is not in the "wheel" group.
This commit is contained in:
parent
3a68622dda
commit
b454977909
1 changed files with 13 additions and 1 deletions
|
@ -300,7 +300,19 @@ Path createTempDir()
|
||||||
while (1) {
|
while (1) {
|
||||||
checkInterrupt();
|
checkInterrupt();
|
||||||
Path tmpDir = tempName();
|
Path tmpDir = tempName();
|
||||||
if (mkdir(tmpDir.c_str(), 0777) == 0) return tmpDir;
|
if (mkdir(tmpDir.c_str(), 0777) == 0) {
|
||||||
|
/* Explicitly set the group of the directory. This is to
|
||||||
|
work around around problems caused by BSD's group
|
||||||
|
ownership semantics (directories inherit the group of
|
||||||
|
the parent). For instance, the group of /tmp on
|
||||||
|
FreeBSD is "wheel", so all directories created in /tmp
|
||||||
|
will be owned by "wheel"; but if the user is not in
|
||||||
|
"wheel", then "tar" will fail to unpack archives that
|
||||||
|
have the setgid bit set on directories. */
|
||||||
|
if (chown(tmpDir.c_str(), (uid_t) -1, getegid()) != 0)
|
||||||
|
throw SysError(format("setting group of directory `%1%'") % tmpDir);
|
||||||
|
return tmpDir;
|
||||||
|
}
|
||||||
if (errno != EEXIST)
|
if (errno != EEXIST)
|
||||||
throw SysError(format("creating directory `%1%'") % tmpDir);
|
throw SysError(format("creating directory `%1%'") % tmpDir);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue