9 "git.curoverse.com/arvados.git/sdk/go/arvados"
10 "github.com/ghodss/yaml"
13 type eventSink interface {
14 Channel() <-chan *event
18 type eventSource interface {
33 // Detail returns the database row corresponding to the event. It can
34 // be called safely from multiple goroutines. Only one attempt will be
35 // made. If the database row cannot be retrieved, Detail returns nil.
36 func (e *event) Detail() *arvados.Log {
39 if e.logRow != nil || e.err != nil {
42 var logRow arvados.Log
44 e.err = e.db.QueryRow(`SELECT id, uuid, object_uuid, COALESCE(object_owner_uuid,''), COALESCE(event_type,''), created_at, properties FROM logs WHERE id = $1`, e.LogID).Scan(
48 &logRow.ObjectOwnerUUID,
53 log.Printf("retrieving log row %d: %s", e.LogID, e.err)
56 e.err = yaml.Unmarshal(propYAML, &logRow.Properties)
58 log.Printf("decoding yaml for log row %d: %s", e.LogID, e.err)