Skip to content

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.

string.const example
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.

string.len example
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.

string.min_len example
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.

string.max_len example
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.

string.len_bytes example
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.

string.min_bytes example
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.

string.max_bytes example
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.

string.pattern example
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.

string.prefix example
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.

string.suffix example
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.

string.contains example
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.

string.not_contains example
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.

string.in example
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.

string.not_in example
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

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.

string.email example
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.

string.hostname example
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.

string.ip example
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.

string.ipv4 example
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.

string.ipv6 example
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.

string.uri example
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.

string.uri_ref example
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.

string.address example
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.

string.uuid example
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.

string.tuuid example
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.

string.ip_with_prefixlen example
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.

string.ipv4_with_prefixlen example
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.

string.ipv6_with_prefixlen example
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).

string.ip_prefix example
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).

string.ipv4_prefix example
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).

string.ipv6_prefix example
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.

string.well_known_regex example
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.

string.strict example
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.

string.example example
message MyString {
  string value = 1 [
    (buf.validate.field).string.example = "hello",
    (buf.validate.field).string.example = "world"
  ];
}