 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
      Index ¶
Constants ¶
This section is empty.
Variables ¶
Functions ¶
This section is empty.
Types ¶
type Capabilities ¶
type Capabilities []*Capability
func (Capabilities) Contains ¶
func (c Capabilities) Contains(capp string) bool
Contains returns true if the specified Capability is in the slice
func (Capabilities) Get ¶ added in v0.10.0
func (c Capabilities) Get(capp string) *Capability
type Capability ¶
type Capability struct {
	Key     string         `json:"key,omitempty"`
	Enabled bool           `json:"enabled"`
	Value   capability.Cap `json:"value,omitempty"`
}
    func GetCapability ¶
func GetCapability(key string) *Capability
func (*Capability) String ¶
func (c *Capability) String() string
type Container ¶
type Container struct {
	Hostname         string          `json:"hostname,omitempty"`          // hostname
	ReadonlyFs       bool            `json:"readonly_fs,omitempty"`       // set the containers rootfs as readonly
	NoPivotRoot      bool            `json:"no_pivot_root,omitempty"`     // this can be enabled if you are running in ramdisk
	User             string          `json:"user,omitempty"`              // user to execute the process as
	WorkingDir       string          `json:"working_dir,omitempty"`       // current working directory
	Env              []string        `json:"environment,omitempty"`       // environment to set
	Tty              bool            `json:"tty,omitempty"`               // setup a proper tty or not
	Namespaces       Namespaces      `json:"namespaces,omitempty"`        // namespaces to apply
	CapabilitiesMask Capabilities    `json:"capabilities_mask,omitempty"` // capabilities to drop
	Networks         []*Network      `json:"networks,omitempty"`          // nil for host's network stack
	Cgroups          *cgroups.Cgroup `json:"cgroups,omitempty"`           // cgroups
	Context          Context         `json:"context,omitempty"`           // generic context for specific options (apparmor, selinux)
	Mounts           []Mount         `json:"mounts,omitempty"`
}
    Container defines configuration options for how a container is setup inside a directory and how a process should be executed
type Mount ¶ added in v0.10.0
type Mount struct {
	Source      string `json:"source"`      // Source path, in the host namespace
	Destination string `json:"destination"` // Destination path, in the container
	Writable    bool   `json:"writable"`
	Private     bool   `json:"private"`
}
    Bind mounts from the host system to the container
type Namespace ¶
type Namespace struct {
	Key     string `json:"key,omitempty"`
	Enabled bool   `json:"enabled,omitempty"`
	Value   int    `json:"value,omitempty"`
	File    string `json:"file,omitempty"`
}
    func GetNamespace ¶
type Namespaces ¶
type Namespaces []*Namespace
func (Namespaces) Contains ¶
func (n Namespaces) Contains(ns string) bool
Contains returns true if the specified Namespace is in the slice
func (Namespaces) Get ¶ added in v0.10.0
func (n Namespaces) Get(ns string) *Namespace
type Network ¶
type Network struct {
	Type    string  `json:"type,omitempty"`    // type of networking to setup i.e. veth, macvlan, etc
	Context Context `json:"context,omitempty"` // generic context for type specific networking options
	Address string  `json:"address,omitempty"`
	Gateway string  `json:"gateway,omitempty"`
	Mtu     int     `json:"mtu,omitempty"`
}
    Network defines configuration for a container's networking stack
The network configuration can be omited from a container causing the container to be setup with the host's networking stack
 Click to show internal directories. 
   Click to hide internal directories.