2023-05-26 01:04:43 +00:00
|
|
|
package entity
|
|
|
|
|
|
|
|
import (
|
2023-05-29 03:53:16 +00:00
|
|
|
"fmt"
|
2023-05-26 01:04:43 +00:00
|
|
|
"strings"
|
|
|
|
|
2023-05-31 05:11:25 +00:00
|
|
|
"npm/internal/database"
|
2023-05-26 01:04:43 +00:00
|
|
|
"npm/internal/model"
|
|
|
|
|
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
|
|
|
func ScopeOffsetLimit(pageInfo *model.PageInfo) func(db *gorm.DB) *gorm.DB {
|
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
|
|
|
if pageInfo.Offset > 0 || pageInfo.Limit > 0 {
|
|
|
|
return db.Limit(pageInfo.Limit).Offset(pageInfo.Offset)
|
|
|
|
}
|
|
|
|
return db
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-27 02:38:35 +00:00
|
|
|
func ScopeOrderBy(sort []model.Sort, defaultSort model.Sort) func(db *gorm.DB) *gorm.DB {
|
2023-05-26 01:04:43 +00:00
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
2023-07-27 02:38:35 +00:00
|
|
|
if sort != nil {
|
2023-05-26 01:04:43 +00:00
|
|
|
// Sort by items in slice
|
2023-07-27 02:38:35 +00:00
|
|
|
return db.Order(sortToOrderString(sort))
|
2023-05-26 01:04:43 +00:00
|
|
|
} else if defaultSort.Field != "" {
|
|
|
|
// Default to this sort
|
|
|
|
str := defaultSort.Field
|
|
|
|
if defaultSort.Direction != "" {
|
|
|
|
str = str + " " + defaultSort.Direction
|
|
|
|
}
|
|
|
|
return db.Order(str)
|
|
|
|
}
|
|
|
|
return db
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-24 01:49:08 +00:00
|
|
|
func ScopeFilters(filters []model.Filter, filterMap map[string]model.FilterMapValue) func(db *gorm.DB) *gorm.DB {
|
2023-05-26 01:04:43 +00:00
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
2023-05-31 05:11:25 +00:00
|
|
|
like := database.GetCaseInsensitiveLike()
|
2023-05-29 03:53:16 +00:00
|
|
|
for _, f := range filters {
|
|
|
|
// Lookup this filter field from the name map
|
|
|
|
if _, ok := filterMap[f.Field]; ok {
|
|
|
|
f.Field = filterMap[f.Field].Field
|
2023-05-26 01:04:43 +00:00
|
|
|
}
|
2023-05-29 03:53:16 +00:00
|
|
|
|
|
|
|
// For boolean fields, the value needs tweaking
|
|
|
|
if filterMap[f.Field].Type == "boolean" {
|
|
|
|
f.Value = parseBoolValue(f.Value[0])
|
|
|
|
}
|
|
|
|
|
|
|
|
// Quick adjustments for commonalities
|
|
|
|
if f.Modifier == "in" && len(f.Value) == 1 {
|
|
|
|
f.Modifier = "equals"
|
|
|
|
} else if f.Modifier == "notin" && len(f.Value) == 1 {
|
|
|
|
f.Modifier = "not"
|
|
|
|
}
|
|
|
|
|
|
|
|
switch strings.ToLower(f.Modifier) {
|
|
|
|
case "not":
|
|
|
|
db.Where(fmt.Sprintf("%s != ?", f.Field), f.Value)
|
|
|
|
case "min":
|
|
|
|
db.Where(fmt.Sprintf("%s >= ?", f.Field), f.Value)
|
|
|
|
case "max":
|
|
|
|
db.Where(fmt.Sprintf("%s <= ?", f.Field), f.Value)
|
|
|
|
case "greater":
|
|
|
|
db.Where(fmt.Sprintf("%s > ?", f.Field), f.Value)
|
|
|
|
case "lesser":
|
|
|
|
db.Where(fmt.Sprintf("%s < ?", f.Field), f.Value)
|
|
|
|
|
|
|
|
// LIKE modifiers:
|
|
|
|
case "contains":
|
2023-05-31 05:11:25 +00:00
|
|
|
db.Where(fmt.Sprintf("%s %s ?", f.Field, like), `%`+f.Value[0]+`%`)
|
2023-05-29 03:53:16 +00:00
|
|
|
case "starts":
|
2023-05-31 05:11:25 +00:00
|
|
|
db.Where(fmt.Sprintf("%s %s ?", f.Field, like), f.Value[0]+`%`)
|
2023-05-29 03:53:16 +00:00
|
|
|
case "ends":
|
2023-05-31 05:11:25 +00:00
|
|
|
db.Where(fmt.Sprintf("%s %s ?", f.Field, like), `%`+f.Value[0])
|
2023-05-29 03:53:16 +00:00
|
|
|
|
|
|
|
// Array parameter modifiers:
|
|
|
|
case "in":
|
|
|
|
db.Where(fmt.Sprintf("%s IN ?", f.Field), f.Value)
|
|
|
|
case "notin":
|
|
|
|
db.Where(fmt.Sprintf("%s NOT IN ?", f.Field), f.Value)
|
|
|
|
|
|
|
|
// Default: equals
|
|
|
|
default:
|
|
|
|
db.Where(fmt.Sprintf("%s = ?", f.Field), f.Value)
|
|
|
|
}
|
|
|
|
}
|
2023-05-26 01:04:43 +00:00
|
|
|
return db
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func sortToOrderString(sorts []model.Sort) string {
|
|
|
|
strs := make([]string, 0)
|
|
|
|
for _, i := range sorts {
|
|
|
|
str := i.Field
|
|
|
|
if i.Direction != "" {
|
|
|
|
str = str + " " + i.Direction
|
|
|
|
}
|
|
|
|
strs = append(strs, str)
|
|
|
|
}
|
|
|
|
return strings.Join(strs, ", ")
|
|
|
|
}
|
2023-05-29 03:53:16 +00:00
|
|
|
|
|
|
|
func parseBoolValue(v string) []string {
|
|
|
|
bVal := "0"
|
|
|
|
switch strings.ToLower(v) {
|
|
|
|
case "yes":
|
|
|
|
fallthrough
|
|
|
|
case "true":
|
|
|
|
fallthrough
|
|
|
|
case "on":
|
|
|
|
fallthrough
|
|
|
|
case "t":
|
|
|
|
fallthrough
|
|
|
|
case "1":
|
|
|
|
fallthrough
|
|
|
|
case "y":
|
|
|
|
bVal = "1"
|
|
|
|
}
|
|
|
|
return []string{bVal}
|
|
|
|
}
|