This repository was archived by the owner on Dec 7, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathInputFilter.go
119 lines (102 loc) · 2.38 KB
/
InputFilter.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
119
package ecms_go_inputfilter
import (
"errors"
"fmt"
"github.com/extensible-cms/ecms-go-validator/is"
)
type InputFilter struct {
Inputs map[string]*Input
BreakOnFailure bool
}
func NewInputFilter() *InputFilter {
return &InputFilter{
Inputs: make(map[string]*Input),
BreakOnFailure: false,
}
}
type InputFilterResult struct {
Result bool `json:"result"`
Messages map[string][]string `json:"messages"`
ValidResults map[string]InputResult `json:"validResults"`
InvalidResults map[string]InputResult `json:"invalidResults"`
}
func NewInputFilterResult() *InputFilterResult {
return &InputFilterResult{
true,
nil,
nil,
nil,
}
}
type InputFilterInterface interface {
Validate(data map[string]interface{})
AddInput(i *Input)
AddInputs(i []*Input)
}
func (inputF *InputFilter) Validate(d map[string]interface{}) InputFilterResult {
ir := *NewInputFilterResult()
inputFInputsLen := len(inputF.Inputs)
if len(d) == 0 && inputFInputsLen == 0 {
ir.Result = true
return ir
}
messages := make(map[string][]string)
validResults := make(map[string]InputResult)
invalidResults := make(map[string]InputResult)
vResult := true
ir.InvalidResults = invalidResults
ir.ValidResults = validResults
ir.Messages = messages
// Validate inputs
for _, i := range inputF.Inputs {
if !i.Required && is.Empty(d[i.Name]) {
continue
}
inputValueRslt := i.Validate(d[i.Name])
if !inputValueRslt.Result {
vResult = false
invalidResults[i.Name] = inputValueRslt
messages[i.Name] = inputValueRslt.Messages
if inputF.BreakOnFailure {
ir.Result = vResult
return ir
}
}
if inputValueRslt.Result {
validResults[i.Name] = inputValueRslt
}
}
ir.Result = vResult
return ir
}
func (inputF *InputFilter) AddInput(i *Input) error {
if i == nil {
return errors.New("empty `Input`'s not allowed")
}
if len(i.Name) == 0 {
return errors.New(
fmt.Sprintf(
"`Input` objects require name values. "+
"Recieved `Input` %v", i,
),
)
}
if inputF.Inputs[i.Name] != nil {
return errors.New(
fmt.Sprintf(
"`Input` with name \"%s\" already exists in input filter",
i.Name,
),
)
}
inputF.Inputs[i.Name] = i
return nil
}
func (inputF *InputFilter) AddInputs(inputs []*Input) error {
for _, i := range inputs {
if err := inputF.AddInput(i); err != nil {
return err
}
}
return nil
}