mirror of
https://github.com/0xJacky/nginx-ui.git
synced 2025-05-12 02:45:49 +02:00
chore: rm unused functions in model.go
This commit is contained in:
parent
38c9727e15
commit
18f2b4aba8
1 changed files with 66 additions and 270 deletions
204
model/model.go
204
model/model.go
|
@ -5,15 +5,11 @@ import (
|
||||||
"github.com/0xJacky/Nginx-UI/internal/logger"
|
"github.com/0xJacky/Nginx-UI/internal/logger"
|
||||||
"github.com/0xJacky/Nginx-UI/settings"
|
"github.com/0xJacky/Nginx-UI/settings"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
"github.com/spf13/cast"
|
|
||||||
"gorm.io/driver/sqlite"
|
"gorm.io/driver/sqlite"
|
||||||
"gorm.io/gen"
|
"gorm.io/gen"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
gormlogger "gorm.io/gorm/logger"
|
gormlogger "gorm.io/gorm/logger"
|
||||||
"gorm.io/gorm/schema"
|
|
||||||
"path"
|
"path"
|
||||||
"strings"
|
|
||||||
"sync"
|
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -91,195 +87,6 @@ type DataList struct {
|
||||||
Pagination Pagination `json:"pagination,omitempty"`
|
Pagination Pagination `json:"pagination,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func SortOrder(c *gin.Context) func(db *gorm.DB) *gorm.DB {
|
|
||||||
return func(db *gorm.DB) *gorm.DB {
|
|
||||||
sort := c.DefaultQuery("order", "desc")
|
|
||||||
order := fmt.Sprintf("`%s` %s", DefaultQuery(c, "sort_by", "id"), sort)
|
|
||||||
return db.Order(order)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func OrderAndPaginate(c *gin.Context) func(db *gorm.DB) *gorm.DB {
|
|
||||||
return func(db *gorm.DB) *gorm.DB {
|
|
||||||
sort := c.DefaultQuery("order", "desc")
|
|
||||||
if sort != "desc" && sort != "asc" {
|
|
||||||
sort = "desc"
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if the order field is valid
|
|
||||||
order := c.DefaultQuery("sort_by", "id")
|
|
||||||
s, _ := schema.Parse(db.Model, &sync.Map{}, schema.NamingStrategy{})
|
|
||||||
if _, ok := s.FieldsByName[order]; ok {
|
|
||||||
order = fmt.Sprintf("%s %s", order, sort)
|
|
||||||
db = db.Order(order)
|
|
||||||
} else {
|
|
||||||
logger.Error("invalid order field: ", order)
|
|
||||||
}
|
|
||||||
|
|
||||||
page := cast.ToInt(c.Query("page"))
|
|
||||||
if page == 0 {
|
|
||||||
page = 1
|
|
||||||
}
|
|
||||||
pageSize := settings.ServerSettings.PageSize
|
|
||||||
reqPageSize := c.Query("page_size")
|
|
||||||
if reqPageSize != "" {
|
|
||||||
pageSize = cast.ToInt(reqPageSize)
|
|
||||||
}
|
|
||||||
offset := (page - 1) * pageSize
|
|
||||||
|
|
||||||
return db.Offset(offset).Limit(pageSize)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToInSearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
queryArray := c.QueryArray(v + "[]")
|
|
||||||
if len(queryArray) == 0 {
|
|
||||||
queryArray = c.QueryArray(v)
|
|
||||||
}
|
|
||||||
if len(queryArray) > 0 {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` IN ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Where(sb.String(), queryArray)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToEqualSearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
if c.Query(v) != "" {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` = ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Where(sb.String(), c.Query(v))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToFussySearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
if c.Query(v) != "" {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` LIKE ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
var sbValue strings.Builder
|
|
||||||
|
|
||||||
_, err = fmt.Fprintf(&sbValue, "%%%s%%", c.Query(v))
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Where(sb.String(), sbValue.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToFussyKeysSearch(c *gin.Context, db *gorm.DB, value string, keys ...string) *gorm.DB {
|
|
||||||
if c.Query(value) == "" {
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
var condition *gorm.DB
|
|
||||||
for i, v := range keys {
|
|
||||||
sb := v + " LIKE ?"
|
|
||||||
sv := "%" + c.Query(value) + "%"
|
|
||||||
|
|
||||||
switch i {
|
|
||||||
case 0:
|
|
||||||
condition = db.Where(db.Where(sb, sv))
|
|
||||||
default:
|
|
||||||
condition = condition.Or(sb, sv)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return db.Where(condition)
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToOrInSearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
queryArray := c.QueryArray(v + "[]")
|
|
||||||
if len(queryArray) == 0 {
|
|
||||||
queryArray = c.QueryArray(v)
|
|
||||||
}
|
|
||||||
if len(queryArray) > 0 {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` IN ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Or(sb.String(), queryArray)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToOrEqualSearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
if c.Query(v) != "" {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` = ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Or(sb.String(), c.Query(v))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func QueryToOrFussySearch(c *gin.Context, db *gorm.DB, keys ...string) *gorm.DB {
|
|
||||||
for _, v := range keys {
|
|
||||||
if c.Query(v) != "" {
|
|
||||||
var sb strings.Builder
|
|
||||||
|
|
||||||
_, err := fmt.Fprintf(&sb, "`%s` LIKE ?", v)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
var sbValue strings.Builder
|
|
||||||
|
|
||||||
_, err = fmt.Fprintf(&sbValue, "%%%s%%", c.Query(v))
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
db = db.Or(sb.String(), sbValue.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return db
|
|
||||||
}
|
|
||||||
|
|
||||||
func TotalPage(total int64, pageSize int) int64 {
|
func TotalPage(total int64, pageSize int) int64 {
|
||||||
n := total / int64(pageSize)
|
n := total / int64(pageSize)
|
||||||
if total%int64(pageSize) > 0 {
|
if total%int64(pageSize) > 0 {
|
||||||
|
@ -288,17 +95,6 @@ func TotalPage(total int64, pageSize int) int64 {
|
||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
|
||||||
func DefaultValue(c *gin.Context, key string, defaultValue any) any {
|
|
||||||
if value, ok := c.Get(key); ok {
|
|
||||||
return value
|
|
||||||
}
|
|
||||||
return defaultValue
|
|
||||||
}
|
|
||||||
|
|
||||||
func DefaultQuery(c *gin.Context, key string, defaultValue any) string {
|
|
||||||
return c.DefaultQuery(key, DefaultValue(c, key, defaultValue).(string))
|
|
||||||
}
|
|
||||||
|
|
||||||
type Method interface {
|
type Method interface {
|
||||||
// FirstByID Where("id=@id")
|
// FirstByID Where("id=@id")
|
||||||
FirstByID(id int) (*gen.T, error)
|
FirstByID(id int) (*gen.T, error)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue