Initial commit of libcontainer
Docker-DCO-1.1-Signed-off-by: Michael Crosby <michael@crosbymichael.com> (github: crosbymichael)
This commit is contained in:
parent
f8923d8060
commit
81d2c67492
20 changed files with 1531 additions and 0 deletions
49
libcontainer/capabilities/capabilities.go
Normal file
49
libcontainer/capabilities/capabilities.go
Normal file
|
@ -0,0 +1,49 @@
|
|||
package capabilities
|
||||
|
||||
import (
|
||||
"github.com/dotcloud/docker/pkg/libcontainer"
|
||||
"github.com/syndtr/gocapability/capability"
|
||||
"os"
|
||||
)
|
||||
|
||||
var capMap = map[libcontainer.Capability]capability.Cap{
|
||||
libcontainer.CAP_SETPCAP: capability.CAP_SETPCAP,
|
||||
libcontainer.CAP_SYS_MODULE: capability.CAP_SYS_MODULE,
|
||||
libcontainer.CAP_SYS_RAWIO: capability.CAP_SYS_RAWIO,
|
||||
libcontainer.CAP_SYS_PACCT: capability.CAP_SYS_PACCT,
|
||||
libcontainer.CAP_SYS_ADMIN: capability.CAP_SYS_ADMIN,
|
||||
libcontainer.CAP_SYS_NICE: capability.CAP_SYS_NICE,
|
||||
libcontainer.CAP_SYS_RESOURCE: capability.CAP_SYS_RESOURCE,
|
||||
libcontainer.CAP_SYS_TIME: capability.CAP_SYS_TIME,
|
||||
libcontainer.CAP_SYS_TTY_CONFIG: capability.CAP_SYS_TTY_CONFIG,
|
||||
libcontainer.CAP_MKNOD: capability.CAP_MKNOD,
|
||||
libcontainer.CAP_AUDIT_WRITE: capability.CAP_AUDIT_WRITE,
|
||||
libcontainer.CAP_AUDIT_CONTROL: capability.CAP_AUDIT_CONTROL,
|
||||
libcontainer.CAP_MAC_OVERRIDE: capability.CAP_MAC_OVERRIDE,
|
||||
libcontainer.CAP_MAC_ADMIN: capability.CAP_MAC_ADMIN,
|
||||
}
|
||||
|
||||
// DropCapabilities drops capabilities for the current process based
|
||||
// on the container's configuration.
|
||||
func DropCapabilities(container *libcontainer.Container) error {
|
||||
if drop := getCapabilities(container); len(drop) > 0 {
|
||||
c, err := capability.NewPid(os.Getpid())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
c.Unset(capability.CAPS|capability.BOUNDS, drop...)
|
||||
|
||||
if err := c.Apply(capability.CAPS | capability.BOUNDS); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func getCapabilities(container *libcontainer.Container) []capability.Cap {
|
||||
drop := []capability.Cap{}
|
||||
for _, c := range container.Capabilities {
|
||||
drop = append(drop, capMap[c])
|
||||
}
|
||||
return drop
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue