Add support for privileged containers.
This commit is contained in:
parent
eec5ca2478
commit
e37fa44630
@ -38,6 +38,10 @@ func (d *Driver) createContainer(image containerd.Image, containerName, containe
|
|||||||
|
|
||||||
opts = append(opts, oci.WithImageConfigArgs(image, args))
|
opts = append(opts, oci.WithImageConfigArgs(image, args))
|
||||||
|
|
||||||
|
if config.Privileged {
|
||||||
|
opts = append(opts, oci.WithPrivileged)
|
||||||
|
}
|
||||||
|
|
||||||
if len(config.CapAdd) > 0 {
|
if len(config.CapAdd) > 0 {
|
||||||
opts = append(opts, oci.WithAddedCapabilities(config.CapAdd))
|
opts = append(opts, oci.WithAddedCapabilities(config.CapAdd))
|
||||||
}
|
}
|
||||||
|
@ -69,11 +69,12 @@ var (
|
|||||||
// this is used to validate the configuration specified for the plugin
|
// this is used to validate the configuration specified for the plugin
|
||||||
// when a job is submitted.
|
// when a job is submitted.
|
||||||
taskConfigSpec = hclspec.NewObject(map[string]*hclspec.Spec{
|
taskConfigSpec = hclspec.NewObject(map[string]*hclspec.Spec{
|
||||||
"image": hclspec.NewAttr("image", "string", true),
|
"image": hclspec.NewAttr("image", "string", true),
|
||||||
"command": hclspec.NewAttr("command", "string", false),
|
"command": hclspec.NewAttr("command", "string", false),
|
||||||
"args": hclspec.NewAttr("args", "list(string)", false),
|
"args": hclspec.NewAttr("args", "list(string)", false),
|
||||||
"cap_add": hclspec.NewAttr("cap_add", "list(string)", false),
|
"cap_add": hclspec.NewAttr("cap_add", "list(string)", false),
|
||||||
"cap_drop": hclspec.NewAttr("cap_drop", "list(string)", false),
|
"cap_drop": hclspec.NewAttr("cap_drop", "list(string)", false),
|
||||||
|
"privileged": hclspec.NewAttr("privileged", "bool", false),
|
||||||
})
|
})
|
||||||
|
|
||||||
// capabilities indicates what optional features this driver supports
|
// capabilities indicates what optional features this driver supports
|
||||||
@ -96,11 +97,12 @@ type Config struct {
|
|||||||
// TaskConfig contains configuration information for a task that runs with
|
// TaskConfig contains configuration information for a task that runs with
|
||||||
// this plugin
|
// this plugin
|
||||||
type TaskConfig struct {
|
type TaskConfig struct {
|
||||||
Image string `codec:"image"`
|
Image string `codec:"image"`
|
||||||
Command string `codec:"command"`
|
Command string `codec:"command"`
|
||||||
Args []string `codec:"args"`
|
Args []string `codec:"args"`
|
||||||
CapAdd []string `codec:"cap_add"`
|
CapAdd []string `codec:"cap_add"`
|
||||||
CapDrop []string `codec:"cap_drop"`
|
CapDrop []string `codec:"cap_drop"`
|
||||||
|
Privileged bool `codec:"privileged"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// TaskState is the runtime state which is encoded in the handle returned to
|
// TaskState is the runtime state which is encoded in the handle returned to
|
||||||
|
Loading…
x
Reference in New Issue
Block a user