nginx-proxy-manager-zh/backend/internal/entity/lists.go

48 lines
1.2 KiB
Go
Raw Normal View History

package entity
import (
"npm/internal/database"
"npm/internal/model"
"gorm.io/gorm"
)
// ListResponse is the JSON response for users list
type ListResponse struct {
Total int64 `json:"total"`
Offset int `json:"offset"`
Limit int `json:"limit"`
Sort []model.Sort `json:"sort"`
Filter []model.Filter `json:"filter,omitempty"`
Items interface{} `json:"items,omitempty"`
}
// ListQueryBuilder is used to setup queries for lists
func ListQueryBuilder(
pageInfo *model.PageInfo,
filters []model.Filter,
filterMap map[string]model.FilterMapValue,
) *gorm.DB {
scopes := make([]func(*gorm.DB) *gorm.DB, 0)
2023-05-28 23:53:16 -04:00
scopes = append(scopes, ScopeFilters(filters, filterMap))
return database.GetDB().Scopes(scopes...)
}
2023-05-30 23:52:58 -04:00
// AddOrderToList is used after query above is used for counting
// Postgres in particular doesn't like count(*) when ordering at the same time
func AddOrderToList(
dbo *gorm.DB,
sort []model.Sort,
2023-05-30 23:52:58 -04:00
defaultSort model.Sort,
) *gorm.DB {
return dbo.Scopes(ScopeOrderBy(sort, defaultSort))
}
// AddOffsetLimitToList is used after query above is used for pagination
func AddOffsetLimitToList(
dbo *gorm.DB,
pageInfo *model.PageInfo,
) *gorm.DB {
return dbo.Scopes(ScopeOffsetLimit(pageInfo))
2023-05-30 23:52:58 -04:00
}