mirror of
https://github.com/openziti/zrok.git
synced 2025-01-11 00:18:43 +01:00
79 lines
1.5 KiB
Go
79 lines
1.5 KiB
Go
package metrics
|
|
|
|
import (
|
|
"github.com/openziti/zrok/controller/store"
|
|
"github.com/pkg/errors"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
type Agent struct {
|
|
events chan ZitiEventMsg
|
|
src ZitiEventJsonSource
|
|
srcJoin chan struct{}
|
|
cache *cache
|
|
snks []UsageSink
|
|
}
|
|
|
|
func NewAgent(cfg *AgentConfig, str *store.Store, ifxCfg *InfluxConfig) (*Agent, error) {
|
|
a := &Agent{}
|
|
if v, ok := cfg.Source.(ZitiEventJsonSource); ok {
|
|
a.src = v
|
|
} else {
|
|
return nil, errors.New("invalid event json source")
|
|
}
|
|
a.cache = newShareCache(str)
|
|
a.snks = append(a.snks, newInfluxWriter(ifxCfg))
|
|
return a, nil
|
|
}
|
|
|
|
func (a *Agent) AddUsageSink(snk UsageSink) {
|
|
a.snks = append(a.snks, snk)
|
|
}
|
|
|
|
func (a *Agent) Start() error {
|
|
a.events = make(chan ZitiEventMsg)
|
|
srcJoin, err := a.src.Start(a.events)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
a.srcJoin = srcJoin
|
|
|
|
go func() {
|
|
logrus.Info("started")
|
|
defer logrus.Info("stopped")
|
|
for {
|
|
select {
|
|
case event := <-a.events:
|
|
if usage, err := Ingest(event.Data()); err == nil {
|
|
if err := a.cache.addZrokDetail(usage); err != nil {
|
|
logrus.Error(err)
|
|
}
|
|
shouldAck := true
|
|
for _, snk := range a.snks {
|
|
if err := snk.Handle(usage); err != nil {
|
|
logrus.Error(err)
|
|
if shouldAck {
|
|
shouldAck = false
|
|
}
|
|
}
|
|
}
|
|
if shouldAck {
|
|
if err := event.Ack(); err != nil {
|
|
logrus.Error("unable to Ack message", err)
|
|
}
|
|
}
|
|
} else {
|
|
logrus.Error(err)
|
|
}
|
|
}
|
|
}
|
|
}()
|
|
|
|
return nil
|
|
}
|
|
|
|
func (a *Agent) Stop() {
|
|
a.src.Stop()
|
|
close(a.events)
|
|
}
|