133 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
|    Copyright The containerd Authors.
 | |
| 
 | |
|    Licensed under the Apache License, Version 2.0 (the "License");
 | |
|    you may not use this file except in compliance with the License.
 | |
|    You may obtain a copy of the License at
 | |
| 
 | |
|        http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
|    Unless required by applicable law or agreed to in writing, software
 | |
|    distributed under the License is distributed on an "AS IS" BASIS,
 | |
|    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|    See the License for the specific language governing permissions and
 | |
|    limitations under the License.
 | |
| */
 | |
| 
 | |
| package runtime
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/gogo/protobuf/types"
 | |
| )
 | |
| 
 | |
| // TaskInfo provides task specific information
 | |
| type TaskInfo struct {
 | |
| 	ID        string
 | |
| 	Runtime   string
 | |
| 	Spec      []byte
 | |
| 	Namespace string
 | |
| }
 | |
| 
 | |
| // Process is a runtime object for an executing process inside a container
 | |
| type Process interface {
 | |
| 	ID() string
 | |
| 	// State returns the process state
 | |
| 	State(context.Context) (State, error)
 | |
| 	// Kill signals a container
 | |
| 	Kill(context.Context, uint32, bool) error
 | |
| 	// Pty resizes the processes pty/console
 | |
| 	ResizePty(context.Context, ConsoleSize) error
 | |
| 	// CloseStdin closes the processes stdin
 | |
| 	CloseIO(context.Context) error
 | |
| 	// Start the container's user defined process
 | |
| 	Start(context.Context) error
 | |
| 	// Wait for the process to exit
 | |
| 	Wait(context.Context) (*Exit, error)
 | |
| }
 | |
| 
 | |
| // Task is the runtime object for an executing container
 | |
| type Task interface {
 | |
| 	Process
 | |
| 
 | |
| 	// Information of the container
 | |
| 	Info() TaskInfo
 | |
| 	// Pause pauses the container process
 | |
| 	Pause(context.Context) error
 | |
| 	// Resume unpauses the container process
 | |
| 	Resume(context.Context) error
 | |
| 	// Exec adds a process into the container
 | |
| 	Exec(context.Context, string, ExecOpts) (Process, error)
 | |
| 	// Pids returns all pids
 | |
| 	Pids(context.Context) ([]ProcessInfo, error)
 | |
| 	// Checkpoint checkpoints a container to an image with live system data
 | |
| 	Checkpoint(context.Context, string, *types.Any) error
 | |
| 	// DeleteProcess deletes a specific exec process via its id
 | |
| 	DeleteProcess(context.Context, string) (*Exit, error)
 | |
| 	// Update sets the provided resources to a running task
 | |
| 	Update(context.Context, *types.Any) error
 | |
| 	// Process returns a process within the task for the provided id
 | |
| 	Process(context.Context, string) (Process, error)
 | |
| 	// Metrics returns runtime specific metrics for a task
 | |
| 	Metrics(context.Context) (interface{}, error)
 | |
| }
 | |
| 
 | |
| // ExecOpts provides additional options for additional processes running in a task
 | |
| type ExecOpts struct {
 | |
| 	Spec *types.Any
 | |
| 	IO   IO
 | |
| }
 | |
| 
 | |
| // ConsoleSize of a pty or windows terminal
 | |
| type ConsoleSize struct {
 | |
| 	Width  uint32
 | |
| 	Height uint32
 | |
| }
 | |
| 
 | |
| // Status is the runtime status of a task and/or process
 | |
| type Status int
 | |
| 
 | |
| const (
 | |
| 	// CreatedStatus when a process has been created
 | |
| 	CreatedStatus Status = iota + 1
 | |
| 	// RunningStatus when a process is running
 | |
| 	RunningStatus
 | |
| 	// StoppedStatus when a process has stopped
 | |
| 	StoppedStatus
 | |
| 	// DeletedStatus when a process has been deleted
 | |
| 	DeletedStatus
 | |
| 	// PausedStatus when a process is paused
 | |
| 	PausedStatus
 | |
| 	// PausingStatus when a process is currently pausing
 | |
| 	PausingStatus
 | |
| )
 | |
| 
 | |
| // State information for a process
 | |
| type State struct {
 | |
| 	// Status is the current status of the container
 | |
| 	Status Status
 | |
| 	// Pid is the main process id for the container
 | |
| 	Pid uint32
 | |
| 	// ExitStatus of the process
 | |
| 	// Only valid if the Status is Stopped
 | |
| 	ExitStatus uint32
 | |
| 	// ExitedAt is the time at which the process exited
 | |
| 	// Only valid if the Status is Stopped
 | |
| 	ExitedAt time.Time
 | |
| 	Stdin    string
 | |
| 	Stdout   string
 | |
| 	Stderr   string
 | |
| 	Terminal bool
 | |
| }
 | |
| 
 | |
| // ProcessInfo holds platform specific process information
 | |
| type ProcessInfo struct {
 | |
| 	// Pid is the process ID
 | |
| 	Pid uint32
 | |
| 	// Info includes additional process information
 | |
| 	// Info varies by platform
 | |
| 	Info interface{}
 | |
| }
 | 
