authzed 1.1.0 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,862 +0,0 @@
1
- syntax = "proto2";
2
- package validate;
3
-
4
- option go_package = "github.com/envoyproxy/protoc-gen-validate/validate";
5
- option java_package = "io.envoyproxy.pgv.validate";
6
-
7
- import "google/protobuf/descriptor.proto";
8
- import "google/protobuf/duration.proto";
9
- import "google/protobuf/timestamp.proto";
10
-
11
- // Validation rules applied at the message level
12
- extend google.protobuf.MessageOptions {
13
- // Disabled nullifies any validation rules for this message, including any
14
- // message fields associated with it that do support validation.
15
- optional bool disabled = 1071;
16
- // Ignore skips generation of validation methods for this message.
17
- optional bool ignored = 1072;
18
- }
19
-
20
- // Validation rules applied at the oneof level
21
- extend google.protobuf.OneofOptions {
22
- // Required ensures that exactly one the field options in a oneof is set;
23
- // validation fails if no fields in the oneof are set.
24
- optional bool required = 1071;
25
- }
26
-
27
- // Validation rules applied at the field level
28
- extend google.protobuf.FieldOptions {
29
- // Rules specify the validations to be performed on this field. By default,
30
- // no validation is performed against a field.
31
- optional FieldRules rules = 1071;
32
- }
33
-
34
- // FieldRules encapsulates the rules for each type of field. Depending on the
35
- // field, the correct set should be used to ensure proper validations.
36
- message FieldRules {
37
- optional MessageRules message = 17;
38
- oneof type {
39
- // Scalar Field Types
40
- FloatRules float = 1;
41
- DoubleRules double = 2;
42
- Int32Rules int32 = 3;
43
- Int64Rules int64 = 4;
44
- UInt32Rules uint32 = 5;
45
- UInt64Rules uint64 = 6;
46
- SInt32Rules sint32 = 7;
47
- SInt64Rules sint64 = 8;
48
- Fixed32Rules fixed32 = 9;
49
- Fixed64Rules fixed64 = 10;
50
- SFixed32Rules sfixed32 = 11;
51
- SFixed64Rules sfixed64 = 12;
52
- BoolRules bool = 13;
53
- StringRules string = 14;
54
- BytesRules bytes = 15;
55
-
56
- // Complex Field Types
57
- EnumRules enum = 16;
58
- RepeatedRules repeated = 18;
59
- MapRules map = 19;
60
-
61
- // Well-Known Field Types
62
- AnyRules any = 20;
63
- DurationRules duration = 21;
64
- TimestampRules timestamp = 22;
65
- }
66
- }
67
-
68
- // FloatRules describes the constraints applied to `float` values
69
- message FloatRules {
70
- // Const specifies that this field must be exactly the specified value
71
- optional float const = 1;
72
-
73
- // Lt specifies that this field must be less than the specified value,
74
- // exclusive
75
- optional float lt = 2;
76
-
77
- // Lte specifies that this field must be less than or equal to the
78
- // specified value, inclusive
79
- optional float lte = 3;
80
-
81
- // Gt specifies that this field must be greater than the specified value,
82
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
83
- // range is reversed.
84
- optional float gt = 4;
85
-
86
- // Gte specifies that this field must be greater than or equal to the
87
- // specified value, inclusive. If the value of Gte is larger than a
88
- // specified Lt or Lte, the range is reversed.
89
- optional float gte = 5;
90
-
91
- // In specifies that this field must be equal to one of the specified
92
- // values
93
- repeated float in = 6;
94
-
95
- // NotIn specifies that this field cannot be equal to one of the specified
96
- // values
97
- repeated float not_in = 7;
98
-
99
- // IgnoreEmpty specifies that the validation rules of this field should be
100
- // evaluated only if the field is not empty
101
- optional bool ignore_empty = 8;
102
- }
103
-
104
- // DoubleRules describes the constraints applied to `double` values
105
- message DoubleRules {
106
- // Const specifies that this field must be exactly the specified value
107
- optional double const = 1;
108
-
109
- // Lt specifies that this field must be less than the specified value,
110
- // exclusive
111
- optional double lt = 2;
112
-
113
- // Lte specifies that this field must be less than or equal to the
114
- // specified value, inclusive
115
- optional double lte = 3;
116
-
117
- // Gt specifies that this field must be greater than the specified value,
118
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
119
- // range is reversed.
120
- optional double gt = 4;
121
-
122
- // Gte specifies that this field must be greater than or equal to the
123
- // specified value, inclusive. If the value of Gte is larger than a
124
- // specified Lt or Lte, the range is reversed.
125
- optional double gte = 5;
126
-
127
- // In specifies that this field must be equal to one of the specified
128
- // values
129
- repeated double in = 6;
130
-
131
- // NotIn specifies that this field cannot be equal to one of the specified
132
- // values
133
- repeated double not_in = 7;
134
-
135
- // IgnoreEmpty specifies that the validation rules of this field should be
136
- // evaluated only if the field is not empty
137
- optional bool ignore_empty = 8;
138
- }
139
-
140
- // Int32Rules describes the constraints applied to `int32` values
141
- message Int32Rules {
142
- // Const specifies that this field must be exactly the specified value
143
- optional int32 const = 1;
144
-
145
- // Lt specifies that this field must be less than the specified value,
146
- // exclusive
147
- optional int32 lt = 2;
148
-
149
- // Lte specifies that this field must be less than or equal to the
150
- // specified value, inclusive
151
- optional int32 lte = 3;
152
-
153
- // Gt specifies that this field must be greater than the specified value,
154
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
155
- // range is reversed.
156
- optional int32 gt = 4;
157
-
158
- // Gte specifies that this field must be greater than or equal to the
159
- // specified value, inclusive. If the value of Gte is larger than a
160
- // specified Lt or Lte, the range is reversed.
161
- optional int32 gte = 5;
162
-
163
- // In specifies that this field must be equal to one of the specified
164
- // values
165
- repeated int32 in = 6;
166
-
167
- // NotIn specifies that this field cannot be equal to one of the specified
168
- // values
169
- repeated int32 not_in = 7;
170
-
171
- // IgnoreEmpty specifies that the validation rules of this field should be
172
- // evaluated only if the field is not empty
173
- optional bool ignore_empty = 8;
174
- }
175
-
176
- // Int64Rules describes the constraints applied to `int64` values
177
- message Int64Rules {
178
- // Const specifies that this field must be exactly the specified value
179
- optional int64 const = 1;
180
-
181
- // Lt specifies that this field must be less than the specified value,
182
- // exclusive
183
- optional int64 lt = 2;
184
-
185
- // Lte specifies that this field must be less than or equal to the
186
- // specified value, inclusive
187
- optional int64 lte = 3;
188
-
189
- // Gt specifies that this field must be greater than the specified value,
190
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
191
- // range is reversed.
192
- optional int64 gt = 4;
193
-
194
- // Gte specifies that this field must be greater than or equal to the
195
- // specified value, inclusive. If the value of Gte is larger than a
196
- // specified Lt or Lte, the range is reversed.
197
- optional int64 gte = 5;
198
-
199
- // In specifies that this field must be equal to one of the specified
200
- // values
201
- repeated int64 in = 6;
202
-
203
- // NotIn specifies that this field cannot be equal to one of the specified
204
- // values
205
- repeated int64 not_in = 7;
206
-
207
- // IgnoreEmpty specifies that the validation rules of this field should be
208
- // evaluated only if the field is not empty
209
- optional bool ignore_empty = 8;
210
- }
211
-
212
- // UInt32Rules describes the constraints applied to `uint32` values
213
- message UInt32Rules {
214
- // Const specifies that this field must be exactly the specified value
215
- optional uint32 const = 1;
216
-
217
- // Lt specifies that this field must be less than the specified value,
218
- // exclusive
219
- optional uint32 lt = 2;
220
-
221
- // Lte specifies that this field must be less than or equal to the
222
- // specified value, inclusive
223
- optional uint32 lte = 3;
224
-
225
- // Gt specifies that this field must be greater than the specified value,
226
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
227
- // range is reversed.
228
- optional uint32 gt = 4;
229
-
230
- // Gte specifies that this field must be greater than or equal to the
231
- // specified value, inclusive. If the value of Gte is larger than a
232
- // specified Lt or Lte, the range is reversed.
233
- optional uint32 gte = 5;
234
-
235
- // In specifies that this field must be equal to one of the specified
236
- // values
237
- repeated uint32 in = 6;
238
-
239
- // NotIn specifies that this field cannot be equal to one of the specified
240
- // values
241
- repeated uint32 not_in = 7;
242
-
243
- // IgnoreEmpty specifies that the validation rules of this field should be
244
- // evaluated only if the field is not empty
245
- optional bool ignore_empty = 8;
246
- }
247
-
248
- // UInt64Rules describes the constraints applied to `uint64` values
249
- message UInt64Rules {
250
- // Const specifies that this field must be exactly the specified value
251
- optional uint64 const = 1;
252
-
253
- // Lt specifies that this field must be less than the specified value,
254
- // exclusive
255
- optional uint64 lt = 2;
256
-
257
- // Lte specifies that this field must be less than or equal to the
258
- // specified value, inclusive
259
- optional uint64 lte = 3;
260
-
261
- // Gt specifies that this field must be greater than the specified value,
262
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
263
- // range is reversed.
264
- optional uint64 gt = 4;
265
-
266
- // Gte specifies that this field must be greater than or equal to the
267
- // specified value, inclusive. If the value of Gte is larger than a
268
- // specified Lt or Lte, the range is reversed.
269
- optional uint64 gte = 5;
270
-
271
- // In specifies that this field must be equal to one of the specified
272
- // values
273
- repeated uint64 in = 6;
274
-
275
- // NotIn specifies that this field cannot be equal to one of the specified
276
- // values
277
- repeated uint64 not_in = 7;
278
-
279
- // IgnoreEmpty specifies that the validation rules of this field should be
280
- // evaluated only if the field is not empty
281
- optional bool ignore_empty = 8;
282
- }
283
-
284
- // SInt32Rules describes the constraints applied to `sint32` values
285
- message SInt32Rules {
286
- // Const specifies that this field must be exactly the specified value
287
- optional sint32 const = 1;
288
-
289
- // Lt specifies that this field must be less than the specified value,
290
- // exclusive
291
- optional sint32 lt = 2;
292
-
293
- // Lte specifies that this field must be less than or equal to the
294
- // specified value, inclusive
295
- optional sint32 lte = 3;
296
-
297
- // Gt specifies that this field must be greater than the specified value,
298
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
299
- // range is reversed.
300
- optional sint32 gt = 4;
301
-
302
- // Gte specifies that this field must be greater than or equal to the
303
- // specified value, inclusive. If the value of Gte is larger than a
304
- // specified Lt or Lte, the range is reversed.
305
- optional sint32 gte = 5;
306
-
307
- // In specifies that this field must be equal to one of the specified
308
- // values
309
- repeated sint32 in = 6;
310
-
311
- // NotIn specifies that this field cannot be equal to one of the specified
312
- // values
313
- repeated sint32 not_in = 7;
314
-
315
- // IgnoreEmpty specifies that the validation rules of this field should be
316
- // evaluated only if the field is not empty
317
- optional bool ignore_empty = 8;
318
- }
319
-
320
- // SInt64Rules describes the constraints applied to `sint64` values
321
- message SInt64Rules {
322
- // Const specifies that this field must be exactly the specified value
323
- optional sint64 const = 1;
324
-
325
- // Lt specifies that this field must be less than the specified value,
326
- // exclusive
327
- optional sint64 lt = 2;
328
-
329
- // Lte specifies that this field must be less than or equal to the
330
- // specified value, inclusive
331
- optional sint64 lte = 3;
332
-
333
- // Gt specifies that this field must be greater than the specified value,
334
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
335
- // range is reversed.
336
- optional sint64 gt = 4;
337
-
338
- // Gte specifies that this field must be greater than or equal to the
339
- // specified value, inclusive. If the value of Gte is larger than a
340
- // specified Lt or Lte, the range is reversed.
341
- optional sint64 gte = 5;
342
-
343
- // In specifies that this field must be equal to one of the specified
344
- // values
345
- repeated sint64 in = 6;
346
-
347
- // NotIn specifies that this field cannot be equal to one of the specified
348
- // values
349
- repeated sint64 not_in = 7;
350
-
351
- // IgnoreEmpty specifies that the validation rules of this field should be
352
- // evaluated only if the field is not empty
353
- optional bool ignore_empty = 8;
354
- }
355
-
356
- // Fixed32Rules describes the constraints applied to `fixed32` values
357
- message Fixed32Rules {
358
- // Const specifies that this field must be exactly the specified value
359
- optional fixed32 const = 1;
360
-
361
- // Lt specifies that this field must be less than the specified value,
362
- // exclusive
363
- optional fixed32 lt = 2;
364
-
365
- // Lte specifies that this field must be less than or equal to the
366
- // specified value, inclusive
367
- optional fixed32 lte = 3;
368
-
369
- // Gt specifies that this field must be greater than the specified value,
370
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
371
- // range is reversed.
372
- optional fixed32 gt = 4;
373
-
374
- // Gte specifies that this field must be greater than or equal to the
375
- // specified value, inclusive. If the value of Gte is larger than a
376
- // specified Lt or Lte, the range is reversed.
377
- optional fixed32 gte = 5;
378
-
379
- // In specifies that this field must be equal to one of the specified
380
- // values
381
- repeated fixed32 in = 6;
382
-
383
- // NotIn specifies that this field cannot be equal to one of the specified
384
- // values
385
- repeated fixed32 not_in = 7;
386
-
387
- // IgnoreEmpty specifies that the validation rules of this field should be
388
- // evaluated only if the field is not empty
389
- optional bool ignore_empty = 8;
390
- }
391
-
392
- // Fixed64Rules describes the constraints applied to `fixed64` values
393
- message Fixed64Rules {
394
- // Const specifies that this field must be exactly the specified value
395
- optional fixed64 const = 1;
396
-
397
- // Lt specifies that this field must be less than the specified value,
398
- // exclusive
399
- optional fixed64 lt = 2;
400
-
401
- // Lte specifies that this field must be less than or equal to the
402
- // specified value, inclusive
403
- optional fixed64 lte = 3;
404
-
405
- // Gt specifies that this field must be greater than the specified value,
406
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
407
- // range is reversed.
408
- optional fixed64 gt = 4;
409
-
410
- // Gte specifies that this field must be greater than or equal to the
411
- // specified value, inclusive. If the value of Gte is larger than a
412
- // specified Lt or Lte, the range is reversed.
413
- optional fixed64 gte = 5;
414
-
415
- // In specifies that this field must be equal to one of the specified
416
- // values
417
- repeated fixed64 in = 6;
418
-
419
- // NotIn specifies that this field cannot be equal to one of the specified
420
- // values
421
- repeated fixed64 not_in = 7;
422
-
423
- // IgnoreEmpty specifies that the validation rules of this field should be
424
- // evaluated only if the field is not empty
425
- optional bool ignore_empty = 8;
426
- }
427
-
428
- // SFixed32Rules describes the constraints applied to `sfixed32` values
429
- message SFixed32Rules {
430
- // Const specifies that this field must be exactly the specified value
431
- optional sfixed32 const = 1;
432
-
433
- // Lt specifies that this field must be less than the specified value,
434
- // exclusive
435
- optional sfixed32 lt = 2;
436
-
437
- // Lte specifies that this field must be less than or equal to the
438
- // specified value, inclusive
439
- optional sfixed32 lte = 3;
440
-
441
- // Gt specifies that this field must be greater than the specified value,
442
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
443
- // range is reversed.
444
- optional sfixed32 gt = 4;
445
-
446
- // Gte specifies that this field must be greater than or equal to the
447
- // specified value, inclusive. If the value of Gte is larger than a
448
- // specified Lt or Lte, the range is reversed.
449
- optional sfixed32 gte = 5;
450
-
451
- // In specifies that this field must be equal to one of the specified
452
- // values
453
- repeated sfixed32 in = 6;
454
-
455
- // NotIn specifies that this field cannot be equal to one of the specified
456
- // values
457
- repeated sfixed32 not_in = 7;
458
-
459
- // IgnoreEmpty specifies that the validation rules of this field should be
460
- // evaluated only if the field is not empty
461
- optional bool ignore_empty = 8;
462
- }
463
-
464
- // SFixed64Rules describes the constraints applied to `sfixed64` values
465
- message SFixed64Rules {
466
- // Const specifies that this field must be exactly the specified value
467
- optional sfixed64 const = 1;
468
-
469
- // Lt specifies that this field must be less than the specified value,
470
- // exclusive
471
- optional sfixed64 lt = 2;
472
-
473
- // Lte specifies that this field must be less than or equal to the
474
- // specified value, inclusive
475
- optional sfixed64 lte = 3;
476
-
477
- // Gt specifies that this field must be greater than the specified value,
478
- // exclusive. If the value of Gt is larger than a specified Lt or Lte, the
479
- // range is reversed.
480
- optional sfixed64 gt = 4;
481
-
482
- // Gte specifies that this field must be greater than or equal to the
483
- // specified value, inclusive. If the value of Gte is larger than a
484
- // specified Lt or Lte, the range is reversed.
485
- optional sfixed64 gte = 5;
486
-
487
- // In specifies that this field must be equal to one of the specified
488
- // values
489
- repeated sfixed64 in = 6;
490
-
491
- // NotIn specifies that this field cannot be equal to one of the specified
492
- // values
493
- repeated sfixed64 not_in = 7;
494
-
495
- // IgnoreEmpty specifies that the validation rules of this field should be
496
- // evaluated only if the field is not empty
497
- optional bool ignore_empty = 8;
498
- }
499
-
500
- // BoolRules describes the constraints applied to `bool` values
501
- message BoolRules {
502
- // Const specifies that this field must be exactly the specified value
503
- optional bool const = 1;
504
- }
505
-
506
- // StringRules describe the constraints applied to `string` values
507
- message StringRules {
508
- // Const specifies that this field must be exactly the specified value
509
- optional string const = 1;
510
-
511
- // Len specifies that this field must be the specified number of
512
- // characters (Unicode code points). Note that the number of
513
- // characters may differ from the number of bytes in the string.
514
- optional uint64 len = 19;
515
-
516
- // MinLen specifies that this field must be the specified number of
517
- // characters (Unicode code points) at a minimum. Note that the number of
518
- // characters may differ from the number of bytes in the string.
519
- optional uint64 min_len = 2;
520
-
521
- // MaxLen specifies that this field must be the specified number of
522
- // characters (Unicode code points) at a maximum. Note that the number of
523
- // characters may differ from the number of bytes in the string.
524
- optional uint64 max_len = 3;
525
-
526
- // LenBytes specifies that this field must be the specified number of bytes
527
- optional uint64 len_bytes = 20;
528
-
529
- // MinBytes specifies that this field must be the specified number of bytes
530
- // at a minimum
531
- optional uint64 min_bytes = 4;
532
-
533
- // MaxBytes specifies that this field must be the specified number of bytes
534
- // at a maximum
535
- optional uint64 max_bytes = 5;
536
-
537
- // Pattern specifes that this field must match against the specified
538
- // regular expression (RE2 syntax). The included expression should elide
539
- // any delimiters.
540
- optional string pattern = 6;
541
-
542
- // Prefix specifies that this field must have the specified substring at
543
- // the beginning of the string.
544
- optional string prefix = 7;
545
-
546
- // Suffix specifies that this field must have the specified substring at
547
- // the end of the string.
548
- optional string suffix = 8;
549
-
550
- // Contains specifies that this field must have the specified substring
551
- // anywhere in the string.
552
- optional string contains = 9;
553
-
554
- // NotContains specifies that this field cannot have the specified substring
555
- // anywhere in the string.
556
- optional string not_contains = 23;
557
-
558
- // In specifies that this field must be equal to one of the specified
559
- // values
560
- repeated string in = 10;
561
-
562
- // NotIn specifies that this field cannot be equal to one of the specified
563
- // values
564
- repeated string not_in = 11;
565
-
566
- // WellKnown rules provide advanced constraints against common string
567
- // patterns
568
- oneof well_known {
569
- // Email specifies that the field must be a valid email address as
570
- // defined by RFC 5322
571
- bool email = 12;
572
-
573
- // Hostname specifies that the field must be a valid hostname as
574
- // defined by RFC 1034. This constraint does not support
575
- // internationalized domain names (IDNs).
576
- bool hostname = 13;
577
-
578
- // Ip specifies that the field must be a valid IP (v4 or v6) address.
579
- // Valid IPv6 addresses should not include surrounding square brackets.
580
- bool ip = 14;
581
-
582
- // Ipv4 specifies that the field must be a valid IPv4 address.
583
- bool ipv4 = 15;
584
-
585
- // Ipv6 specifies that the field must be a valid IPv6 address. Valid
586
- // IPv6 addresses should not include surrounding square brackets.
587
- bool ipv6 = 16;
588
-
589
- // Uri specifies that the field must be a valid, absolute URI as defined
590
- // by RFC 3986
591
- bool uri = 17;
592
-
593
- // UriRef specifies that the field must be a valid URI as defined by RFC
594
- // 3986 and may be relative or absolute.
595
- bool uri_ref = 18;
596
-
597
- // Address specifies that the field must be either a valid hostname as
598
- // defined by RFC 1034 (which does not support internationalized domain
599
- // names or IDNs), or it can be a valid IP (v4 or v6).
600
- bool address = 21;
601
-
602
- // Uuid specifies that the field must be a valid UUID as defined by
603
- // RFC 4122
604
- bool uuid = 22;
605
-
606
- // WellKnownRegex specifies a common well known pattern defined as a regex.
607
- KnownRegex well_known_regex = 24;
608
- }
609
-
610
- // This applies to regexes HTTP_HEADER_NAME and HTTP_HEADER_VALUE to enable
611
- // strict header validation.
612
- // By default, this is true, and HTTP header validations are RFC-compliant.
613
- // Setting to false will enable a looser validations that only disallows
614
- // \r\n\0 characters, which can be used to bypass header matching rules.
615
- optional bool strict = 25 [default = true];
616
-
617
- // IgnoreEmpty specifies that the validation rules of this field should be
618
- // evaluated only if the field is not empty
619
- optional bool ignore_empty = 26;
620
- }
621
-
622
- // WellKnownRegex contain some well-known patterns.
623
- enum KnownRegex {
624
- UNKNOWN = 0;
625
-
626
- // HTTP header name as defined by RFC 7230.
627
- HTTP_HEADER_NAME = 1;
628
-
629
- // HTTP header value as defined by RFC 7230.
630
- HTTP_HEADER_VALUE = 2;
631
- }
632
-
633
- // BytesRules describe the constraints applied to `bytes` values
634
- message BytesRules {
635
- // Const specifies that this field must be exactly the specified value
636
- optional bytes const = 1;
637
-
638
- // Len specifies that this field must be the specified number of bytes
639
- optional uint64 len = 13;
640
-
641
- // MinLen specifies that this field must be the specified number of bytes
642
- // at a minimum
643
- optional uint64 min_len = 2;
644
-
645
- // MaxLen specifies that this field must be the specified number of bytes
646
- // at a maximum
647
- optional uint64 max_len = 3;
648
-
649
- // Pattern specifes that this field must match against the specified
650
- // regular expression (RE2 syntax). The included expression should elide
651
- // any delimiters.
652
- optional string pattern = 4;
653
-
654
- // Prefix specifies that this field must have the specified bytes at the
655
- // beginning of the string.
656
- optional bytes prefix = 5;
657
-
658
- // Suffix specifies that this field must have the specified bytes at the
659
- // end of the string.
660
- optional bytes suffix = 6;
661
-
662
- // Contains specifies that this field must have the specified bytes
663
- // anywhere in the string.
664
- optional bytes contains = 7;
665
-
666
- // In specifies that this field must be equal to one of the specified
667
- // values
668
- repeated bytes in = 8;
669
-
670
- // NotIn specifies that this field cannot be equal to one of the specified
671
- // values
672
- repeated bytes not_in = 9;
673
-
674
- // WellKnown rules provide advanced constraints against common byte
675
- // patterns
676
- oneof well_known {
677
- // Ip specifies that the field must be a valid IP (v4 or v6) address in
678
- // byte format
679
- bool ip = 10;
680
-
681
- // Ipv4 specifies that the field must be a valid IPv4 address in byte
682
- // format
683
- bool ipv4 = 11;
684
-
685
- // Ipv6 specifies that the field must be a valid IPv6 address in byte
686
- // format
687
- bool ipv6 = 12;
688
- }
689
-
690
- // IgnoreEmpty specifies that the validation rules of this field should be
691
- // evaluated only if the field is not empty
692
- optional bool ignore_empty = 14;
693
- }
694
-
695
- // EnumRules describe the constraints applied to enum values
696
- message EnumRules {
697
- // Const specifies that this field must be exactly the specified value
698
- optional int32 const = 1;
699
-
700
- // DefinedOnly specifies that this field must be only one of the defined
701
- // values for this enum, failing on any undefined value.
702
- optional bool defined_only = 2;
703
-
704
- // In specifies that this field must be equal to one of the specified
705
- // values
706
- repeated int32 in = 3;
707
-
708
- // NotIn specifies that this field cannot be equal to one of the specified
709
- // values
710
- repeated int32 not_in = 4;
711
- }
712
-
713
- // MessageRules describe the constraints applied to embedded message values.
714
- // For message-type fields, validation is performed recursively.
715
- message MessageRules {
716
- // Skip specifies that the validation rules of this field should not be
717
- // evaluated
718
- optional bool skip = 1;
719
-
720
- // Required specifies that this field must be set
721
- optional bool required = 2;
722
- }
723
-
724
- // RepeatedRules describe the constraints applied to `repeated` values
725
- message RepeatedRules {
726
- // MinItems specifies that this field must have the specified number of
727
- // items at a minimum
728
- optional uint64 min_items = 1;
729
-
730
- // MaxItems specifies that this field must have the specified number of
731
- // items at a maximum
732
- optional uint64 max_items = 2;
733
-
734
- // Unique specifies that all elements in this field must be unique. This
735
- // contraint is only applicable to scalar and enum types (messages are not
736
- // supported).
737
- optional bool unique = 3;
738
-
739
- // Items specifies the contraints to be applied to each item in the field.
740
- // Repeated message fields will still execute validation against each item
741
- // unless skip is specified here.
742
- optional FieldRules items = 4;
743
-
744
- // IgnoreEmpty specifies that the validation rules of this field should be
745
- // evaluated only if the field is not empty
746
- optional bool ignore_empty = 5;
747
- }
748
-
749
- // MapRules describe the constraints applied to `map` values
750
- message MapRules {
751
- // MinPairs specifies that this field must have the specified number of
752
- // KVs at a minimum
753
- optional uint64 min_pairs = 1;
754
-
755
- // MaxPairs specifies that this field must have the specified number of
756
- // KVs at a maximum
757
- optional uint64 max_pairs = 2;
758
-
759
- // NoSparse specifies values in this field cannot be unset. This only
760
- // applies to map's with message value types.
761
- optional bool no_sparse = 3;
762
-
763
- // Keys specifies the constraints to be applied to each key in the field.
764
- optional FieldRules keys = 4;
765
-
766
- // Values specifies the constraints to be applied to the value of each key
767
- // in the field. Message values will still have their validations evaluated
768
- // unless skip is specified here.
769
- optional FieldRules values = 5;
770
-
771
- // IgnoreEmpty specifies that the validation rules of this field should be
772
- // evaluated only if the field is not empty
773
- optional bool ignore_empty = 6;
774
- }
775
-
776
- // AnyRules describe constraints applied exclusively to the
777
- // `google.protobuf.Any` well-known type
778
- message AnyRules {
779
- // Required specifies that this field must be set
780
- optional bool required = 1;
781
-
782
- // In specifies that this field's `type_url` must be equal to one of the
783
- // specified values.
784
- repeated string in = 2;
785
-
786
- // NotIn specifies that this field's `type_url` must not be equal to any of
787
- // the specified values.
788
- repeated string not_in = 3;
789
- }
790
-
791
- // DurationRules describe the constraints applied exclusively to the
792
- // `google.protobuf.Duration` well-known type
793
- message DurationRules {
794
- // Required specifies that this field must be set
795
- optional bool required = 1;
796
-
797
- // Const specifies that this field must be exactly the specified value
798
- optional google.protobuf.Duration const = 2;
799
-
800
- // Lt specifies that this field must be less than the specified value,
801
- // exclusive
802
- optional google.protobuf.Duration lt = 3;
803
-
804
- // Lt specifies that this field must be less than the specified value,
805
- // inclusive
806
- optional google.protobuf.Duration lte = 4;
807
-
808
- // Gt specifies that this field must be greater than the specified value,
809
- // exclusive
810
- optional google.protobuf.Duration gt = 5;
811
-
812
- // Gte specifies that this field must be greater than the specified value,
813
- // inclusive
814
- optional google.protobuf.Duration gte = 6;
815
-
816
- // In specifies that this field must be equal to one of the specified
817
- // values
818
- repeated google.protobuf.Duration in = 7;
819
-
820
- // NotIn specifies that this field cannot be equal to one of the specified
821
- // values
822
- repeated google.protobuf.Duration not_in = 8;
823
- }
824
-
825
- // TimestampRules describe the constraints applied exclusively to the
826
- // `google.protobuf.Timestamp` well-known type
827
- message TimestampRules {
828
- // Required specifies that this field must be set
829
- optional bool required = 1;
830
-
831
- // Const specifies that this field must be exactly the specified value
832
- optional google.protobuf.Timestamp const = 2;
833
-
834
- // Lt specifies that this field must be less than the specified value,
835
- // exclusive
836
- optional google.protobuf.Timestamp lt = 3;
837
-
838
- // Lte specifies that this field must be less than the specified value,
839
- // inclusive
840
- optional google.protobuf.Timestamp lte = 4;
841
-
842
- // Gt specifies that this field must be greater than the specified value,
843
- // exclusive
844
- optional google.protobuf.Timestamp gt = 5;
845
-
846
- // Gte specifies that this field must be greater than the specified value,
847
- // inclusive
848
- optional google.protobuf.Timestamp gte = 6;
849
-
850
- // LtNow specifies that this must be less than the current time. LtNow
851
- // can only be used with the Within rule.
852
- optional bool lt_now = 7;
853
-
854
- // GtNow specifies that this must be greater than the current time. GtNow
855
- // can only be used with the Within rule.
856
- optional bool gt_now = 8;
857
-
858
- // Within specifies that this field must be within this duration of the
859
- // current time. This constraint can be used alone or with the LtNow and
860
- // GtNow rules.
861
- optional google.protobuf.Duration within = 9;
862
- }