package events import ( "context" "time" "github.com/pkg/errors" ) // EventerType ... type EventerType int const ( // LogFile indicates the event logger will be a logfile LogFile EventerType = iota // Journald indicates journald should be used to log events Journald EventerType = iota // Null is a no-op events logger. It does not read or write events. Null EventerType = iota // Memory indicates the event logger will hold events in memory Memory EventerType = iota ) // Event describes the attributes of a libpod event type Event struct { // ContainerExitCode is for storing the exit code of a container which can // be used for "internal" event notification ContainerExitCode int `json:",omitempty"` // ID can be for the container, image, volume, etc ID string `json:",omitempty"` // Image used where applicable Image string `json:",omitempty"` // Name where applicable Name string `json:",omitempty"` // Network is the network name in a network event Network string `json:"network,omitempty"` // Status describes the event that occurred Status Status // Time the event occurred Time time.Time // Type of event that occurred Type Type Details } // Details describes specifics about certain events, specifically around // container events type Details struct { // ID is the event ID ID string // Attributes can be used to describe specifics about the event // in the case of a container event, labels for example Attributes map[string]string } // EventerOptions describe options that need to be passed to create // an eventer type EventerOptions struct { // EventerType describes whether to use journald, file or memory EventerType string // LogFilePath is the path to where the log file should reside if using // the file logger LogFilePath string // LogFileMaxSize is the default limit used for rotating the log file LogFileMaxSize uint64 } // Eventer is the interface for journald or file event logging type Eventer interface { // Write an event to a backend Write(event Event) error // Read an event from the backend Read(ctx context.Context, options ReadOptions) error // String returns the type of event logger String() string } // ReadOptions describe the attributes needed to read event logs type ReadOptions struct { // EventChannel is the comm path back to user EventChannel chan *Event // Filters are key/value pairs that describe to limit output Filters []string // FromStart means you start reading from the start of the logs FromStart bool // Since reads "since" the given time Since string // Stream is follow Stream bool // Until reads "until" the given time Until string } // Type of event that occurred (container, volume, image, pod, etc) type Type string // Status describes the actual event action (stop, start, create, kill) type Status string const ( // Container - event is related to containers Container Type = "container" // Image - event is related to images Image Type = "image" // Network - event is related to networks Network Type = "network" // Pod - event is related to pods Pod Type = "pod" // System - event is related to Podman whole and not to any specific // container/pod/image/volume System Type = "system" // Volume - event is related to volumes Volume Type = "volume" // Machine - event is related to machine VM's Machine Type = "machine" // Attach ... Attach Status = "attach" // AutoUpdate ... AutoUpdate Status = "auto-update" // Build ... Build Status = "build" // Checkpoint ... Checkpoint Status = "checkpoint" // Cleanup ... Cleanup Status = "cleanup" // Commit ... Commit Status = "commit" // Copy ... Copy Status = "copy" // Create ... Create Status = "create" // Exec ... Exec Status = "exec" // ExecDied indicates that an exec session in a container died. ExecDied Status = "exec_died" // Exited indicates that a container's process died Exited Status = "died" // Export ... Export Status = "export" // History ... History Status = "history" // Import ... Import Status = "import" // Init ... Init Status = "init" // Kill ... Kill Status = "kill" // LoadFromArchive ... LoadFromArchive Status = "loadfromarchive" // Mount ... Mount Status = "mount" // NetworkConnect NetworkConnect Status = "connect" // NetworkDisconnect NetworkDisconnect Status = "disconnect" // Pause ... Pause Status = "pause" // Prune ... Prune Status = "prune" // Pull ... Pull Status = "pull" // Push ... Push Status = "push" // Refresh indicates that the system refreshed the state after a // reboot. Refresh Status = "refresh" // Remove ... Remove Status = "remove" // Rename indicates that a container was renamed Rename Status = "rename" // Renumber indicates that lock numbers were reallocated at user // request. Renumber Status = "renumber" // Restart indicates the target was restarted via an API call. Restart Status = "restart" // Restore ... Restore Status = "restore" // Rotate indicates that the log file was rotated Rotate Status = "log-rotation" // Save ... Save Status = "save" // Start ... Start Status = "start" // Stop ... Stop Status = "stop" // Sync ... Sync Status = "sync" // Tag ... Tag Status = "tag" // Unmount ... Unmount Status = "unmount" // Unpause ... Unpause Status = "unpause" // Untag ... Untag Status = "untag" ) // EventFilter for filtering events type EventFilter func(*Event) bool var ( // ErrEventTypeBlank indicates the event log found something done by podman // but it isn't likely an event ErrEventTypeBlank = errors.New("event type blank") // ErrEventNotFound indicates that the event was not found in the event log ErrEventNotFound = errors.New("unable to find event") )