.. always, always setgid() before setuid()!
Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=
1061751
Signed-off-by: Karel Zak <kzak@redhat.com>
#include <assert.h>
#include <sys/types.h>
#include <sys/wait.h>
+#include <grp.h>
#include "strutils.h"
#include "nls.h"
continue_as_child();
if (namespaces & CLONE_NEWUSER) {
- if (setuid(uid) < 0)
- err(EXIT_FAILURE, _("setuid failed"));
+ if (setgroups(0, NULL)) /* drop supplementary groups */
+ err(EXIT_FAILURE, _("setgroups failed"));
if (setgid(gid) < 0)
err(EXIT_FAILURE, _("setgid failed"));
+ if (setuid(uid) < 0)
+ err(EXIT_FAILURE, _("setuid failed"));
}
if (optind < argc) {