events.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package logic
  2. import (
  3. "context"
  4. "encoding/json"
  5. "log/slog"
  6. "time"
  7. "github.com/google/go-cmp/cmp"
  8. "github.com/google/uuid"
  9. "github.com/gravitl/netmaker/db"
  10. "github.com/gravitl/netmaker/logic"
  11. "github.com/gravitl/netmaker/models"
  12. "github.com/gravitl/netmaker/schema"
  13. )
  14. var EventActivityCh = make(chan models.Event, 100)
  15. func LogEvent(a *models.Event) {
  16. EventActivityCh <- *a
  17. }
  18. func EventRententionHook() error {
  19. settings := logic.GetServerSettings()
  20. retentionPeriod := settings.AuditLogsRetentionPeriodInDays
  21. if retentionPeriod <= 0 {
  22. retentionPeriod = 30
  23. }
  24. err := (&schema.Event{}).DeleteOldEvents(db.WithContext(context.TODO()), retentionPeriod)
  25. if err != nil {
  26. slog.Warn("failed to delete old events pas retention period", "error", err)
  27. }
  28. return nil
  29. }
  30. func EventWatcher() {
  31. logic.HookManagerCh <- models.HookDetails{
  32. Hook: EventRententionHook,
  33. Interval: time.Hour * 24,
  34. }
  35. for e := range EventActivityCh {
  36. if e.Action == models.Update {
  37. // check if diff
  38. if cmp.Equal(e.Diff.Old, e.Diff.New) {
  39. continue
  40. }
  41. }
  42. sourceJson, _ := json.Marshal(e.Source)
  43. dstJson, _ := json.Marshal(e.Target)
  44. diff, _ := json.Marshal(e.Diff)
  45. a := schema.Event{
  46. ID: uuid.New().String(),
  47. Action: e.Action,
  48. Source: sourceJson,
  49. Target: dstJson,
  50. Origin: e.Origin,
  51. NetworkID: e.NetworkID,
  52. TriggeredBy: e.TriggeredBy,
  53. Diff: diff,
  54. TimeStamp: time.Now().UTC(),
  55. }
  56. a.Create(db.WithContext(context.TODO()))
  57. }
  58. }