Merge pull request #6083 from bernerdschaefer/nsinit-drop-capabilities-after-changing-user
SETUID/SETGID not required for changing user
This commit is contained in:
commit
1dd391fe26
3 changed files with 56 additions and 3 deletions
|
@ -185,15 +185,33 @@ func setupRoute(container *libcontainer.Container) error {
|
||||||
// and working dir, and closes any leaky file descriptors
|
// and working dir, and closes any leaky file descriptors
|
||||||
// before execing the command inside the namespace
|
// before execing the command inside the namespace
|
||||||
func FinalizeNamespace(container *libcontainer.Container) error {
|
func FinalizeNamespace(container *libcontainer.Container) error {
|
||||||
if err := capabilities.DropCapabilities(container); err != nil {
|
|
||||||
return fmt.Errorf("drop capabilities %s", err)
|
|
||||||
}
|
|
||||||
if err := system.CloseFdsFrom(3); err != nil {
|
if err := system.CloseFdsFrom(3); err != nil {
|
||||||
return fmt.Errorf("close open file descriptors %s", err)
|
return fmt.Errorf("close open file descriptors %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// drop capabilities in bounding set before changing user
|
||||||
|
if err := capabilities.DropBoundingSet(container); err != nil {
|
||||||
|
return fmt.Errorf("drop bounding set %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// preserve existing capabilities while we change users
|
||||||
|
if err := system.SetKeepCaps(); err != nil {
|
||||||
|
return fmt.Errorf("set keep caps %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
if err := SetupUser(container.User); err != nil {
|
if err := SetupUser(container.User); err != nil {
|
||||||
return fmt.Errorf("setup user %s", err)
|
return fmt.Errorf("setup user %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := system.ClearKeepCaps(); err != nil {
|
||||||
|
return fmt.Errorf("clear keep caps %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// drop all other capabilities
|
||||||
|
if err := capabilities.DropCapabilities(container); err != nil {
|
||||||
|
return fmt.Errorf("drop capabilities %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
if container.WorkingDir != "" {
|
if container.WorkingDir != "" {
|
||||||
if err := system.Chdir(container.WorkingDir); err != nil {
|
if err := system.Chdir(container.WorkingDir); err != nil {
|
||||||
return fmt.Errorf("chdir to %s %s", container.WorkingDir, err)
|
return fmt.Errorf("chdir to %s %s", container.WorkingDir, err)
|
||||||
|
|
|
@ -9,6 +9,25 @@ import (
|
||||||
|
|
||||||
const allCapabilityTypes = capability.CAPS | capability.BOUNDS
|
const allCapabilityTypes = capability.CAPS | capability.BOUNDS
|
||||||
|
|
||||||
|
// DropBoundingSet drops the capability bounding set to those specified in the
|
||||||
|
// container configuration.
|
||||||
|
func DropBoundingSet(container *libcontainer.Container) error {
|
||||||
|
c, err := capability.NewPid(os.Getpid())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
keep := getEnabledCapabilities(container)
|
||||||
|
c.Clear(capability.BOUNDS)
|
||||||
|
c.Set(capability.BOUNDS, keep...)
|
||||||
|
|
||||||
|
if err := c.Apply(capability.BOUNDS); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// DropCapabilities drops all capabilities for the current process expect those specified in the container configuration.
|
// DropCapabilities drops all capabilities for the current process expect those specified in the container configuration.
|
||||||
func DropCapabilities(container *libcontainer.Container) error {
|
func DropCapabilities(container *libcontainer.Container) error {
|
||||||
c, err := capability.NewPid(os.Getpid())
|
c, err := capability.NewPid(os.Getpid())
|
||||||
|
|
|
@ -135,6 +135,22 @@ func GetParentDeathSignal() (int, error) {
|
||||||
return sig, nil
|
return sig, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func SetKeepCaps() error {
|
||||||
|
if _, _, err := syscall.RawSyscall(syscall.SYS_PRCTL, syscall.PR_SET_KEEPCAPS, 1, 0); err != 0 {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func ClearKeepCaps() error {
|
||||||
|
if _, _, err := syscall.RawSyscall(syscall.SYS_PRCTL, syscall.PR_SET_KEEPCAPS, 0, 0); err != 0 {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func Setctty() error {
|
func Setctty() error {
|
||||||
if _, _, err := syscall.RawSyscall(syscall.SYS_IOCTL, 0, uintptr(syscall.TIOCSCTTY), 0); err != 0 {
|
if _, _, err := syscall.RawSyscall(syscall.SYS_IOCTL, 0, uintptr(syscall.TIOCSCTTY), 0); err != 0 {
|
||||||
return err
|
return err
|
||||||
|
|
Loading…
Reference in a new issue