Double rules
DoubleRules describes the constraints applied to double
values. These
rules may also be applied to the google.protobuf.DoubleValue
Well-Known-Type.
const
const
requires the field value to exactly match the specified value. If
the field value doesn't match, an error message is generated.
message MyDouble {
// value must equal 42.0
double value = 1 [(buf.validate.field).double.const = 42.0];
}
lt
lt
requires the field value to be less than the specified value (field <
value). If the field value is equal to or greater than the specified
value, an error message is generated.
message MyDouble {
// value must be less than 10.0
double value = 1 [(buf.validate.field).double.lt = 10.0];
}
lte
lte
requires the field value to be less than or equal to the specified value
(field <= value). If the field value is greater than the specified value,
an error message is generated.
message MyDouble {
// value must be less than or equal to 10.0
double value = 1 [(buf.validate.field).double.lte = 10.0];
}
gt
gt
requires the field value to be greater than the specified value
(exclusive). If the value of gt
is larger than a specified lt
or lte
,
the range is reversed, and the field value must be outside the specified
range. If the field value doesn't meet the required conditions, an error
message is generated.
message MyDouble {
// value must be greater than 5.0 [double.gt]
double value = 1 [(buf.validate.field).double.gt = 5.0];
// value must be greater than 5 and less than 10.0 [double.gt_lt]
double other_value = 2 [(buf.validate.field).double = { gt: 5.0, lt: 10.0 }];
// value must be greater than 10 or less than 5.0 [double.gt_lt_exclusive]
double another_value = 3 [(buf.validate.field).double = { gt: 10.0, lt: 5.0 }];
}
gte
gte
requires the field value to be greater than or equal to the specified
value (exclusive). If the value of gte
is larger than a specified lt
or
lte
, the range is reversed, and the field value must be outside the
specified range. If the field value doesn't meet the required conditions,
an error message is generated.
message MyDouble {
// value must be greater than or equal to 5.0 [double.gte]
double value = 1 [(buf.validate.field).double.gte = 5.0];
// value must be greater than or equal to 5.0 and less than 10.0 [double.gte_lt]
double other_value = 2 [(buf.validate.field).double = { gte: 5.0, lt: 10.0 }];
// value must be greater than or equal to 10.0 or less than 5.0 [double.gte_lt_exclusive]
double another_value = 3 [(buf.validate.field).double = { gte: 10.0, lt: 5.0 }];
}
in
in
requires the field value to be equal to one of the specified values.
If the field value isn't one of the specified values, an error message is
generated.
message MyDouble {
// value must be in list [1.0, 2.0, 3.0]
repeated double value = 1 (buf.validate.field).double = { in: [1.0, 2.0, 3.0] };
}
not_in
not_in
requires the field value to not be equal to any of the specified
values. If the field value is one of the specified values, an error
message is generated.
message MyDouble {
// value must not be in list [1.0, 2.0, 3.0]
repeated double value = 1 (buf.validate.field).double = { not_in: [1.0, 2.0, 3.0] };
}
finite
finite
requires the field value to be finite. If the field value is
infinite or NaN, an error message is generated.
@generated from field: optional bool finite = 8;
example
example
specifies values that the field may have. These values SHOULD
conform to other constraints. example
values will not impact validation
but may be used as helpful guidance on how to populate the given field.