admin.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package models
  2. import (
  3. "fmt"
  4. "gitote/gitote/pkg/setting"
  5. "gitote/gitote/pkg/tool"
  6. "os"
  7. "os/exec"
  8. "strings"
  9. "time"
  10. "github.com/Unknwon/com"
  11. "github.com/go-xorm/xorm"
  12. log "gopkg.in/clog.v1"
  13. )
  14. type NoticeType int
  15. const (
  16. NOTICE_REPOSITORY NoticeType = iota + 1
  17. )
  18. // Notice represents a system notice for admin.
  19. type Notice struct {
  20. ID int64
  21. Type NoticeType
  22. Description string `xorm:"TEXT"`
  23. Created time.Time `xorm:"-" json:"-"`
  24. CreatedUnix int64
  25. }
  26. func (n *Notice) BeforeInsert() {
  27. n.CreatedUnix = time.Now().Unix()
  28. }
  29. func (n *Notice) AfterSet(colName string, _ xorm.Cell) {
  30. switch colName {
  31. case "created_unix":
  32. n.Created = time.Unix(n.CreatedUnix, 0).Local()
  33. }
  34. }
  35. // TrStr returns a translation format string.
  36. func (n *Notice) TrStr() string {
  37. return "admin.notices.type_" + com.ToStr(n.Type)
  38. }
  39. // CreateNotice creates new system notice.
  40. func CreateNotice(tp NoticeType, desc string) error {
  41. // prevent panic if database connection is not available at this point
  42. if x == nil {
  43. return fmt.Errorf("Could not save notice due database connection not being available: %d %s", tp, desc)
  44. }
  45. n := &Notice{
  46. Type: tp,
  47. Description: desc,
  48. }
  49. _, err := x.Insert(n)
  50. return err
  51. }
  52. // CreateRepositoryNotice creates new system notice with type NOTICE_REPOSITORY.
  53. func CreateRepositoryNotice(desc string) error {
  54. return CreateNotice(NOTICE_REPOSITORY, desc)
  55. }
  56. // RemoveAllWithNotice removes all directories in given path and
  57. // creates a system notice when error occurs.
  58. func RemoveAllWithNotice(title, path string) {
  59. var err error
  60. // LEGACY [Go 1.7, 0.12]: workaround for Go not being able to remove read-only files/folders: https://github.com/golang/go/issues/9606
  61. // this bug should be fixed on Go 1.7, so the workaround should be removed when Gitote don't support Go 1.6 anymore:
  62. // https://github.com/golang/go/commit/2ffb3e5d905b5622204d199128dec06cefd57790
  63. // Note: Windows complains when delete target does not exist, therefore we can skip deletion in such cases.
  64. if setting.IsWindows && com.IsExist(path) {
  65. // converting "/" to "\" in path on Windows
  66. path = strings.Replace(path, "/", "\\", -1)
  67. err = exec.Command("cmd", "/C", "rmdir", "/S", "/Q", path).Run()
  68. } else {
  69. err = os.RemoveAll(path)
  70. }
  71. if err != nil {
  72. desc := fmt.Sprintf("%s [%s]: %v", title, path, err)
  73. log.Warn(desc)
  74. if err = CreateRepositoryNotice(desc); err != nil {
  75. log.Error(4, "CreateRepositoryNotice: %v", err)
  76. }
  77. }
  78. }
  79. // CountNotices returns number of notices.
  80. func CountNotices() int64 {
  81. count, _ := x.Count(new(Notice))
  82. return count
  83. }
  84. // Notices returns number of notices in given page.
  85. func Notices(page, pageSize int) ([]*Notice, error) {
  86. notices := make([]*Notice, 0, pageSize)
  87. return notices, x.Limit(pageSize, (page-1)*pageSize).Desc("id").Find(&notices)
  88. }
  89. // DeleteNotice deletes a system notice by given ID.
  90. func DeleteNotice(id int64) error {
  91. _, err := x.Id(id).Delete(new(Notice))
  92. return err
  93. }
  94. // DeleteNotices deletes all notices with ID from start to end (inclusive).
  95. func DeleteNotices(start, end int64) error {
  96. sess := x.Where("id >= ?", start)
  97. if end > 0 {
  98. sess.And("id <= ?", end)
  99. }
  100. _, err := sess.Delete(new(Notice))
  101. return err
  102. }
  103. // DeleteNoticesByIDs deletes notices by given IDs.
  104. func DeleteNoticesByIDs(ids []int64) error {
  105. if len(ids) == 0 {
  106. return nil
  107. }
  108. _, err := x.Where("id IN (" + strings.Join(tool.Int64sToStrings(ids), ",") + ")").Delete(new(Notice))
  109. return err
  110. }