forked from TrueCloudLab/distribution
123 lines
4.2 KiB
Go
123 lines
4.2 KiB
Go
|
package notifications
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"time"
|
||
|
|
||
|
"github.com/docker/distribution/digest"
|
||
|
)
|
||
|
|
||
|
// EventAction constants used in action field of Event.
|
||
|
const (
|
||
|
EventActionPull = "pull"
|
||
|
EventActionPush = "push"
|
||
|
EventActionDelete = "delete"
|
||
|
EventActionPing = "ping"
|
||
|
)
|
||
|
|
||
|
// EventsMediaType is the mediatype for the json event envelope. If the Event,
|
||
|
// ActorRecord, SourceRecord or Envelope structs change, the version number
|
||
|
// should be incremented.
|
||
|
const EventsMediaType = "application/vnd.docker.distribution.events.v1+json"
|
||
|
|
||
|
// Envelope defines the fields of a json event envelope message that can hold
|
||
|
// one or more events.
|
||
|
type Envelope struct {
|
||
|
// Events make up the contents of the envelope. Events present in a single
|
||
|
// envelope are not necessarily related.
|
||
|
Events []Event `json:"events,omitempty"`
|
||
|
}
|
||
|
|
||
|
// TODO(stevvooe): The event type should be separate from the json format. It
|
||
|
// should be defined as an interface. Leaving as is for now since we don't
|
||
|
// need that at this time. If we make this change, the struct below would be
|
||
|
// called "EventRecord".
|
||
|
|
||
|
// Event provides the fields required to describe a registry event.
|
||
|
type Event struct {
|
||
|
// ID provides a unique identifier for the event.
|
||
|
ID string `json:"uuid,omitempty"`
|
||
|
|
||
|
// Timestamp is the time at which the event occurred.
|
||
|
Timestamp time.Time `json:"timestamp,omitempty"`
|
||
|
|
||
|
// Action indicates what action encompasses the provided event.
|
||
|
Action string `json:"action,omitempty"`
|
||
|
|
||
|
// Target uniquely describes the target of the event.
|
||
|
Target struct {
|
||
|
// Type should be "manifest" or "blob"
|
||
|
Type string `json:"type,omitempty"`
|
||
|
|
||
|
// Name identifies the named repository.
|
||
|
Name string `json:"name,omitempty"`
|
||
|
|
||
|
// Digest should identify the object in the repository.
|
||
|
Digest digest.Digest `json:"digest,omitempty"`
|
||
|
|
||
|
// Tag is present if the operation involved a tagged manifest.
|
||
|
Tag string `json:"tag,omitempty"`
|
||
|
|
||
|
// URL provides a link to the content on the relevant repository instance.
|
||
|
URL string `json:"url,omitempty"`
|
||
|
} `json:"target,omitempty"`
|
||
|
|
||
|
// Actor specifies the agent that initiated the event. For most
|
||
|
// situations, this could be from the authorizaton context of the request.
|
||
|
Actor ActorRecord `json:"actor,omitempty"`
|
||
|
|
||
|
// Source identifies the registry node that generated the event. Put
|
||
|
// differently, while the actor "initiates" the event, the source
|
||
|
// "generates" it.
|
||
|
Source SourceRecord `json:"source,omitempty"`
|
||
|
}
|
||
|
|
||
|
// ActorRecord specifies the agent that initiated the event. For most
|
||
|
// situations, this could be from the authorizaton context of the request.
|
||
|
type ActorRecord struct {
|
||
|
// Name corresponds to the subject or username associated with the
|
||
|
// request context that generated the event.
|
||
|
Name string `json:"name,omitempty"`
|
||
|
|
||
|
// Addr contains the ip or hostname and possibly port of the client
|
||
|
// connection that initiated the event.
|
||
|
Addr string `json:"addr,omitempty"`
|
||
|
}
|
||
|
|
||
|
// SourceRecord identifies the registry node that generated the event. Put
|
||
|
// differently, while the actor "initiates" the event, the source "generates"
|
||
|
// it.
|
||
|
type SourceRecord struct {
|
||
|
// Addr contains the ip or hostname and the port of the registry node
|
||
|
// that generated the event. Generally, this will be resolved by
|
||
|
// os.Hostname() along with the running port.
|
||
|
Addr string `json:"addr,omitempty"`
|
||
|
|
||
|
// Host is the dns name of the registry cluster, as configured.
|
||
|
Host string `json:"host,omitempty"`
|
||
|
|
||
|
// RequestID uniquely identifies the registry request that generated the
|
||
|
// event.
|
||
|
RequestID string `json:"request_id,omitempty"`
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
// ErrSinkClosed is returned if a write is issued to a sink that has been
|
||
|
// closed. If encountered, the error should be considered terminal and
|
||
|
// retries will not be successful.
|
||
|
ErrSinkClosed = fmt.Errorf("sink: closed")
|
||
|
)
|
||
|
|
||
|
// Sink accepts and sends events.
|
||
|
type Sink interface {
|
||
|
// Write writes one or more events to the sink. If no error is returned,
|
||
|
// the caller will assume that all events have been committed and will not
|
||
|
// try to send them again. If an error is received, the caller may retry
|
||
|
// sending the event. The caller should cede the slice of memory to the
|
||
|
// sink and not modify it after calling this method.
|
||
|
Write(events ...Event) error
|
||
|
|
||
|
// Close the sink, possibly waiting for pending events to flush.
|
||
|
Close() error
|
||
|
}
|