diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2021-11-18 13:58:42 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-18 13:58:42 +0800 |
commit | 3c3855a05c79ccc7a8495cdbf4a361e7bef74248 (patch) | |
tree | 43f8616bca25a09c0e284e9407819ba43a6a0d79 /models/admin.go | |
parent | 6874fe90e591fa1bfb4b0575b27d876ab544e6e0 (diff) | |
download | gitea-3c3855a05c79ccc7a8495cdbf4a361e7bef74248.tar.gz gitea-3c3855a05c79ccc7a8495cdbf4a361e7bef74248.zip |
Move user functions into user.go (#17659)
* Move user functions into user.go
* Fix test
Diffstat (limited to 'models/admin.go')
-rw-r--r-- | models/admin.go | 157 |
1 files changed, 0 insertions, 157 deletions
diff --git a/models/admin.go b/models/admin.go deleted file mode 100644 index a003aff7e6..0000000000 --- a/models/admin.go +++ /dev/null @@ -1,157 +0,0 @@ -// Copyright 2014 The Gogs Authors. All rights reserved. -// Copyright 2020 The Gitea Authors. All rights reserved. -// Use of this source code is governed by a MIT-style -// license that can be found in the LICENSE file. - -package models - -import ( - "fmt" - - "code.gitea.io/gitea/models/db" - "code.gitea.io/gitea/modules/log" - "code.gitea.io/gitea/modules/storage" - "code.gitea.io/gitea/modules/timeutil" - "code.gitea.io/gitea/modules/util" -) - -// NoticeType describes the notice type -type NoticeType int - -const ( - // NoticeRepository type - NoticeRepository NoticeType = iota + 1 - // NoticeTask type - NoticeTask -) - -// Notice represents a system notice for admin. -type Notice struct { - ID int64 `xorm:"pk autoincr"` - Type NoticeType - Description string `xorm:"TEXT"` - CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` -} - -func init() { - db.RegisterModel(new(Notice)) -} - -// TrStr returns a translation format string. -func (n *Notice) TrStr() string { - return fmt.Sprintf("admin.notices.type_%d", n.Type) -} - -// CreateNotice creates new system notice. -func CreateNotice(tp NoticeType, desc string, args ...interface{}) error { - return createNotice(db.GetEngine(db.DefaultContext), tp, desc, args...) -} - -func createNotice(e db.Engine, tp NoticeType, desc string, args ...interface{}) error { - if len(args) > 0 { - desc = fmt.Sprintf(desc, args...) - } - n := &Notice{ - Type: tp, - Description: desc, - } - _, err := e.Insert(n) - return err -} - -// CreateRepositoryNotice creates new system notice with type NoticeRepository. -func CreateRepositoryNotice(desc string, args ...interface{}) error { - return createNotice(db.GetEngine(db.DefaultContext), NoticeRepository, desc, args...) -} - -// RemoveAllWithNotice removes all directories in given path and -// creates a system notice when error occurs. -func RemoveAllWithNotice(title, path string) { - removeAllWithNotice(db.GetEngine(db.DefaultContext), title, path) -} - -// RemoveStorageWithNotice removes a file from the storage and -// creates a system notice when error occurs. -func RemoveStorageWithNotice(bucket storage.ObjectStorage, title, path string) { - removeStorageWithNotice(db.GetEngine(db.DefaultContext), bucket, title, path) -} - -func removeStorageWithNotice(e db.Engine, bucket storage.ObjectStorage, title, path string) { - if err := bucket.Delete(path); err != nil { - desc := fmt.Sprintf("%s [%s]: %v", title, path, err) - log.Warn(title+" [%s]: %v", path, err) - if err = createNotice(e, NoticeRepository, desc); err != nil { - log.Error("CreateRepositoryNotice: %v", err) - } - } -} - -func removeAllWithNotice(e db.Engine, title, path string) { - if err := util.RemoveAll(path); err != nil { - desc := fmt.Sprintf("%s [%s]: %v", title, path, err) - log.Warn(title+" [%s]: %v", path, err) - if err = createNotice(e, NoticeRepository, desc); err != nil { - log.Error("CreateRepositoryNotice: %v", err) - } - } -} - -// CountNotices returns number of notices. -func CountNotices() int64 { - count, _ := db.GetEngine(db.DefaultContext).Count(new(Notice)) - return count -} - -// Notices returns notices in given page. -func Notices(page, pageSize int) ([]*Notice, error) { - notices := make([]*Notice, 0, pageSize) - return notices, db.GetEngine(db.DefaultContext). - Limit(pageSize, (page-1)*pageSize). - Desc("created_unix"). - Find(¬ices) -} - -// DeleteNotice deletes a system notice by given ID. -func DeleteNotice(id int64) error { - _, err := db.GetEngine(db.DefaultContext).ID(id).Delete(new(Notice)) - return err -} - -// DeleteNotices deletes all notices with ID from start to end (inclusive). -func DeleteNotices(start, end int64) error { - if start == 0 && end == 0 { - _, err := db.GetEngine(db.DefaultContext).Exec("DELETE FROM notice") - return err - } - - sess := db.GetEngine(db.DefaultContext).Where("id >= ?", start) - if end > 0 { - sess.And("id <= ?", end) - } - _, err := sess.Delete(new(Notice)) - return err -} - -// DeleteNoticesByIDs deletes notices by given IDs. -func DeleteNoticesByIDs(ids []int64) error { - if len(ids) == 0 { - return nil - } - _, err := db.GetEngine(db.DefaultContext). - In("id", ids). - Delete(new(Notice)) - return err -} - -// GetAdminUser returns the first administrator -func GetAdminUser() (*User, error) { - var admin User - has, err := db.GetEngine(db.DefaultContext).Where("is_admin=?", true).Get(&admin) - if err != nil { - return nil, err - } else if !has { - return nil, ErrUserNotExist{} - } - - return &admin, nil -} |