summaryrefslogtreecommitdiffstats
path: root/models/admin.go
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2021-11-18 13:58:42 +0800
committerGitHub <noreply@github.com>2021-11-18 13:58:42 +0800
commit3c3855a05c79ccc7a8495cdbf4a361e7bef74248 (patch)
tree43f8616bca25a09c0e284e9407819ba43a6a0d79 /models/admin.go
parent6874fe90e591fa1bfb4b0575b27d876ab544e6e0 (diff)
downloadgitea-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.go157
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(&notices)
-}
-
-// 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
-}