- 2.65.1 (latest)
- 2.65.0
- 2.64.1
- 2.63.2
- 2.62.0
- 2.61.3
- 2.60.0
- 2.59.2
- 2.58.0
- 2.57.0
- 2.56.0
- 2.54.1
- 2.53.0
- 2.52.0
- 2.51.0
- 2.50.1
- 2.49.0
- 2.48.0
- 2.46.0
- 2.45.1
- 2.44.0
- 2.43.0
- 2.42.0
- 2.41.0
- 2.40.0
- 2.39.1
- 2.38.0
- 2.37.1
- 2.36.0
- 2.34.0
- 2.33.0
- 2.32.0
- 2.30.0
- 2.29.0
- 2.28.0
- 2.27.0
- 2.26.0
- 2.25.1
- 2.24.0
- 2.23.1
- 2.22.1
- 2.21.1
- 2.15.0
- 2.14.3
- 2.13.0
- 2.12.0
- 2.11.0
- 2.10.0
- 2.9.6
- 2.8.4
- 2.7.4
public static final class RoutingRule.Builder extends GeneratedMessage.Builder<RoutingRule.Builder> implements RoutingRuleOrBuilderSpecifies the routing information that should be sent along with the request in the form of routing header. NOTE: All service configuration rules follow the "last one wins" order.
The examples below will apply to an RPC which has the following request type:
Message Definition:
message Request {
// The name of the Table
// Values can be of the following formats:
// - projects/<project>/tables/<table>
// - projects/<project>/instances/<instance>/tables/<table>
// - region/<region>/zones/<zone>/tables/<table>
string table_name = 1;
// This value specifies routing for replication.
// It can be in the following formats:
// - profiles/<profile_id>
// - a legacy profile_id that can be any string
string app_profile_id = 2;
}
Example message:
{ table_name: projects/proj_foo/instances/instance_bar/table/table_baz, app_profile_id: profiles/prof_qux }
The routing header consists of one or multiple key-value pairs. Every key
and value must be percent-encoded, and joined together in the format of
key1=value1&key2=value2.
The examples below skip the percent-encoding for readability.
Example 1
Extracting a field from the request to put into the routing header unchanged, with the key equal to the field name.
annotation:
option (google.api.routing) = {
// Take the app_profile_id.
routing_parameters {
field: "app_profile_id"
}
};
result:
x-goog-request-params: app_profile_id=profiles/prof_qux
Example 2
Extracting a field from the request to put into the routing header unchanged, with the key different from the field name.
annotation:
option (google.api.routing) = {
// Take the app_profile_id, but name it routing_id in the header.
routing_parameters {
field: "app_profile_id"
path_template: "{routing_id=**}"
}
};
result:
x-goog-request-params: routing_id=profiles/prof_qux
Example 3
Extracting a field from the request to put into the routing header, while matching a path template syntax on the field's value.
NB: it is more useful to send nothing than to send garbage for the purpose of dynamic routing, since garbage pollutes cache. Thus the matching.
Sub-example 3a
The field matches the template.
annotation:
option (google.api.routing) = {
// Take the table_name, if it's well-formed (with project-based
// syntax).
routing_parameters {
field: "table_name"
path_template: "{table_name=projects/*/instances/*/**}"
}
};
result:
x-goog-request-params: table_name=projects/proj_foo/instances/instance_bar/table/table_baz
Sub-example 3b
The field does not match the template.
annotation:
option (google.api.routing) = {
// Take the table_name, if it's well-formed (with region-based
// syntax).
routing_parameters {
field: "table_name"
path_template: "{table_name=regions/*/zones/*/**}"
}
};
result:
<no routing header will be sent>
Sub-example 3c
Multiple alternative conflictingly named path templates are specified. The one that matches is used to construct the header.
annotation:
option (google.api.routing) = {
// Take the table_name, if it's well-formed, whether
// using the region- or projects-based syntax.
routing_parameters { field: "table_name" path_template: "{table_name=regions/*/zones/*/*}" } routing_parameters { field: "table_name" path_template: "{table_name=projects/*/instances/*/*}" } };
result:
x-goog-request-params: table_name=projects/proj_foo/instances/instance_bar/table/table_baz
Example 4
Extracting a single routing header key-value pair by matching a template syntax on (a part of) a single request field.
annotation:
option (google.api.routing) = {
// Take just the project id from the table_name field.
routing_parameters {
field: "table_name"
path_template: "{routing_id=projects/*}/**"
}
};
result:
x-goog-request-params: routing_id=projects/proj_foo
Example 5
Extracting a single routing header key-value pair by matching several conflictingly named path templates on (parts of) a single request field. The last template to match "wins" the conflict.
annotation:
option (google.api.routing) = {
// If the table_name does not have instances information,
// take just the project id for routing.
// Otherwise take project + instance.
routing_parameters { field: "table_name" path_template: "{routing_id=projects/*}/*" } routing_parameters { field: "table_name" path_template: "{routing_id=projects/*/instances/*}/*" } };
result:
x-goog-request-params: routing_id=projects/proj_foo/instances/instance_bar
Example 6
Extracting multiple routing header key-value pairs by matching several non-conflicting path templates on (parts of) a single request field.
Sub-example 6a
Make the templates strict, so that if the table_name does not
have an instance information, nothing is sent.
annotation:
option (google.api.routing) = { // The routing code needs two keys instead of one composite // but works only for the tables with the "project-instance" name // syntax.
routing_parameters { field: "table_name" path_template: "{project_id=projects/*}/instances/*/*" } routing_parameters { field: "table_name" path_template: "projects/*/{instance_id=instances/*}/*" } };
result:
x-goog-request-params: project_id=projects/proj_foo&instance_id=instances/instance_bar
Sub-example 6b
Make the templates loose, so that if the table_name does not
have an instance information, just the project id part is sent.
annotation:
option (google.api.routing) = {
// The routing code wants two keys instead of one composite
// but will work with just the project_id for tables without
// an instance in the table_name.
routing_parameters { field: "table_name" path_template: "{project_id=projects/*}/*" } routing_parameters { field: "table_name" path_template: "projects/*/{instance_id=instances/*}/*" } };
result (is the same as 6a for our example message because it has the instance information):
x-goog-request-params: project_id=projects/proj_foo&instance_id=instances/instance_bar
Example 7
Extracting multiple routing header key-value pairs by matching several path templates on multiple request fields.
NB: note that here there is no way to specify sending nothing if one of the
fields does not match its template. E.g. if the table_name is in the wrong
format, the project_id will not be sent, but the routing_id will be.
The backend routing code has to be aware of that and be prepared to not
receive a full complement of keys if it expects multiple.
annotation:
option (google.api.routing) = {
// The routing needs both project_id and routing_id
// (from the app_profile_id field) for routing.
routing_parameters { field: "table_name" path_template: "{project_id=projects/*}/*" } routing_parameters { field: "app_profile_id" path_template: "{routing_id=*}" } };
result:
x-goog-request-params: project_id=projects/proj_foo&routing_id=profiles/prof_qux
Example 8
Extracting a single routing header key-value pair by matching several conflictingly named path templates on several request fields. The last template to match "wins" the conflict.
annotation:
option (google.api.routing) = {
// The routing_id can be a project id or a region id depending on
// the table name format, but only if the app_profile_id is not set.
// If app_profile_id is set it should be used instead.
routing_parameters { field: "table_name" path_template: "{routing_id=projects/*}/*" } routing_parameters { field: "table_name" path_template: "{routing_id=regions/*}/*" } routing_parameters { field: "app_profile_id" path_template: "{routing_id=**}" } };
result:
x-goog-request-params: routing_id=profiles/prof_qux
Example 9
Bringing it all together.
annotation:
option (google.api.routing) = {
// For routing both table_location and a routing_id are needed.
//
// table_location can be either an instance id or a region+zone id.
//
// For routing_id, take the value of app_profile_id
// - If it's in the format profiles/<profile_id>, send
// just the <profile_id> part.
// - If it's any other literal, send it as is.
// If the app_profile_id is empty, and the table_name starts with
// the project_id, send that instead.
routing_parameters { field: "table_name" path_template: "projects/*/{table_location=instances/*}/tables/*" } routing_parameters { field: "table_name" path_template: "{table_location=regions/*/zones/*}/tables/*" } routing_parameters { field: "table_name" path_template: "{routing_id=projects/*}/*" } routing_parameters { field: "app_profile_id" path_template: "{routing_id=}" } routing_parameters { field: "app_profile_id" path_template: "profiles/{routing_id=}" } };
result:
x-goog-request-params: table_location=instances/instance_bar&routing_id=prof_qux
Protobuf type google.api.RoutingRule
Inheritance
java.lang.Object > AbstractMessageLite.Builder<MessageType,BuilderType> > AbstractMessage.Builder<BuilderType> > GeneratedMessage.Builder > RoutingRule.BuilderImplements
RoutingRuleOrBuilderStatic Methods
getDescriptor()
public static final Descriptors.Descriptor getDescriptor()| Returns | |
|---|---|
| Type | Description |
Descriptor |
|
Methods
addAllRoutingParameters(Iterable<? extends RoutingParameter> values)
public RoutingRule.Builder addAllRoutingParameters(Iterable<? extends RoutingParameter> values) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
values |
Iterable<? extends com.google.api.RoutingParameter> |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
addRoutingParameters(RoutingParameter value)
public RoutingRule.Builder addRoutingParameters(RoutingParameter value) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
value |
RoutingParameter |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
addRoutingParameters(RoutingParameter.Builder builderForValue)
public RoutingRule.Builder addRoutingParameters(RoutingParameter.Builder builderForValue) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
builderForValue |
RoutingParameter.Builder |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
addRoutingParameters(int index, RoutingParameter value)
public RoutingRule.Builder addRoutingParameters(int index, RoutingParameter value) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameters | |
|---|---|
| Name | Description |
index |
int |
value |
RoutingParameter |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
addRoutingParameters(int index, RoutingParameter.Builder builderForValue)
public RoutingRule.Builder addRoutingParameters(int index, RoutingParameter.Builder builderForValue) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameters | |
|---|---|
| Name | Description |
index |
int |
builderForValue |
RoutingParameter.Builder |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
addRoutingParametersBuilder()
public RoutingParameter.Builder addRoutingParametersBuilder() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
RoutingParameter.Builder |
|
addRoutingParametersBuilder(int index)
public RoutingParameter.Builder addRoutingParametersBuilder(int index) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
index |
int |
| Returns | |
|---|---|
| Type | Description |
RoutingParameter.Builder |
|
build()
public RoutingRule build()| Returns | |
|---|---|
| Type | Description |
RoutingRule |
|
buildPartial()
public RoutingRule buildPartial()| Returns | |
|---|---|
| Type | Description |
RoutingRule |
|
clear()
public RoutingRule.Builder clear()| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
clearRoutingParameters()
public RoutingRule.Builder clearRoutingParameters() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
getDefaultInstanceForType()
public RoutingRule getDefaultInstanceForType()| Returns | |
|---|---|
| Type | Description |
RoutingRule |
|
getDescriptorForType()
public Descriptors.Descriptor getDescriptorForType()| Returns | |
|---|---|
| Type | Description |
Descriptor |
|
getRoutingParameters(int index)
public RoutingParameter getRoutingParameters(int index) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
index |
int |
| Returns | |
|---|---|
| Type | Description |
RoutingParameter |
|
getRoutingParametersBuilder(int index)
public RoutingParameter.Builder getRoutingParametersBuilder(int index) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
index |
int |
| Returns | |
|---|---|
| Type | Description |
RoutingParameter.Builder |
|
getRoutingParametersBuilderList()
public List<RoutingParameter.Builder> getRoutingParametersBuilderList() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
List<Builder> |
|
getRoutingParametersCount()
public int getRoutingParametersCount() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
int |
|
getRoutingParametersList()
public List<RoutingParameter> getRoutingParametersList() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
List<RoutingParameter> |
|
getRoutingParametersOrBuilder(int index)
public RoutingParameterOrBuilder getRoutingParametersOrBuilder(int index) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
index |
int |
| Returns | |
|---|---|
| Type | Description |
RoutingParameterOrBuilder |
|
getRoutingParametersOrBuilderList()
public List<? extends RoutingParameterOrBuilder> getRoutingParametersOrBuilderList() A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Returns | |
|---|---|
| Type | Description |
List<? extends com.google.api.RoutingParameterOrBuilder> |
|
internalGetFieldAccessorTable()
protected GeneratedMessage.FieldAccessorTable internalGetFieldAccessorTable()| Returns | |
|---|---|
| Type | Description |
FieldAccessorTable |
|
isInitialized()
public final boolean isInitialized()| Returns | |
|---|---|
| Type | Description |
boolean |
|
mergeFrom(RoutingRule other)
public RoutingRule.Builder mergeFrom(RoutingRule other)| Parameter | |
|---|---|
| Name | Description |
other |
RoutingRule |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
mergeFrom(CodedInputStream input, ExtensionRegistryLite extensionRegistry)
public RoutingRule.Builder mergeFrom(CodedInputStream input, ExtensionRegistryLite extensionRegistry)| Parameters | |
|---|---|
| Name | Description |
input |
CodedInputStream |
extensionRegistry |
ExtensionRegistryLite |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
| Exceptions | |
|---|---|
| Type | Description |
IOException |
|
mergeFrom(Message other)
public RoutingRule.Builder mergeFrom(Message other)| Parameter | |
|---|---|
| Name | Description |
other |
Message |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
removeRoutingParameters(int index)
public RoutingRule.Builder removeRoutingParameters(int index) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameter | |
|---|---|
| Name | Description |
index |
int |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
setRoutingParameters(int index, RoutingParameter value)
public RoutingRule.Builder setRoutingParameters(int index, RoutingParameter value) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameters | |
|---|---|
| Name | Description |
index |
int |
value |
RoutingParameter |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|
setRoutingParameters(int index, RoutingParameter.Builder builderForValue)
public RoutingRule.Builder setRoutingParameters(int index, RoutingParameter.Builder builderForValue) A collection of Routing Parameter specifications.
NOTE: If multiple Routing Parameters describe the same key
(via the path_template field or via the field field when
path_template is not provided), "last one wins" rule
determines which Parameter gets used.
See the examples for more details.
repeated .google.api.RoutingParameter routing_parameters = 2;
| Parameters | |
|---|---|
| Name | Description |
index |
int |
builderForValue |
RoutingParameter.Builder |
| Returns | |
|---|---|
| Type | Description |
RoutingRule.Builder |
|