123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- package db
- import (
- "fmt"
- "os"
- "strings"
- "time"
- "github.com/unknwon/com"
- log "unknwon.dev/clog/v2"
- "xorm.io/xorm"
- "gogs.io/gogs/internal/tool"
- )
- type NoticeType int
- const (
- NOTICE_REPOSITORY NoticeType = iota + 1
- )
- type Notice struct {
- ID int64
- Type NoticeType
- Description string `xorm:"TEXT"`
- Created time.Time `xorm:"-" json:"-"`
- CreatedUnix int64
- }
- func (n *Notice) BeforeInsert() {
- n.CreatedUnix = time.Now().Unix()
- }
- func (n *Notice) AfterSet(colName string, _ xorm.Cell) {
- switch colName {
- case "created_unix":
- n.Created = time.Unix(n.CreatedUnix, 0).Local()
- }
- }
- func (n *Notice) TrStr() string {
- return "admin.notices.type_" + com.ToStr(n.Type)
- }
- func CreateNotice(tp NoticeType, desc string) error {
-
- if x == nil {
- return fmt.Errorf("could not save notice due database connection not being available: %d %s", tp, desc)
- }
- n := &Notice{
- Type: tp,
- Description: desc,
- }
- _, err := x.Insert(n)
- return err
- }
- func CreateRepositoryNotice(desc string) error {
- return CreateNotice(NOTICE_REPOSITORY, desc)
- }
- func RemoveAllWithNotice(title, path string) {
- if err := os.RemoveAll(path); err != nil {
- desc := fmt.Sprintf("%s [%s]: %v", title, path, err)
- log.Warn(desc)
- if err = CreateRepositoryNotice(desc); err != nil {
- log.Error("CreateRepositoryNotice: %v", err)
- }
- }
- }
- func CountNotices() int64 {
- count, _ := x.Count(new(Notice))
- return count
- }
- func Notices(page, pageSize int) ([]*Notice, error) {
- notices := make([]*Notice, 0, pageSize)
- return notices, x.Limit(pageSize, (page-1)*pageSize).Desc("id").Find(¬ices)
- }
- func DeleteNotice(id int64) error {
- _, err := x.Id(id).Delete(new(Notice))
- return err
- }
- func DeleteNotices(start, end int64) error {
- sess := x.Where("id >= ?", start)
- if end > 0 {
- sess.And("id <= ?", end)
- }
- _, err := sess.Delete(new(Notice))
- return err
- }
- func DeleteNoticesByIDs(ids []int64) error {
- if len(ids) == 0 {
- return nil
- }
- _, err := x.Where("id IN (" + strings.Join(tool.Int64sToStrings(ids), ",") + ")").Delete(new(Notice))
- return err
- }
|