syslog.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package logger
  2. import (
  3. "fmt"
  4. "log/syslog"
  5. "os"
  6. "github.com/imgproxy/imgproxy/v3/config/configurators"
  7. "github.com/sirupsen/logrus"
  8. )
  9. var (
  10. syslogLevels = map[string]logrus.Level{
  11. "crit": logrus.FatalLevel,
  12. "error": logrus.ErrorLevel,
  13. "warning": logrus.WarnLevel,
  14. "info": logrus.InfoLevel,
  15. }
  16. )
  17. type syslogHook struct {
  18. writer *syslog.Writer
  19. levels []logrus.Level
  20. formatter logrus.Formatter
  21. }
  22. func isSyslogEnabled() (enabled bool) {
  23. configurators.Bool(&enabled, "IMGPROXY_SYSLOG_ENABLE")
  24. return
  25. }
  26. func newSyslogHook() (*syslogHook, error) {
  27. var (
  28. network, addr string
  29. level logrus.Level
  30. tag = "imgproxy"
  31. levelStr = "notice"
  32. )
  33. configurators.String(&network, "IMGPROXY_SYSLOG_NETWORK")
  34. configurators.String(&addr, "IMGPROXY_SYSLOG_ADDRESS")
  35. configurators.String(&tag, "IMGPROXY_SYSLOG_TAG")
  36. configurators.String(&levelStr, "IMGPROXY_SYSLOG_LEVEL")
  37. if l, ok := syslogLevels[levelStr]; ok {
  38. level = l
  39. } else {
  40. level = logrus.InfoLevel
  41. logrus.Warningf("Syslog level '%s' is invalid, 'info' is used", levelStr)
  42. }
  43. w, err := syslog.Dial(network, addr, syslog.LOG_NOTICE, tag)
  44. return &syslogHook{
  45. writer: w,
  46. levels: logrus.AllLevels[:int(level)+1],
  47. formatter: &structuredFormatter{},
  48. }, err
  49. }
  50. func (hook *syslogHook) Fire(entry *logrus.Entry) error {
  51. line, err := hook.formatter.Format(entry)
  52. if err != nil {
  53. fmt.Fprintf(os.Stderr, "Unable to read entry, %v\n", err)
  54. return err
  55. }
  56. switch entry.Level {
  57. case logrus.PanicLevel, logrus.FatalLevel:
  58. return hook.writer.Crit(string(line))
  59. case logrus.ErrorLevel:
  60. return hook.writer.Err(string(line))
  61. case logrus.WarnLevel:
  62. return hook.writer.Warning(string(line))
  63. case logrus.InfoLevel:
  64. return hook.writer.Info(string(line))
  65. default:
  66. return nil
  67. }
  68. }
  69. func (hook *syslogHook) Levels() []logrus.Level {
  70. return hook.levels
  71. }