docs/execdriver/driver.go

87 lines
1.6 KiB
Go

package execdriver
import (
"errors"
"io"
"os/exec"
"syscall"
"time"
)
var (
ErrCommandIsNil = errors.New("Process's cmd is nil")
)
type Driver interface {
Start(c *Process) error
Stop(c *Process) error
Kill(c *Process, sig int) error
Wait(c *Process, duration time.Duration) error
}
// Network settings of the container
type Network struct {
Gateway string
IPAddress string
IPPrefixLen int
Mtu int
}
type Process struct {
Name string // unique name for the conatienr
Privileged bool
User string
Dir string // root fs of the container
InitPath string // dockerinit
Entrypoint string
Args []string
// Environment map[string]string // we don't use this right now because we use an env file
WorkingDir string
ConfigPath string
Tty bool
Network *Network // if network is nil then networking is disabled
Stdin io.Reader
Stdout io.Writer
Stderr io.Writer
cmd *exec.Cmd
}
func (c *Process) SetCmd(cmd *exec.Cmd) error {
c.cmd = cmd
cmd.Stdout = c.Stdout
cmd.Stderr = c.Stderr
cmd.Stdin = c.Stdin
return nil
}
func (c *Process) Pid() int {
return c.cmd.Process.Pid
}
func (c *Process) StdinPipe() (io.WriteCloser, error) {
return c.cmd.StdinPipe()
}
func (c *Process) StderrPipe() (io.ReadCloser, error) {
return c.cmd.StderrPipe()
}
func (c *Process) StdoutPipe() (io.ReadCloser, error) {
return c.cmd.StdoutPipe()
}
func (c *Process) GetExitCode() int {
if c.cmd != nil {
return c.cmd.ProcessState.Sys().(syscall.WaitStatus).ExitStatus()
}
return -1
}
func (c *Process) Wait() error {
if c.cmd != nil {
return c.cmd.Wait()
}
return ErrCommandIsNil
}