forked from qri-io/jsonschema
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkeywords_numeric.go
172 lines (143 loc) · 4.96 KB
/
keywords_numeric.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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
package jsonschema
import (
"context"
"fmt"
jptr "github.com/qri-io/jsonpointer"
)
// MultipleOf defines the multipleOf JSON Schema keyword
type MultipleOf float64
// NewMultipleOf allocates a new MultipleOf keyword
func NewMultipleOf() Keyword {
return new(MultipleOf)
}
// Register implements the Keyword interface for MultipleOf
func (m *MultipleOf) Register(uri string, registry *SchemaRegistry) {}
// Resolve implements the Keyword interface for MultipleOf
func (m *MultipleOf) Resolve(pointer jptr.Pointer, uri string) *Schema {
return nil
}
// ValidateKeyword implements the Keyword interface for MultipleOf
func (m MultipleOf) ValidateKeyword(ctx context.Context, currentState *ValidationState, data interface{}) {
schemaDebug("[MultipleOf] Validating")
if num, ok := convertNumberToFloat(data); ok {
div := num / float64(m)
if float64(int(div)) != div {
currentState.AddError(data, fmt.Sprintf("must be a multiple of %v", m))
}
}
}
// Maximum defines the maximum JSON Schema keyword
type Maximum float64
// NewMaximum allocates a new Maximum keyword
func NewMaximum() Keyword {
return new(Maximum)
}
// Register implements the Keyword interface for Maximum
func (m *Maximum) Register(uri string, registry *SchemaRegistry) {}
// Resolve implements the Keyword interface for Maximum
func (m *Maximum) Resolve(pointer jptr.Pointer, uri string) *Schema {
return nil
}
// ValidateKeyword implements the Keyword interface for Maximum
func (m Maximum) ValidateKeyword(ctx context.Context, currentState *ValidationState, data interface{}) {
schemaDebug("[Maximum] Validating")
if num, ok := convertNumberToFloat(data); ok {
if num > float64(m) {
currentState.AddError(data, fmt.Sprintf("must be less than or equal to %v", m))
}
}
}
// ExclusiveMaximum defines the exclusiveMaximum JSON Schema keyword
type ExclusiveMaximum float64
// NewExclusiveMaximum allocates a new ExclusiveMaximum keyword
func NewExclusiveMaximum() Keyword {
return new(ExclusiveMaximum)
}
// Register implements the Keyword interface for ExclusiveMaximum
func (m *ExclusiveMaximum) Register(uri string, registry *SchemaRegistry) {}
// Resolve implements the Keyword interface for ExclusiveMaximum
func (m *ExclusiveMaximum) Resolve(pointer jptr.Pointer, uri string) *Schema {
return nil
}
// ValidateKeyword implements the Keyword interface for ExclusiveMaximum
func (m ExclusiveMaximum) ValidateKeyword(ctx context.Context, currentState *ValidationState, data interface{}) {
schemaDebug("[ExclusiveMaximum] Validating")
if num, ok := convertNumberToFloat(data); ok {
if num >= float64(m) {
currentState.AddError(data, fmt.Sprintf("%v must be less than %v", num, m))
}
}
}
// Minimum defines the minimum JSON Schema keyword
type Minimum float64
// NewMinimum allocates a new Minimum keyword
func NewMinimum() Keyword {
return new(Minimum)
}
// Register implements the Keyword interface for Minimum
func (m *Minimum) Register(uri string, registry *SchemaRegistry) {}
// Resolve implements the Keyword interface for Minimum
func (m *Minimum) Resolve(pointer jptr.Pointer, uri string) *Schema {
return nil
}
// ValidateKeyword implements the Keyword interface for Minimum
func (m Minimum) ValidateKeyword(ctx context.Context, currentState *ValidationState, data interface{}) {
schemaDebug("[Minimum] Validating")
if num, ok := convertNumberToFloat(data); ok {
if num < float64(m) {
currentState.AddError(data, fmt.Sprintf("must be greater than or equal to %v", m))
}
}
}
// ExclusiveMinimum defines the exclusiveMinimum JSON Schema keyword
type ExclusiveMinimum float64
// NewExclusiveMinimum allocates a new ExclusiveMinimum keyword
func NewExclusiveMinimum() Keyword {
return new(ExclusiveMinimum)
}
// Register implements the Keyword interface for ExclusiveMinimum
func (m *ExclusiveMinimum) Register(uri string, registry *SchemaRegistry) {}
// Resolve implements the Keyword interface for ExclusiveMinimum
func (m *ExclusiveMinimum) Resolve(pointer jptr.Pointer, uri string) *Schema {
return nil
}
// ValidateKeyword implements the Keyword interface for ExclusiveMinimum
func (m ExclusiveMinimum) ValidateKeyword(ctx context.Context, currentState *ValidationState, data interface{}) {
schemaDebug("[ExclusiveMinimum] Validating")
if num, ok := convertNumberToFloat(data); ok {
if num <= float64(m) {
currentState.AddError(data, fmt.Sprintf("%v must be greater than %v", num, m))
}
}
}
func convertNumberToFloat(data interface{}) (float64, bool) {
switch v := data.(type) {
case uint:
return float64(v), true
case uint8:
return float64(v), true
case uint16:
return float64(v), true
case uint32:
return float64(v), true
case uint64:
return float64(v), true
case int:
return float64(v), true
case int8:
return float64(v), true
case int16:
return float64(v), true
case int32:
return float64(v), true
case int64:
return float64(v), true
case float32:
return float64(v), true
case float64:
return float64(v), true
case uintptr:
return float64(v), true
}
return 0, false
}