fix: sort order

This commit is contained in:
Jacky 2024-02-25 10:24:17 +08:00
parent b1e95d30f1
commit 0d140b41da

View file

@ -1,36 +1,34 @@
package cosy
import (
"fmt"
"github.com/0xJacky/Nginx-UI/internal/logger"
"gorm.io/gorm"
"gorm.io/gorm/schema"
"strings"
"sync"
)
func (c *Ctx[T]) SortOrder() func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
sort := c.ctx.DefaultQuery("order", "desc")
if sort != "desc" && sort != "asc" {
sort = "desc"
order := c.ctx.DefaultQuery("order", "desc")
if order != "desc" && order != "asc" {
order = "desc"
}
order := c.itemKey
if value, ok := c.ctx.Get("order"); ok {
// check if the order field is valid
// todo: maybe we can use more generic way to check if the sort_by is valid
sortBy := c.ctx.DefaultQuery("sort_by", c.itemKey)
s, _ := schema.Parse(c.Model, &sync.Map{}, schema.NamingStrategy{})
if _, ok := s.FieldsByDBName[value.(string)]; ok {
order = value.(string)
} else {
logger.Error("invalid order field:", order)
}
} else if value, ok := c.ctx.Get("sort_by"); ok {
order = value.(string)
if _, ok := s.FieldsByDBName[sortBy]; !ok && sortBy != c.itemKey {
logger.Error("invalid order field:", sortBy)
return db
}
order = fmt.Sprintf("%s %s", order, sort)
return db.Order(order)
var sb strings.Builder
sb.WriteString(sortBy)
sb.WriteString(" ")
sb.WriteString(order)
return db.Order(sb.String())
}
}