1JSON::Validator::Joi(3)User Contributed Perl DocumentatioJnSON::Validator::Joi(3)
2
3
4

NAME

6       JSON::Validator::Joi - Joi validation sugar for JSON::Validator
7

SYNOPSIS

9         use JSON::Validator::Joi "joi";
10
11         my @errors = joi->object->props(
12           age   => joi->integer->min(0)->max(200),
13           email => joi->regex(".@.")->required,
14           name  => joi->string->min(1),
15         )->validate({
16           name  => "Jan Henning",
17           age   => 34,
18           email => "jhthorsen@cpan.org",
19         });
20
21         die "@errors" if @errors;
22
23   EXPORTED FUNCTIONS
24   joi
25         $joi = joi(%attrs);
26
27       Same as:
28
29         JSON::Validator::Joi->new(%attrs);
30

DESCRIPTION

32       JSON::Validator::Joi is an elegant DSL schema-builder. The main purpose
33       is to build a JSON Schema <https://json-schema.org/> for
34       JSON::Validator, but it can also validate data directly with sane
35       defaults.
36

ATTRIBUTES

38   enum
39         my $joi       = $joi->enum(["foo", "bar"]);
40         my $array_ref = $joi->enum;
41
42       Defines a list of enum values for "integer", "number" and "string".
43
44   format
45         my $joi = $joi->format("email");
46         my $str = $joi->format;
47
48       Used to set the format of the "string".  See also "iso_date", "email"
49       and "uri".
50
51   max
52         my $joi = $joi->max(10);
53         my $int = $joi->max;
54
55       • array
56
57         Defines the max number of items in the array.
58
59       • integer, number
60
61         Defined the max value.
62
63       • object
64
65         Defines the max number of items in the object.
66
67       • string
68
69         Defines how long the string can be.
70
71   min
72         my $joi = $joi->min(10);
73         my $int = $joi->min;
74
75       • array
76
77         Defines the minimum number of items in the array.
78
79       • integer, number
80
81         Defined the minimum value.
82
83       • object
84
85         Defines the minimum number of items in the object.
86
87       • string
88
89         Defines how short the string can be.
90
91   multiple_of
92         my $joi = $joi->multiple_of(3);
93         my $int = $joi->multiple_of;
94
95       Used by "integer" and "number" to define what the number must be a
96       multiple of.
97
98   regex
99         my $joi = $joi->regex("^\w+$");
100         my $str = $joi->regex;
101
102       Defines a pattern that "string" will be validated against.
103
104   type
105         my $joi = $joi->type("string");
106         my $joi = $joi->type([qw(null integer)]);
107         my $any = $joi->type;
108
109       Sets the required type. This attribute is set by the convenience
110       methods "array", "integer", "object" and "string", but can be set
111       manually if you need to check against a list of type.
112
113   validator
114         my $joi = $joi->validator(JSON::Validator::Schema::Draft7->new);
115         my $jv  = $joi->validator;
116
117       Defaults to a JSON::Validator object. This object is used by
118       "validate".
119
120       Note: This might change to JSON::Validator::Schema::Draft7 or a later
121       schema in the future.
122

METHODS

124   TO_JSON
125       Alias for "compile".
126
127   alphanum
128         my $joi = $joi->alphanum;
129
130       Sets "regex" to "^\w*$".
131
132   array
133         my $joi = $joi->array;
134
135       Sets "type" to "array".
136
137   boolean
138         my $joi = $joi->boolean;
139
140       Sets "type" to "boolean".
141
142   compile
143         my $hash_ref = $joi->compile;
144
145       Will convert this object into a JSON-Schema data structure that
146       "schema" in JSON::Validator understands.
147
148   date_time
149         my $joi = $joi->date_time;
150
151       Sets "format" to date-time.
152
153   email
154         my $joi = $joi->email;
155
156       Sets "format" to email.
157
158   extend
159         my $new_joi = $joi->extend($other_joi_object);
160
161       Will extend $joi with the definitions in $other_joi_object and return a
162       new object.
163
164   iso_date
165       Alias for "date_time".
166
167   integer
168         my $joi = $joi->integer;
169
170       Sets "type" to "integer".
171
172   items
173         my $joi = $joi->items($joi);
174         my $joi = $joi->items([$joi, ...]);
175
176       Defines a list of items for the "array" type.
177
178   length
179         my $joi = $joi->length(10);
180
181       Sets both "min" and "max" to the number provided.
182
183   lowercase
184         my $joi = $joi->lowercase;
185
186       Will set "regex" to only match lower case strings.
187
188   negative
189         my $joi = $joi->negative;
190
191       Sets "max" to 0.
192
193   number
194         my $joi = $joi->number;
195
196       Sets "type" to "number".
197
198   object
199         my $joi = $joi->object;
200
201       Sets "type" to "object".
202
203   pattern
204       Alias for "regex".
205
206   positive
207         my $joi = $joi->positive;
208
209       Sets "min" to 0.
210
211   props
212         my $joi = $joi->props(name => JSON::Validator::Joi->new->string, ...);
213
214       Used to define properties for an "object" type. Each key is the name of
215       the parameter and the values must be a JSON::Validator::Joi object.
216
217   required
218         my $joi = $joi->required;
219
220       Marks the current property as required.
221
222   strict
223         my $joi = $joi->strict;
224
225       Sets "array" and "object" to not allow any more items/keys than what is
226       defined.
227
228   string
229         my $joi = $joi->string;
230
231       Sets "type" to "string".
232
233   token
234         my $joi = $joi->token;
235
236       Sets "regex" to "^[a-zA-Z0-9_]+$".
237
238   validate
239         my @errors = $joi->validate($data);
240
241       Used to validate $data using "validate" in JSON::Validator. Returns a
242       list of JSON::Validator::Error objects on invalid input.
243
244   unique
245         my $joi = $joi->unique;
246
247       Used to force the "array" to only contain unique items.
248
249   uppercase
250         my $joi = $joi->uppercase;
251
252       Will set "regex" to only match upper case strings.
253
254   uri
255         my $joi = $joi->uri;
256
257       Sets "format" to uri.
258

SEE ALSO

260       JSON::Validator
261
262       <https://github.com/hapijs/joi>.
263
264
265
266perl v5.36.0                      2022-07-22           JSON::Validator::Joi(3)
Impressum