cron.go 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright 2015 - Present, The Gogs Authors. All rights reserved.
  2. // Copyright 2018 - Present, Gitote. All rights reserved.
  3. //
  4. // This source code is licensed under the MIT license found in the
  5. // LICENSE file in the root directory of this source tree.
  6. package cron
  7. import (
  8. "gitote/gitote/models"
  9. "gitote/gitote/pkg/setting"
  10. "time"
  11. raven "github.com/getsentry/raven-go"
  12. "gitlab.com/gitote/cron"
  13. log "gopkg.in/clog.v1"
  14. )
  15. var c = cron.New()
  16. // NewContext begins cron tasks
  17. func NewContext() {
  18. var (
  19. entry *cron.Entry
  20. err error
  21. )
  22. if setting.Cron.UpdateMirror.Enabled {
  23. entry, err = c.AddFunc("Update mirrors", setting.Cron.UpdateMirror.Schedule, models.MirrorUpdate)
  24. if err != nil {
  25. raven.CaptureErrorAndWait(err, nil)
  26. log.Fatal(2, "Cron.(update mirrors): %v", err)
  27. }
  28. if setting.Cron.UpdateMirror.RunAtStart {
  29. entry.Prev = time.Now()
  30. entry.ExecTimes++
  31. go models.MirrorUpdate()
  32. }
  33. }
  34. if setting.Cron.RepoHealthCheck.Enabled {
  35. entry, err = c.AddFunc("Repository health check", setting.Cron.RepoHealthCheck.Schedule, models.GitFsck)
  36. if err != nil {
  37. raven.CaptureErrorAndWait(err, nil)
  38. log.Fatal(2, "Cron.(repository health check): %v", err)
  39. }
  40. if setting.Cron.RepoHealthCheck.RunAtStart {
  41. entry.Prev = time.Now()
  42. entry.ExecTimes++
  43. go models.GitFsck()
  44. }
  45. }
  46. if setting.Cron.CheckRepoStats.Enabled {
  47. entry, err = c.AddFunc("Check repository statistics", setting.Cron.CheckRepoStats.Schedule, models.CheckRepoStats)
  48. if err != nil {
  49. raven.CaptureErrorAndWait(err, nil)
  50. log.Fatal(2, "Cron.(check repository statistics): %v", err)
  51. }
  52. if setting.Cron.CheckRepoStats.RunAtStart {
  53. entry.Prev = time.Now()
  54. entry.ExecTimes++
  55. go models.CheckRepoStats()
  56. }
  57. }
  58. if setting.Cron.RepoArchiveCleanup.Enabled {
  59. entry, err = c.AddFunc("Repository archive cleanup", setting.Cron.RepoArchiveCleanup.Schedule, models.DeleteOldRepositoryArchives)
  60. if err != nil {
  61. raven.CaptureErrorAndWait(err, nil)
  62. log.Fatal(2, "Cron.(repository archive cleanup): %v", err)
  63. }
  64. if setting.Cron.RepoArchiveCleanup.RunAtStart {
  65. entry.Prev = time.Now()
  66. entry.ExecTimes++
  67. go models.DeleteOldRepositoryArchives()
  68. }
  69. }
  70. c.Start()
  71. }
  72. // ListTasks returns all running cron tasks.
  73. func ListTasks() []*cron.Entry {
  74. return c.Entries()
  75. }