lengthCheck.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. package lengthCheck
  2. import (
  3. "context"
  4. "go-common/app/service/ops/log-agent/event"
  5. "go-common/app/service/ops/log-agent/processor"
  6. "go-common/app/service/ops/log-agent/pkg/flowmonitor"
  7. )
  8. type LengthCheck struct {
  9. c *Config
  10. }
  11. func init() {
  12. err := processor.Register("lengthCheck", Process)
  13. if err != nil {
  14. panic(err)
  15. }
  16. }
  17. func Process(ctx context.Context, config interface{}, input <-chan *event.ProcessorEvent) (output chan *event.ProcessorEvent, err error) {
  18. lcheck := new(LengthCheck)
  19. if c, ok := config.(*Config); !ok {
  20. panic("Error config for lengthCheck Processor")
  21. } else {
  22. if err = c.ConfigValidate(); err != nil {
  23. return nil, err
  24. }
  25. lcheck.c = c
  26. }
  27. output = make(chan *event.ProcessorEvent)
  28. go func() {
  29. for {
  30. select {
  31. case e := <-input:
  32. // log length check
  33. if e.Length > lcheck.c.MaxLength {
  34. flowmonitor.Fm.AddEvent(e, "log-agent.processor.lengthCheck", "ERROR", "too long")
  35. event.PutEvent(e)
  36. continue
  37. }
  38. output <- e
  39. case <-ctx.Done():
  40. return
  41. }
  42. }
  43. }()
  44. return output, nil
  45. }