From 0d140b41da244fded7dcecc64826c20b55a2caea Mon Sep 17 00:00:00 2001 From: Jacky Date: Sun, 25 Feb 2024 10:24:17 +0800 Subject: [PATCH] fix: sort order --- api/cosy/sort.go | 34 ++++++++++++++++------------------ 1 file changed, 16 insertions(+), 18 deletions(-) diff --git a/api/cosy/sort.go b/api/cosy/sort.go index e62ab6c1..20634427 100644 --- a/api/cosy/sort.go +++ b/api/cosy/sort.go @@ -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 - 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) + sortBy := c.ctx.DefaultQuery("sort_by", c.itemKey) + + s, _ := schema.Parse(c.Model, &sync.Map{}, schema.NamingStrategy{}) + 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()) } }