/
search.go
118 lines (97 loc) · 1.95 KB
/
search.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package curd
import (
"github.com/gin-gonic/gin"
)
func ApiSearch[T any](fields ...string) gin.HandlerFunc {
return func(ctx *gin.Context) {
var body ParamSearch
err := ctx.ShouldBindJSON(&body)
if err != nil {
Error(ctx, err)
return
}
query := body.ToQuery()
//查询字段
fs := ctx.QueryArray("field")
if len(fs) > 0 {
query.Cols(fs...)
} else if len(fields) > 0 {
query.Cols(fields...)
}
var datum []*T
cnt, err := query.FindAndCount(&datum)
if err != nil {
Error(ctx, err)
return
}
//OK(ctx, cs)
List(ctx, datum, cnt)
}
}
func ApiSearchHook[T any](after func(datum []*T) error, fields ...string) gin.HandlerFunc {
return func(ctx *gin.Context) {
var body ParamSearch
err := ctx.ShouldBindJSON(&body)
if err != nil {
Error(ctx, err)
return
}
query := body.ToQuery()
//查询字段
fs := ctx.QueryArray("field")
if len(fs) > 0 {
query.Cols(fs...)
} else if len(fields) > 0 {
query.Cols(fields...)
}
var datum []*T
cnt, err := query.FindAndCount(&datum)
if err != nil {
Error(ctx, err)
return
}
if after != nil {
if err := after(datum); err != nil {
Error(ctx, err)
return
}
}
//OK(ctx, cs)
List(ctx, datum, cnt)
}
}
func ApiSearchMapHook[T any](after func(datum []map[string]any) error, fields ...string) gin.HandlerFunc {
return func(ctx *gin.Context) {
var body ParamSearch
err := ctx.ShouldBindJSON(&body)
if err != nil {
Error(ctx, err)
return
}
query := body.ToQuery()
//查询字段
fs := ctx.QueryArray("field")
if len(fs) > 0 {
query.Cols(fs...)
} else if len(fields) > 0 {
query.Cols(fields...)
}
var data T
var datum []map[string]any
cnt, err := query.Table(data).FindAndCount(&datum)
if err != nil {
Error(ctx, err)
return
}
//后续处理
if after != nil {
err := after(datum)
if err != nil {
Error(ctx, err)
return
}
}
//OK(ctx, cs)
List(ctx, datum, cnt)
}
}