remove_tmp_images.go 798 B

1234567891011121314151617181920212223242526272829303132333435363738
  1. package backgroundtasks
  2. import (
  3. "io/ioutil"
  4. "os"
  5. "path"
  6. "github.com/grafana/grafana/pkg/bus"
  7. "github.com/grafana/grafana/pkg/models"
  8. "github.com/grafana/grafana/pkg/setting"
  9. )
  10. func init() {
  11. bus.AddEventListener(CleanTmpFiles)
  12. }
  13. func CleanTmpFiles(cmd *models.HourCommand) error {
  14. files, err := ioutil.ReadDir(setting.ImagesDir)
  15. var toDelete []os.FileInfo
  16. for _, file := range files {
  17. if file.ModTime().AddDate(0, 0, setting.RenderedImageTTLDays).Before(cmd.Time) {
  18. toDelete = append(toDelete, file)
  19. }
  20. }
  21. for _, file := range toDelete {
  22. fullPath := path.Join(setting.ImagesDir, file.Name())
  23. err := os.Remove(fullPath)
  24. if err != nil {
  25. return err
  26. }
  27. }
  28. tlog.Debug("Found old rendered image to delete", "deleted", len(toDelete), "keept", len(files))
  29. return err
  30. }