
Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: update events package to include emitter and use envelope proto Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: add events service Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: enable events service and update ctr events to use events service Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> event listeners Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: helper func for emitting in services Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: improved cli for containers and tasks Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> create event envelope with poster Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: introspect event data to use for type url Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: use pb encoding; add event types Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: instrument content and snapshot services with events Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: instrument image service with events Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: instrument namespace service with events Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: add namespace support Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: only send events from namespace requested from client Signed-off-by: Evan Hazlett <ejhazlett@gmail.com> events: switch to go-events for broadcasting Signed-off-by: Evan Hazlett <ejhazlett@gmail.com>
66 lines
1.3 KiB
Go
66 lines
1.3 KiB
Go
package events
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/Sirupsen/logrus"
|
|
"github.com/containerd/containerd/log"
|
|
"github.com/containerd/containerd/namespaces"
|
|
)
|
|
|
|
var (
|
|
G = GetPoster
|
|
)
|
|
|
|
// Poster posts the event.
|
|
type Poster interface {
|
|
Post(ctx context.Context, evt Event) error
|
|
}
|
|
|
|
type posterKey struct{}
|
|
|
|
func WithPoster(ctx context.Context, poster Poster) context.Context {
|
|
return context.WithValue(ctx, posterKey{}, poster)
|
|
}
|
|
|
|
func GetPoster(ctx context.Context) Poster {
|
|
poster := ctx.Value(posterKey{})
|
|
|
|
if poster == nil {
|
|
tx, _ := getTx(ctx)
|
|
topic := getTopic(ctx)
|
|
|
|
// likely means we don't have a configured event system. Just return
|
|
// the default poster, which merely logs events.
|
|
return posterFunc(func(ctx context.Context, evt Event) error {
|
|
fields := logrus.Fields{"event": evt}
|
|
|
|
if topic != "" {
|
|
fields["topic"] = topic
|
|
}
|
|
ns, _ := namespaces.Namespace(ctx)
|
|
fields["ns"] = ns
|
|
|
|
if tx != nil {
|
|
fields["tx.id"] = tx.id
|
|
if tx.parent != nil {
|
|
fields["tx.parent.id"] = tx.parent.id
|
|
}
|
|
}
|
|
|
|
log.G(ctx).WithFields(fields).Debug("event fired")
|
|
|
|
return nil
|
|
})
|
|
}
|
|
|
|
return poster.(Poster)
|
|
}
|
|
|
|
type posterFunc func(ctx context.Context, evt Event) error
|
|
|
|
func (fn posterFunc) Post(ctx context.Context, evt Event) error {
|
|
fn(ctx, evt)
|
|
return nil
|
|
}
|