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