Otherwise, it can be misused for privilege escalation attacks.
The problem has been noted by Ronald Chan, but my fix differs from his.
#include <sys/stat.h>
#include <sys/quota.h>
#include <sys/vfs.h>
#include <sys/stat.h>
#include <sys/quota.h>
#include <sys/vfs.h>
#define NONRET __attribute__((noreturn))
#define UNUSED __attribute__((unused))
#define NONRET __attribute__((noreturn))
#define UNUSED __attribute__((unused))
metafile = stdout;
return;
}
metafile = stdout;
return;
}
+ if (setfsuid(getuid()) < 0)
+ die("Failed to switch FS UID: %m");
metafile = fopen(name, "w");
metafile = fopen(name, "w");
+ if (setfsuid(geteuid()) < 0)
+ die("Failed to switch FS UID back: %m");
if (!metafile)
die("Failed to open metafile '%s'",name);
}
if (!metafile)
die("Failed to open metafile '%s'",name);
}