-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsql.go
97 lines (73 loc) · 1.38 KB
/
sql.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
package validator
import (
"context"
"github.com/xwb1989/sqlparser"
)
type SQL struct {
message string
whenFunc WhenFunc
asWhereClause bool
skipEmpty bool
skipError bool
}
func NewSQL() *SQL {
return &SQL{
message: "Value is invalid sql.",
}
}
func (r *SQL) AsWhereClause() *SQL {
rc := *r
rc.asWhereClause = true
return &rc
}
func (r *SQL) WithMessage(message string) *SQL {
rc := *r
rc.message = message
return &rc
}
func (r *SQL) When(v WhenFunc) *SQL {
rc := *r
rc.whenFunc = v
return &rc
}
func (r *SQL) when() WhenFunc {
return r.whenFunc
}
func (r *SQL) setWhen(v WhenFunc) {
r.whenFunc = v
}
func (r *SQL) SkipOnEmpty() *SQL {
rc := *r
rc.skipEmpty = true
return &rc
}
func (r *SQL) skipOnEmpty() bool {
return r.skipEmpty
}
func (r *SQL) setSkipOnEmpty(v bool) {
r.skipEmpty = v
}
func (r *SQL) SkipOnError() *SQL {
rs := *r
rs.skipError = true
return &rs
}
func (r *SQL) shouldSkipOnError() bool {
return r.skipError
}
func (r *SQL) setSkipOnError(v bool) {
r.skipError = v
}
func (r *SQL) ValidateValue(_ context.Context, value any) error {
v, ok := toString(value)
if !ok {
return NewResult().WithError(NewValidationError(r.message))
}
if r.asWhereClause {
v = "select * from x where " + v
}
if _, err := sqlparser.Parse(v); err != nil {
return NewResult().WithError(NewValidationError(r.message))
}
return nil
}