Documentation ¶
Index ¶
- func NewFifos(id string, stdin bool) (*containerdio.FIFOSet, error)
- func NewIOWithTerminal(stdin io.Reader, stdout, stderr io.Writer, terminal bool, stdinEnable bool) containerdio.Creation
- func Register(create func() Backend)
- func WithAttach(stdin io.Reader, stdout, stderr io.Writer) containerdio.Attach
- func WithCriLogFile(criLogFile *os.File) func(*Option)
- func WithDiscard() func(*Option)
- func WithHijack(hi http.Hijacker, upgrade bool) func(*Option)
- func WithID(id string) func(*Option)
- func WithJSONFile() func(*Option)
- func WithLoggerInfo(info logger.Info) func(*Option)
- func WithMuxDisabled(muxDisabled bool) func(*Option)
- func WithPipe(pipe *io.PipeWriter) func(*Option)
- func WithStdin(stdin bool) func(*Option)
- func WithStdinHijack() func(*Option)
- func WithStdinStream() func(*Option)
- func WithStreams(streams *remotecommand.Streams) func(*Option)
- func WithSyslog() func(*Option)
- type Backend
- type Cache
- type ContainerIO
- type IO
- type Option
- type StreamType
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewFifos ¶
func NewFifos(id string, stdin bool) (*containerdio.FIFOSet, error)
NewFifos returns a new set of fifos for the task
func NewIOWithTerminal ¶
func NewIOWithTerminal(stdin io.Reader, stdout, stderr io.Writer, terminal bool, stdinEnable bool) containerdio.Creation
NewIOWithTerminal creates a new io set with the provied io.Reader/Writers for use with a terminal
func WithAttach ¶
WithAttach attaches the existing io for a task to the provided io.Reader/Writers
func WithCriLogFile ¶
WithCriLogFile specified the cri log file backend.
func WithHijack ¶
WithHijack specified the hijack backend.
func WithLoggerInfo ¶
WithLoggerInfo specified the container's logger information.
func WithMuxDisabled ¶
WithMuxDisabled specified whether mux stdout & stderr of container IO.
func WithPipe ¶
func WithPipe(pipe *io.PipeWriter) func(*Option)
WithPipe specified the pipe backend.
func WithStdinHijack ¶
func WithStdinHijack() func(*Option)
WithStdinHijack sepcified the stdin with hijack.
func WithStdinStream ¶
func WithStdinStream() func(*Option)
WithStdinStream specified the stdin with stream.
func WithStreams ¶
func WithStreams(streams *remotecommand.Streams) func(*Option)
WithStreams specified the stream backend.
Types ¶
type Backend ¶
type Backend interface { // Name defines the backend's name. Name() string // Init initializes the backend io. Init(opt *Option) error // Out returns the stdout. Out() io.Writer // In returns the stdin. In() io.Reader // Err returns the stderr. Err() io.Writer // Close closes the io. Close() error }
Backend defines the real output/input of the container's stdio.
type Cache ¶
type Cache struct {
// contains filtered or unexported fields
}
Cache saves the all container's io.
type ContainerIO ¶
type ContainerIO struct { Option // contains filtered or unexported fields }
ContainerIO used to control the container's stdio.
func (*ContainerIO) Close ¶
func (cio *ContainerIO) Close() error
Close implements the standard Close interface.
func (*ContainerIO) OpenStdin ¶
func (cio *ContainerIO) OpenStdin() bool
OpenStdin returns open container's stdin or not.
type IO ¶
type IO struct { Stdout *ContainerIO Stderr *ContainerIO Stdin *ContainerIO // For IO backend like http, we need to mux stdout & stderr // if terminal is disabled. // But for other IO backend, it is not necessary. // So we should make it configurable. MuxDisabled bool }
IO wraps the three container's ios of stdout, stderr, stdin.
func (*IO) AddBackend ¶
AddBackend adds more backends to container's stdio.
type Option ¶
type Option struct {
// contains filtered or unexported fields
}
Option is used to pass some data into ContainerIO.
FIXME(fuwei): use logger.Info to separate options and backends.
type StreamType ¶
type StreamType string
StreamType is the type of the stream.
const ( // Stdin stream type. Stdin StreamType = "stdin" // Stdout stream type. Stdout StreamType = "stdout" // Stderr stream type. Stderr StreamType = "stderr" )