Merge pull request #1918 from giuseppe/skip-setgroups
rootless: fix running with /proc/self/setgroups set to deny
This commit is contained in:
commit
9e5aa7494d
|
@ -6,6 +6,7 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
@ -300,11 +301,18 @@ func setupUser(config *initConfig) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setgroups, err := ioutil.ReadFile("/proc/self/setgroups")
|
||||||
|
if err != nil && !os.IsNotExist(err) {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// This isn't allowed in an unprivileged user namespace since Linux 3.19.
|
// This isn't allowed in an unprivileged user namespace since Linux 3.19.
|
||||||
// There's nothing we can do about /etc/group entries, so we silently
|
// There's nothing we can do about /etc/group entries, so we silently
|
||||||
// ignore setting groups here (since the user didn't explicitly ask us to
|
// ignore setting groups here (since the user didn't explicitly ask us to
|
||||||
// set the group).
|
// set the group).
|
||||||
if !config.RootlessEUID {
|
allowSupGroups := !config.RootlessEUID && strings.TrimSpace(string(setgroups)) != "deny"
|
||||||
|
|
||||||
|
if allowSupGroups {
|
||||||
suppGroups := append(execUser.Sgids, addGroups...)
|
suppGroups := append(execUser.Sgids, addGroups...)
|
||||||
if err := unix.Setgroups(suppGroups); err != nil {
|
if err := unix.Setgroups(suppGroups); err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
Loading…
Reference in New Issue