String rules
StringRules describes the constraints applied to string
values These
rules may also be applied to the google.protobuf.StringValue
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 MyString {
// value must equal `hello`
string value = 1 [(buf.validate.field).string.const = "hello"];
}
len
len
dictates that the field value must have the specified
number of characters (Unicode code points), which may differ from the number
of bytes in the string. If the field value does not meet the specified
length, an error message will be generated.
message MyString {
// value length must be 5 characters
string value = 1 [(buf.validate.field).string.len = 5];
}
min_len
min_len
specifies that the field value must have at least the specified
number of characters (Unicode code points), which may differ from the number
of bytes in the string. If the field value contains fewer characters, an error
message will be generated.
message MyString {
// value length must be at least 3 characters
string value = 1 [(buf.validate.field).string.min_len = 3];
}
max_len
max_len
specifies that the field value must have no more than the specified
number of characters (Unicode code points), which may differ from the
number of bytes in the string. If the field value contains more characters,
an error message will be generated.
message MyString {
// value length must be at most 10 characters
string value = 1 [(buf.validate.field).string.max_len = 10];
}
len_bytes
len_bytes
dictates that the field value must have the specified number of
bytes. If the field value does not match the specified length in bytes,
an error message will be generated.
message MyString {
// value length must be 6 bytes
string value = 1 [(buf.validate.field).string.len_bytes = 6];
}
min_bytes
min_bytes
specifies that the field value must have at least the specified
number of bytes. If the field value contains fewer bytes, an error message
will be generated.
message MyString {
// value length must be at least 4 bytes
string value = 1 [(buf.validate.field).string.min_bytes = 4];
}
max_bytes
max_bytes
specifies that the field value must have no more than the
specified number of bytes. If the field value contains more bytes, an
error message will be generated.
message MyString {
// value length must be at most 8 bytes
string value = 1 [(buf.validate.field).string.max_bytes = 8];
}
pattern
pattern
specifies that the field value must match the specified
regular expression (RE2 syntax), with the expression provided without any
delimiters. If the field value doesn't match the regular expression, an
error message will be generated.
message MyString {
// value does not match regex pattern `^[a-zA-Z]//$`
string value = 1 [(buf.validate.field).string.pattern = "^[a-zA-Z]//$"];
}
prefix
prefix
specifies that the field value must have the
specified substring at the beginning of the string. If the field value
doesn't start with the specified prefix, an error message will be
generated.
message MyString {
// value does not have prefix `pre`
string value = 1 [(buf.validate.field).string.prefix = "pre"];
}
suffix
suffix
specifies that the field value must have the
specified substring at the end of the string. If the field value doesn't
end with the specified suffix, an error message will be generated.
message MyString {
// value does not have suffix `post`
string value = 1 [(buf.validate.field).string.suffix = "post"];
}
contains
contains
specifies that the field value must have the
specified substring anywhere in the string. If the field value doesn't
contain the specified substring, an error message will be generated.
message MyString {
// value does not contain substring `inside`.
string value = 1 [(buf.validate.field).string.contains = "inside"];
}
not_contains
not_contains
specifies that the field value must not have the
specified substring anywhere in the string. If the field value contains
the specified substring, an error message will be generated.
message MyString {
// value contains substring `inside`.
string value = 1 [(buf.validate.field).string.not_contains = "inside"];
}
in
in
specifies that the field value must be equal to one of the specified
values. If the field value isn't one of the specified values, an error
message will be generated.
message MyString {
// value must be in list ["apple", "banana"]
repeated string value = 1 [(buf.validate.field).string.in = "apple", (buf.validate.field).string.in = "banana"];
}
not_in
not_in
specifies that the field value cannot be equal to any
of the specified values. If the field value is one of the specified values,
an error message will be generated.
message MyString {
// value must not be in list ["orange", "grape"]
repeated string value = 1 [(buf.validate.field).string.not_in = "orange", (buf.validate.field).string.not_in = "grape"];
}
email
specifies that the field value must be a valid email address
(addr-spec only) as defined by RFC 5322.
If the field value isn't a valid email address, an error message will be generated.
message MyString {
// value must be a valid email address
string value = 1 [(buf.validate.field).string.email = true];
}
hostname
hostname
specifies that the field value must be a valid
hostname as defined by RFC 1034. This constraint doesn't support
internationalized domain names (IDNs). If the field value isn't a
valid hostname, an error message will be generated.
message MyString {
// value must be a valid hostname
string value = 1 [(buf.validate.field).string.hostname = true];
}
ip
ip
specifies that the field value must be a valid IP
(v4 or v6) address, without surrounding square brackets for IPv6 addresses.
If the field value isn't a valid IP address, an error message will be
generated.
message MyString {
// value must be a valid IP address
string value = 1 [(buf.validate.field).string.ip = true];
}
ipv4
ipv4
specifies that the field value must be a valid IPv4
address. If the field value isn't a valid IPv4 address, an error message
will be generated.
message MyString {
// value must be a valid IPv4 address
string value = 1 [(buf.validate.field).string.ipv4 = true];
}
ipv6
ipv6
specifies that the field value must be a valid
IPv6 address, without surrounding square brackets. If the field value is
not a valid IPv6 address, an error message will be generated.
message MyString {
// value must be a valid IPv6 address
string value = 1 [(buf.validate.field).string.ipv6 = true];
}
uri
uri
specifies that the field value must be a valid,
absolute URI as defined by RFC 3986. If the field value isn't a valid,
absolute URI, an error message will be generated.
message MyString {
// value must be a valid URI
string value = 1 [(buf.validate.field).string.uri = true];
}
uri_ref
uri_ref
specifies that the field value must be a valid URI
as defined by RFC 3986 and may be either relative or absolute. If the
field value isn't a valid URI, an error message will be generated.
message MyString {
// value must be a valid URI
string value = 1 [(buf.validate.field).string.uri_ref = true];
}
address
address
specifies that the field value must be either a valid hostname
as defined by RFC 1034
(which doesn't support internationalized domain names or IDNs) or a valid
IP (v4 or v6). If the field value isn't a valid hostname or IP, an error
message will be generated.
message MyString {
// value must be a valid hostname, or ip address
string value = 1 [(buf.validate.field).string.address = true];
}
uuid
uuid
specifies that the field value must be a valid UUID as defined by
RFC 4122. If the
field value isn't a valid UUID, an error message will be generated.
message MyString {
// value must be a valid UUID
string value = 1 [(buf.validate.field).string.uuid = true];
}
tuuid
tuuid
(trimmed UUID) specifies that the field value must be a valid UUID as
defined by RFC 4122 with all dashes
omitted. If the field value isn't a valid UUID without dashes, an error message
will be generated.
message MyString {
// value must be a valid trimmed UUID
string value = 1 [(buf.validate.field).string.tuuid = true];
}
ip_with_prefixlen
ip_with_prefixlen
specifies that the field value must be a valid IP (v4 or v6)
address with prefix length. If the field value isn't a valid IP with prefix
length, an error message will be generated.
message MyString {
// value must be a valid IP with prefix length
string value = 1 [(buf.validate.field).string.ip_with_prefixlen = true];
}
ipv4_with_prefixlen
ipv4_with_prefixlen
specifies that the field value must be a valid
IPv4 address with prefix.
If the field value isn't a valid IPv4 address with prefix length,
an error message will be generated.
message MyString {
// value must be a valid IPv4 address with prefix length
string value = 1 [(buf.validate.field).string.ipv4_with_prefixlen = true];
}
ipv6_with_prefixlen
ipv6_with_prefixlen
specifies that the field value must be a valid
IPv6 address with prefix length.
If the field value is not a valid IPv6 address with prefix length,
an error message will be generated.
message MyString {
// value must be a valid IPv6 address prefix length
string value = 1 [(buf.validate.field).string.ipv6_with_prefixlen = true];
}
ip_prefix
ip_prefix
specifies that the field value must be a valid IP (v4 or v6) prefix.
If the field value isn't a valid IP prefix, an error message will be
generated. The prefix must have all zeros for the masked bits of the prefix (e.g.,
127.0.0.0/16
, not 127.0.0.1/16
).
message MyString {
// value must be a valid IP prefix
string value = 1 [(buf.validate.field).string.ip_prefix = true];
}
ipv4_prefix
ipv4_prefix
specifies that the field value must be a valid IPv4
prefix. If the field value isn't a valid IPv4 prefix, an error message
will be generated. The prefix must have all zeros for the masked bits of
the prefix (e.g., 127.0.0.0/16
, not 127.0.0.1/16
).
message MyString {
// value must be a valid IPv4 prefix
string value = 1 [(buf.validate.field).string.ipv4_prefix = true];
}
ipv6_prefix
ipv6_prefix
specifies that the field value must be a valid IPv6 prefix.
If the field value is not a valid IPv6 prefix, an error message will be
generated. The prefix must have all zeros for the masked bits of the prefix
(e.g., 2001:db8::/48
, not 2001:db8::1/48
).
message MyString {
// value must be a valid IPv6 prefix
string value = 1 [(buf.validate.field).string.ipv6_prefix = true];
}
host_and_port
host_and_port
specifies the field value must be a valid host and port
pair. The host must be a valid hostname or IP address while the port
must be in the range of 0-65535, inclusive. IPv6 addresses must be delimited
with square brackets (e.g., [::1]:1234
).
@generated from field: bool host_and_port = 32;
well_known_regex
well_known_regex
specifies a common well-known pattern
defined as a regex. If the field value doesn't match the well-known
regex, an error message will be generated.
message MyString {
// value must be a valid HTTP header value
string value = 1 [(buf.validate.field).string.well_known_regex = KNOWN_REGEX_HTTP_HEADER_VALUE];
}
strict
This applies to regexes HTTP_HEADER_NAME
and HTTP_HEADER_VALUE
to
enable strict header validation. By default, this is true, and HTTP header
validations are RFC-compliant. Setting to false will enable looser
validations that only disallow \r\n\0
characters, which can be used to
bypass header matching rules.
message MyString {
// The field `value` must have be a valid HTTP headers, but not enforced with strict rules.
string value = 1 [(buf.validate.field).string.strict = false];
}
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.