All Downloads are FREE. Search and download functionalities are using the official Maven repository.

shade.polaris.com.google.api.BackendRule Maven / Gradle / Ivy

/*
 * Copyright 2020 Google LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: google/api/backend.proto

package com.google.api;

/**
 *
 *
 * 
 * A backend rule provides configuration for an individual API element.
 * 
* * Protobuf type {@code google.api.BackendRule} */ public final class BackendRule extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.api.BackendRule) BackendRuleOrBuilder { private static final long serialVersionUID = 0L; // Use BackendRule.newBuilder() to construct. private BackendRule(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private BackendRule() { selector_ = ""; address_ = ""; pathTranslation_ = 0; protocol_ = ""; } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance(UnusedPrivateParameter unused) { return new BackendRule(); } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.api.BackendProto.internal_static_google_api_BackendRule_descriptor; } @SuppressWarnings({"rawtypes"}) @java.lang.Override protected com.google.protobuf.MapField internalGetMapField(int number) { switch (number) { case 10: return internalGetOverridesByRequestProtocol(); default: throw new RuntimeException("Invalid map field number: " + number); } } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.api.BackendProto.internal_static_google_api_BackendRule_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.api.BackendRule.class, com.google.api.BackendRule.Builder.class); } /** * * *
   * Path Translation specifies how to combine the backend address with the
   * request path in order to produce the appropriate forwarding URL for the
   * request.
   *
   * Path Translation is applicable only to HTTP-based backends. Backends which
   * do not accept requests over HTTP/HTTPS should leave `path_translation`
   * unspecified.
   * 
* * Protobuf enum {@code google.api.BackendRule.PathTranslation} */ public enum PathTranslation implements com.google.protobuf.ProtocolMessageEnum { /** PATH_TRANSLATION_UNSPECIFIED = 0; */ PATH_TRANSLATION_UNSPECIFIED(0), /** * * *
     * Use the backend address as-is, with no modification to the path. If the
     * URL pattern contains variables, the variable names and values will be
     * appended to the query string. If a query string parameter and a URL
     * pattern variable have the same name, this may result in duplicate keys in
     * the query string.
     *
     * # Examples
     *
     * Given the following operation config:
     *
     *     Method path:        /api/company/{cid}/user/{uid}
     *     Backend address:    https://example.cloudfunctions.net/getUser
     *
     * Requests to the following request paths will call the backend at the
     * translated path:
     *
     *     Request path: /api/company/widgetworks/user/johndoe
     *     Translated:
     *     https://example.cloudfunctions.net/getUser?cid=widgetworks&uid=johndoe
     *
     *     Request path: /api/company/widgetworks/user/johndoe?timezone=EST
     *     Translated:
     *     https://example.cloudfunctions.net/getUser?timezone=EST&cid=widgetworks&uid=johndoe
     * 
* * CONSTANT_ADDRESS = 1; */ CONSTANT_ADDRESS(1), /** * * *
     * The request path will be appended to the backend address.
     *
     * # Examples
     *
     * Given the following operation config:
     *
     *     Method path:        /api/company/{cid}/user/{uid}
     *     Backend address:    https://example.appspot.com
     *
     * Requests to the following request paths will call the backend at the
     * translated path:
     *
     *     Request path: /api/company/widgetworks/user/johndoe
     *     Translated:
     *     https://example.appspot.com/api/company/widgetworks/user/johndoe
     *
     *     Request path: /api/company/widgetworks/user/johndoe?timezone=EST
     *     Translated:
     *     https://example.appspot.com/api/company/widgetworks/user/johndoe?timezone=EST
     * 
* * APPEND_PATH_TO_ADDRESS = 2; */ APPEND_PATH_TO_ADDRESS(2), UNRECOGNIZED(-1), ; /** PATH_TRANSLATION_UNSPECIFIED = 0; */ public static final int PATH_TRANSLATION_UNSPECIFIED_VALUE = 0; /** * * *
     * Use the backend address as-is, with no modification to the path. If the
     * URL pattern contains variables, the variable names and values will be
     * appended to the query string. If a query string parameter and a URL
     * pattern variable have the same name, this may result in duplicate keys in
     * the query string.
     *
     * # Examples
     *
     * Given the following operation config:
     *
     *     Method path:        /api/company/{cid}/user/{uid}
     *     Backend address:    https://example.cloudfunctions.net/getUser
     *
     * Requests to the following request paths will call the backend at the
     * translated path:
     *
     *     Request path: /api/company/widgetworks/user/johndoe
     *     Translated:
     *     https://example.cloudfunctions.net/getUser?cid=widgetworks&uid=johndoe
     *
     *     Request path: /api/company/widgetworks/user/johndoe?timezone=EST
     *     Translated:
     *     https://example.cloudfunctions.net/getUser?timezone=EST&cid=widgetworks&uid=johndoe
     * 
* * CONSTANT_ADDRESS = 1; */ public static final int CONSTANT_ADDRESS_VALUE = 1; /** * * *
     * The request path will be appended to the backend address.
     *
     * # Examples
     *
     * Given the following operation config:
     *
     *     Method path:        /api/company/{cid}/user/{uid}
     *     Backend address:    https://example.appspot.com
     *
     * Requests to the following request paths will call the backend at the
     * translated path:
     *
     *     Request path: /api/company/widgetworks/user/johndoe
     *     Translated:
     *     https://example.appspot.com/api/company/widgetworks/user/johndoe
     *
     *     Request path: /api/company/widgetworks/user/johndoe?timezone=EST
     *     Translated:
     *     https://example.appspot.com/api/company/widgetworks/user/johndoe?timezone=EST
     * 
* * APPEND_PATH_TO_ADDRESS = 2; */ public static final int APPEND_PATH_TO_ADDRESS_VALUE = 2; public final int getNumber() { if (this == UNRECOGNIZED) { throw new java.lang.IllegalArgumentException( "Can't get the number of an unknown enum value."); } return value; } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. * @deprecated Use {@link #forNumber(int)} instead. */ @java.lang.Deprecated public static PathTranslation valueOf(int value) { return forNumber(value); } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. */ public static PathTranslation forNumber(int value) { switch (value) { case 0: return PATH_TRANSLATION_UNSPECIFIED; case 1: return CONSTANT_ADDRESS; case 2: return APPEND_PATH_TO_ADDRESS; default: return null; } } public static com.google.protobuf.Internal.EnumLiteMap internalGetValueMap() { return internalValueMap; } private static final com.google.protobuf.Internal.EnumLiteMap internalValueMap = new com.google.protobuf.Internal.EnumLiteMap() { public PathTranslation findValueByNumber(int number) { return PathTranslation.forNumber(number); } }; public final com.google.protobuf.Descriptors.EnumValueDescriptor getValueDescriptor() { if (this == UNRECOGNIZED) { throw new java.lang.IllegalStateException( "Can't get the descriptor of an unrecognized enum value."); } return getDescriptor().getValues().get(ordinal()); } public final com.google.protobuf.Descriptors.EnumDescriptor getDescriptorForType() { return getDescriptor(); } public static final com.google.protobuf.Descriptors.EnumDescriptor getDescriptor() { return com.google.api.BackendRule.getDescriptor().getEnumTypes().get(0); } private static final PathTranslation[] VALUES = values(); public static PathTranslation valueOf( com.google.protobuf.Descriptors.EnumValueDescriptor desc) { if (desc.getType() != getDescriptor()) { throw new java.lang.IllegalArgumentException("EnumValueDescriptor is not for this type."); } if (desc.getIndex() == -1) { return UNRECOGNIZED; } return VALUES[desc.getIndex()]; } private final int value; private PathTranslation(int value) { this.value = value; } // @@protoc_insertion_point(enum_scope:google.api.BackendRule.PathTranslation) } private int authenticationCase_ = 0; @SuppressWarnings("serial") private java.lang.Object authentication_; public enum AuthenticationCase implements com.google.protobuf.Internal.EnumLite, com.google.protobuf.AbstractMessage.InternalOneOfEnum { JWT_AUDIENCE(7), DISABLE_AUTH(8), AUTHENTICATION_NOT_SET(0); private final int value; private AuthenticationCase(int value) { this.value = value; } /** * @param value The number of the enum to look for. * @return The enum associated with the given number. * @deprecated Use {@link #forNumber(int)} instead. */ @java.lang.Deprecated public static AuthenticationCase valueOf(int value) { return forNumber(value); } public static AuthenticationCase forNumber(int value) { switch (value) { case 7: return JWT_AUDIENCE; case 8: return DISABLE_AUTH; case 0: return AUTHENTICATION_NOT_SET; default: return null; } } public int getNumber() { return this.value; } }; public AuthenticationCase getAuthenticationCase() { return AuthenticationCase.forNumber(authenticationCase_); } public static final int SELECTOR_FIELD_NUMBER = 1; @SuppressWarnings("serial") private volatile java.lang.Object selector_ = ""; /** * * *
   * Selects the methods to which this rule applies.
   *
   * Refer to [selector][google.api.DocumentationRule.selector] for syntax
   * details.
   * 
* * string selector = 1; * * @return The selector. */ @java.lang.Override public java.lang.String getSelector() { java.lang.Object ref = selector_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); selector_ = s; return s; } } /** * * *
   * Selects the methods to which this rule applies.
   *
   * Refer to [selector][google.api.DocumentationRule.selector] for syntax
   * details.
   * 
* * string selector = 1; * * @return The bytes for selector. */ @java.lang.Override public com.google.protobuf.ByteString getSelectorBytes() { java.lang.Object ref = selector_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); selector_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int ADDRESS_FIELD_NUMBER = 2; @SuppressWarnings("serial") private volatile java.lang.Object address_ = ""; /** * * *
   * The address of the API backend.
   *
   * The scheme is used to determine the backend protocol and security.
   * The following schemes are accepted:
   *
   *    SCHEME        PROTOCOL    SECURITY
   *    http://       HTTP        None
   *    https://      HTTP        TLS
   *    grpc://       gRPC        None
   *    grpcs://      gRPC        TLS
   *
   * It is recommended to explicitly include a scheme. Leaving out the scheme
   * may cause constrasting behaviors across platforms.
   *
   * If the port is unspecified, the default is:
   * - 80 for schemes without TLS
   * - 443 for schemes with TLS
   *
   * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
   * to specify the protocol version.
   * 
* * string address = 2; * * @return The address. */ @java.lang.Override public java.lang.String getAddress() { java.lang.Object ref = address_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); address_ = s; return s; } } /** * * *
   * The address of the API backend.
   *
   * The scheme is used to determine the backend protocol and security.
   * The following schemes are accepted:
   *
   *    SCHEME        PROTOCOL    SECURITY
   *    http://       HTTP        None
   *    https://      HTTP        TLS
   *    grpc://       gRPC        None
   *    grpcs://      gRPC        TLS
   *
   * It is recommended to explicitly include a scheme. Leaving out the scheme
   * may cause constrasting behaviors across platforms.
   *
   * If the port is unspecified, the default is:
   * - 80 for schemes without TLS
   * - 443 for schemes with TLS
   *
   * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
   * to specify the protocol version.
   * 
* * string address = 2; * * @return The bytes for address. */ @java.lang.Override public com.google.protobuf.ByteString getAddressBytes() { java.lang.Object ref = address_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); address_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int DEADLINE_FIELD_NUMBER = 3; private double deadline_ = 0D; /** * * *
   * The number of seconds to wait for a response from a request. The default
   * varies based on the request protocol and deployment environment.
   * 
* * double deadline = 3; * * @return The deadline. */ @java.lang.Override public double getDeadline() { return deadline_; } public static final int MIN_DEADLINE_FIELD_NUMBER = 4; private double minDeadline_ = 0D; /** * * *
   * Deprecated, do not use.
   * 
* * double min_deadline = 4 [deprecated = true]; * * @deprecated google.api.BackendRule.min_deadline is deprecated. See * google/api/backend.proto;l=124 * @return The minDeadline. */ @java.lang.Override @java.lang.Deprecated public double getMinDeadline() { return minDeadline_; } public static final int OPERATION_DEADLINE_FIELD_NUMBER = 5; private double operationDeadline_ = 0D; /** * * *
   * The number of seconds to wait for the completion of a long running
   * operation. The default is no deadline.
   * 
* * double operation_deadline = 5; * * @return The operationDeadline. */ @java.lang.Override public double getOperationDeadline() { return operationDeadline_; } public static final int PATH_TRANSLATION_FIELD_NUMBER = 6; private int pathTranslation_ = 0; /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @return The enum numeric value on the wire for pathTranslation. */ @java.lang.Override public int getPathTranslationValue() { return pathTranslation_; } /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @return The pathTranslation. */ @java.lang.Override public com.google.api.BackendRule.PathTranslation getPathTranslation() { com.google.api.BackendRule.PathTranslation result = com.google.api.BackendRule.PathTranslation.forNumber(pathTranslation_); return result == null ? com.google.api.BackendRule.PathTranslation.UNRECOGNIZED : result; } public static final int JWT_AUDIENCE_FIELD_NUMBER = 7; /** * * *
   * The JWT audience is used when generating a JWT ID token for the backend.
   * This ID token will be added in the HTTP "authorization" header, and sent
   * to the backend.
   * 
* * string jwt_audience = 7; * * @return Whether the jwtAudience field is set. */ public boolean hasJwtAudience() { return authenticationCase_ == 7; } /** * * *
   * The JWT audience is used when generating a JWT ID token for the backend.
   * This ID token will be added in the HTTP "authorization" header, and sent
   * to the backend.
   * 
* * string jwt_audience = 7; * * @return The jwtAudience. */ public java.lang.String getJwtAudience() { java.lang.Object ref = ""; if (authenticationCase_ == 7) { ref = authentication_; } if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (authenticationCase_ == 7) { authentication_ = s; } return s; } } /** * * *
   * The JWT audience is used when generating a JWT ID token for the backend.
   * This ID token will be added in the HTTP "authorization" header, and sent
   * to the backend.
   * 
* * string jwt_audience = 7; * * @return The bytes for jwtAudience. */ public com.google.protobuf.ByteString getJwtAudienceBytes() { java.lang.Object ref = ""; if (authenticationCase_ == 7) { ref = authentication_; } if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); if (authenticationCase_ == 7) { authentication_ = b; } return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int DISABLE_AUTH_FIELD_NUMBER = 8; /** * * *
   * When disable_auth is true, a JWT ID token won't be generated and the
   * original "Authorization" HTTP header will be preserved. If the header is
   * used to carry the original token and is expected by the backend, this
   * field must be set to true to preserve the header.
   * 
* * bool disable_auth = 8; * * @return Whether the disableAuth field is set. */ @java.lang.Override public boolean hasDisableAuth() { return authenticationCase_ == 8; } /** * * *
   * When disable_auth is true, a JWT ID token won't be generated and the
   * original "Authorization" HTTP header will be preserved. If the header is
   * used to carry the original token and is expected by the backend, this
   * field must be set to true to preserve the header.
   * 
* * bool disable_auth = 8; * * @return The disableAuth. */ @java.lang.Override public boolean getDisableAuth() { if (authenticationCase_ == 8) { return (java.lang.Boolean) authentication_; } return false; } public static final int PROTOCOL_FIELD_NUMBER = 9; @SuppressWarnings("serial") private volatile java.lang.Object protocol_ = ""; /** * * *
   * The protocol used for sending a request to the backend.
   * The supported values are "http/1.1" and "h2".
   *
   * The default value is inferred from the scheme in the
   * [address][google.api.BackendRule.address] field:
   *
   *    SCHEME        PROTOCOL
   *    http://       http/1.1
   *    https://      http/1.1
   *    grpc://       h2
   *    grpcs://      h2
   *
   * For secure HTTP backends (https://) that support HTTP/2, set this field
   * to "h2" for improved performance.
   *
   * Configuring this field to non-default values is only supported for secure
   * HTTP backends. This field will be ignored for all other backends.
   *
   * See
   * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
   * for more details on the supported values.
   * 
* * string protocol = 9; * * @return The protocol. */ @java.lang.Override public java.lang.String getProtocol() { java.lang.Object ref = protocol_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); protocol_ = s; return s; } } /** * * *
   * The protocol used for sending a request to the backend.
   * The supported values are "http/1.1" and "h2".
   *
   * The default value is inferred from the scheme in the
   * [address][google.api.BackendRule.address] field:
   *
   *    SCHEME        PROTOCOL
   *    http://       http/1.1
   *    https://      http/1.1
   *    grpc://       h2
   *    grpcs://      h2
   *
   * For secure HTTP backends (https://) that support HTTP/2, set this field
   * to "h2" for improved performance.
   *
   * Configuring this field to non-default values is only supported for secure
   * HTTP backends. This field will be ignored for all other backends.
   *
   * See
   * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
   * for more details on the supported values.
   * 
* * string protocol = 9; * * @return The bytes for protocol. */ @java.lang.Override public com.google.protobuf.ByteString getProtocolBytes() { java.lang.Object ref = protocol_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); protocol_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int OVERRIDES_BY_REQUEST_PROTOCOL_FIELD_NUMBER = 10; private static final class OverridesByRequestProtocolDefaultEntryHolder { static final com.google.protobuf.MapEntry defaultEntry = com.google.protobuf.MapEntry .newDefaultInstance( com.google.api.BackendProto .internal_static_google_api_BackendRule_OverridesByRequestProtocolEntry_descriptor, com.google.protobuf.WireFormat.FieldType.STRING, "", com.google.protobuf.WireFormat.FieldType.MESSAGE, com.google.api.BackendRule.getDefaultInstance()); } @SuppressWarnings("serial") private com.google.protobuf.MapField overridesByRequestProtocol_; private com.google.protobuf.MapField internalGetOverridesByRequestProtocol() { if (overridesByRequestProtocol_ == null) { return com.google.protobuf.MapField.emptyMapField( OverridesByRequestProtocolDefaultEntryHolder.defaultEntry); } return overridesByRequestProtocol_; } public int getOverridesByRequestProtocolCount() { return internalGetOverridesByRequestProtocol().getMap().size(); } /** * * *
   * The map between request protocol and the backend address.
   * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public boolean containsOverridesByRequestProtocol(java.lang.String key) { if (key == null) { throw new NullPointerException("map key"); } return internalGetOverridesByRequestProtocol().getMap().containsKey(key); } /** Use {@link #getOverridesByRequestProtocolMap()} instead. */ @java.lang.Override @java.lang.Deprecated public java.util.Map getOverridesByRequestProtocol() { return getOverridesByRequestProtocolMap(); } /** * * *
   * The map between request protocol and the backend address.
   * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public java.util.Map getOverridesByRequestProtocolMap() { return internalGetOverridesByRequestProtocol().getMap(); } /** * * *
   * The map between request protocol and the backend address.
   * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public /* nullable */ com.google.api.BackendRule getOverridesByRequestProtocolOrDefault( java.lang.String key, /* nullable */ com.google.api.BackendRule defaultValue) { if (key == null) { throw new NullPointerException("map key"); } java.util.Map map = internalGetOverridesByRequestProtocol().getMap(); return map.containsKey(key) ? map.get(key) : defaultValue; } /** * * *
   * The map between request protocol and the backend address.
   * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public com.google.api.BackendRule getOverridesByRequestProtocolOrThrow(java.lang.String key) { if (key == null) { throw new NullPointerException("map key"); } java.util.Map map = internalGetOverridesByRequestProtocol().getMap(); if (!map.containsKey(key)) { throw new java.lang.IllegalArgumentException(); } return map.get(key); } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(selector_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 1, selector_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(address_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 2, address_); } if (java.lang.Double.doubleToRawLongBits(deadline_) != 0) { output.writeDouble(3, deadline_); } if (java.lang.Double.doubleToRawLongBits(minDeadline_) != 0) { output.writeDouble(4, minDeadline_); } if (java.lang.Double.doubleToRawLongBits(operationDeadline_) != 0) { output.writeDouble(5, operationDeadline_); } if (pathTranslation_ != com.google.api.BackendRule.PathTranslation.PATH_TRANSLATION_UNSPECIFIED.getNumber()) { output.writeEnum(6, pathTranslation_); } if (authenticationCase_ == 7) { com.google.protobuf.GeneratedMessageV3.writeString(output, 7, authentication_); } if (authenticationCase_ == 8) { output.writeBool(8, (boolean) ((java.lang.Boolean) authentication_)); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(protocol_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 9, protocol_); } com.google.protobuf.GeneratedMessageV3.serializeStringMapTo( output, internalGetOverridesByRequestProtocol(), OverridesByRequestProtocolDefaultEntryHolder.defaultEntry, 10); getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(selector_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, selector_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(address_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, address_); } if (java.lang.Double.doubleToRawLongBits(deadline_) != 0) { size += com.google.protobuf.CodedOutputStream.computeDoubleSize(3, deadline_); } if (java.lang.Double.doubleToRawLongBits(minDeadline_) != 0) { size += com.google.protobuf.CodedOutputStream.computeDoubleSize(4, minDeadline_); } if (java.lang.Double.doubleToRawLongBits(operationDeadline_) != 0) { size += com.google.protobuf.CodedOutputStream.computeDoubleSize(5, operationDeadline_); } if (pathTranslation_ != com.google.api.BackendRule.PathTranslation.PATH_TRANSLATION_UNSPECIFIED.getNumber()) { size += com.google.protobuf.CodedOutputStream.computeEnumSize(6, pathTranslation_); } if (authenticationCase_ == 7) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(7, authentication_); } if (authenticationCase_ == 8) { size += com.google.protobuf.CodedOutputStream.computeBoolSize( 8, (boolean) ((java.lang.Boolean) authentication_)); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(protocol_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(9, protocol_); } for (java.util.Map.Entry entry : internalGetOverridesByRequestProtocol().getMap().entrySet()) { com.google.protobuf.MapEntry overridesByRequestProtocol__ = OverridesByRequestProtocolDefaultEntryHolder.defaultEntry .newBuilderForType() .setKey(entry.getKey()) .setValue(entry.getValue()) .build(); size += com.google.protobuf.CodedOutputStream.computeMessageSize( 10, overridesByRequestProtocol__); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.api.BackendRule)) { return super.equals(obj); } com.google.api.BackendRule other = (com.google.api.BackendRule) obj; if (!getSelector().equals(other.getSelector())) return false; if (!getAddress().equals(other.getAddress())) return false; if (java.lang.Double.doubleToLongBits(getDeadline()) != java.lang.Double.doubleToLongBits(other.getDeadline())) return false; if (java.lang.Double.doubleToLongBits(getMinDeadline()) != java.lang.Double.doubleToLongBits(other.getMinDeadline())) return false; if (java.lang.Double.doubleToLongBits(getOperationDeadline()) != java.lang.Double.doubleToLongBits(other.getOperationDeadline())) return false; if (pathTranslation_ != other.pathTranslation_) return false; if (!getProtocol().equals(other.getProtocol())) return false; if (!internalGetOverridesByRequestProtocol() .equals(other.internalGetOverridesByRequestProtocol())) return false; if (!getAuthenticationCase().equals(other.getAuthenticationCase())) return false; switch (authenticationCase_) { case 7: if (!getJwtAudience().equals(other.getJwtAudience())) return false; break; case 8: if (getDisableAuth() != other.getDisableAuth()) return false; break; case 0: default: } if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); hash = (37 * hash) + SELECTOR_FIELD_NUMBER; hash = (53 * hash) + getSelector().hashCode(); hash = (37 * hash) + ADDRESS_FIELD_NUMBER; hash = (53 * hash) + getAddress().hashCode(); hash = (37 * hash) + DEADLINE_FIELD_NUMBER; hash = (53 * hash) + com.google.protobuf.Internal.hashLong( java.lang.Double.doubleToLongBits(getDeadline())); hash = (37 * hash) + MIN_DEADLINE_FIELD_NUMBER; hash = (53 * hash) + com.google.protobuf.Internal.hashLong( java.lang.Double.doubleToLongBits(getMinDeadline())); hash = (37 * hash) + OPERATION_DEADLINE_FIELD_NUMBER; hash = (53 * hash) + com.google.protobuf.Internal.hashLong( java.lang.Double.doubleToLongBits(getOperationDeadline())); hash = (37 * hash) + PATH_TRANSLATION_FIELD_NUMBER; hash = (53 * hash) + pathTranslation_; hash = (37 * hash) + PROTOCOL_FIELD_NUMBER; hash = (53 * hash) + getProtocol().hashCode(); if (!internalGetOverridesByRequestProtocol().getMap().isEmpty()) { hash = (37 * hash) + OVERRIDES_BY_REQUEST_PROTOCOL_FIELD_NUMBER; hash = (53 * hash) + internalGetOverridesByRequestProtocol().hashCode(); } switch (authenticationCase_) { case 7: hash = (37 * hash) + JWT_AUDIENCE_FIELD_NUMBER; hash = (53 * hash) + getJwtAudience().hashCode(); break; case 8: hash = (37 * hash) + DISABLE_AUTH_FIELD_NUMBER; hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(getDisableAuth()); break; case 0: default: } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.api.BackendRule parseFrom(java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.api.BackendRule parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.api.BackendRule parseFrom(com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.api.BackendRule parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.api.BackendRule parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.api.BackendRule parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.api.BackendRule parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException(PARSER, input); } public static com.google.api.BackendRule parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException( PARSER, input, extensionRegistry); } public static com.google.api.BackendRule parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseDelimitedWithIOException(PARSER, input); } public static com.google.api.BackendRule parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseDelimitedWithIOException( PARSER, input, extensionRegistry); } public static com.google.api.BackendRule parseFrom(com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException(PARSER, input); } public static com.google.api.BackendRule parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException( PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.api.BackendRule prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType(com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** * * *
   * A backend rule provides configuration for an individual API element.
   * 
* * Protobuf type {@code google.api.BackendRule} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.api.BackendRule) com.google.api.BackendRuleOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.api.BackendProto.internal_static_google_api_BackendRule_descriptor; } @SuppressWarnings({"rawtypes"}) protected com.google.protobuf.MapField internalGetMapField(int number) { switch (number) { case 10: return internalGetOverridesByRequestProtocol(); default: throw new RuntimeException("Invalid map field number: " + number); } } @SuppressWarnings({"rawtypes"}) protected com.google.protobuf.MapField internalGetMutableMapField(int number) { switch (number) { case 10: return internalGetMutableOverridesByRequestProtocol(); default: throw new RuntimeException("Invalid map field number: " + number); } } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.api.BackendProto.internal_static_google_api_BackendRule_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.api.BackendRule.class, com.google.api.BackendRule.Builder.class); } // Construct using com.google.api.BackendRule.newBuilder() private Builder() {} private Builder(com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; selector_ = ""; address_ = ""; deadline_ = 0D; minDeadline_ = 0D; operationDeadline_ = 0D; pathTranslation_ = 0; protocol_ = ""; internalGetMutableOverridesByRequestProtocol().clear(); authenticationCase_ = 0; authentication_ = null; return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.api.BackendProto.internal_static_google_api_BackendRule_descriptor; } @java.lang.Override public com.google.api.BackendRule getDefaultInstanceForType() { return com.google.api.BackendRule.getDefaultInstance(); } @java.lang.Override public com.google.api.BackendRule build() { com.google.api.BackendRule result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.api.BackendRule buildPartial() { com.google.api.BackendRule result = new com.google.api.BackendRule(this); if (bitField0_ != 0) { buildPartial0(result); } buildPartialOneofs(result); onBuilt(); return result; } private void buildPartial0(com.google.api.BackendRule result) { int from_bitField0_ = bitField0_; if (((from_bitField0_ & 0x00000001) != 0)) { result.selector_ = selector_; } if (((from_bitField0_ & 0x00000002) != 0)) { result.address_ = address_; } if (((from_bitField0_ & 0x00000004) != 0)) { result.deadline_ = deadline_; } if (((from_bitField0_ & 0x00000008) != 0)) { result.minDeadline_ = minDeadline_; } if (((from_bitField0_ & 0x00000010) != 0)) { result.operationDeadline_ = operationDeadline_; } if (((from_bitField0_ & 0x00000020) != 0)) { result.pathTranslation_ = pathTranslation_; } if (((from_bitField0_ & 0x00000100) != 0)) { result.protocol_ = protocol_; } if (((from_bitField0_ & 0x00000200) != 0)) { result.overridesByRequestProtocol_ = internalGetOverridesByRequestProtocol(); result.overridesByRequestProtocol_.makeImmutable(); } } private void buildPartialOneofs(com.google.api.BackendRule result) { result.authenticationCase_ = authenticationCase_; result.authentication_ = this.authentication_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField(com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof(com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.api.BackendRule) { return mergeFrom((com.google.api.BackendRule) other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.api.BackendRule other) { if (other == com.google.api.BackendRule.getDefaultInstance()) return this; if (!other.getSelector().isEmpty()) { selector_ = other.selector_; bitField0_ |= 0x00000001; onChanged(); } if (!other.getAddress().isEmpty()) { address_ = other.address_; bitField0_ |= 0x00000002; onChanged(); } if (other.getDeadline() != 0D) { setDeadline(other.getDeadline()); } if (other.getMinDeadline() != 0D) { setMinDeadline(other.getMinDeadline()); } if (other.getOperationDeadline() != 0D) { setOperationDeadline(other.getOperationDeadline()); } if (other.pathTranslation_ != 0) { setPathTranslationValue(other.getPathTranslationValue()); } if (!other.getProtocol().isEmpty()) { protocol_ = other.protocol_; bitField0_ |= 0x00000100; onChanged(); } internalGetMutableOverridesByRequestProtocol() .mergeFrom(other.internalGetOverridesByRequestProtocol()); bitField0_ |= 0x00000200; switch (other.getAuthenticationCase()) { case JWT_AUDIENCE: { authenticationCase_ = 7; authentication_ = other.authentication_; onChanged(); break; } case DISABLE_AUTH: { setDisableAuth(other.getDisableAuth()); break; } case AUTHENTICATION_NOT_SET: { break; } } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 10: { selector_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000001; break; } // case 10 case 18: { address_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000002; break; } // case 18 case 25: { deadline_ = input.readDouble(); bitField0_ |= 0x00000004; break; } // case 25 case 33: { minDeadline_ = input.readDouble(); bitField0_ |= 0x00000008; break; } // case 33 case 41: { operationDeadline_ = input.readDouble(); bitField0_ |= 0x00000010; break; } // case 41 case 48: { pathTranslation_ = input.readEnum(); bitField0_ |= 0x00000020; break; } // case 48 case 58: { java.lang.String s = input.readStringRequireUtf8(); authenticationCase_ = 7; authentication_ = s; break; } // case 58 case 64: { authentication_ = input.readBool(); authenticationCase_ = 8; break; } // case 64 case 74: { protocol_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000100; break; } // case 74 case 82: { com.google.protobuf.MapEntry overridesByRequestProtocol__ = input.readMessage( OverridesByRequestProtocolDefaultEntryHolder.defaultEntry .getParserForType(), extensionRegistry); internalGetMutableOverridesByRequestProtocol() .getMutableMap() .put( overridesByRequestProtocol__.getKey(), overridesByRequestProtocol__.getValue()); bitField0_ |= 0x00000200; break; } // case 82 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int authenticationCase_ = 0; private java.lang.Object authentication_; public AuthenticationCase getAuthenticationCase() { return AuthenticationCase.forNumber(authenticationCase_); } public Builder clearAuthentication() { authenticationCase_ = 0; authentication_ = null; onChanged(); return this; } private int bitField0_; private java.lang.Object selector_ = ""; /** * * *
     * Selects the methods to which this rule applies.
     *
     * Refer to [selector][google.api.DocumentationRule.selector] for syntax
     * details.
     * 
* * string selector = 1; * * @return The selector. */ public java.lang.String getSelector() { java.lang.Object ref = selector_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); selector_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * Selects the methods to which this rule applies.
     *
     * Refer to [selector][google.api.DocumentationRule.selector] for syntax
     * details.
     * 
* * string selector = 1; * * @return The bytes for selector. */ public com.google.protobuf.ByteString getSelectorBytes() { java.lang.Object ref = selector_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); selector_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * Selects the methods to which this rule applies.
     *
     * Refer to [selector][google.api.DocumentationRule.selector] for syntax
     * details.
     * 
* * string selector = 1; * * @param value The selector to set. * @return This builder for chaining. */ public Builder setSelector(java.lang.String value) { if (value == null) { throw new NullPointerException(); } selector_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } /** * * *
     * Selects the methods to which this rule applies.
     *
     * Refer to [selector][google.api.DocumentationRule.selector] for syntax
     * details.
     * 
* * string selector = 1; * * @return This builder for chaining. */ public Builder clearSelector() { selector_ = getDefaultInstance().getSelector(); bitField0_ = (bitField0_ & ~0x00000001); onChanged(); return this; } /** * * *
     * Selects the methods to which this rule applies.
     *
     * Refer to [selector][google.api.DocumentationRule.selector] for syntax
     * details.
     * 
* * string selector = 1; * * @param value The bytes for selector to set. * @return This builder for chaining. */ public Builder setSelectorBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); selector_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } private java.lang.Object address_ = ""; /** * * *
     * The address of the API backend.
     *
     * The scheme is used to determine the backend protocol and security.
     * The following schemes are accepted:
     *
     *    SCHEME        PROTOCOL    SECURITY
     *    http://       HTTP        None
     *    https://      HTTP        TLS
     *    grpc://       gRPC        None
     *    grpcs://      gRPC        TLS
     *
     * It is recommended to explicitly include a scheme. Leaving out the scheme
     * may cause constrasting behaviors across platforms.
     *
     * If the port is unspecified, the default is:
     * - 80 for schemes without TLS
     * - 443 for schemes with TLS
     *
     * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
     * to specify the protocol version.
     * 
* * string address = 2; * * @return The address. */ public java.lang.String getAddress() { java.lang.Object ref = address_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); address_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * The address of the API backend.
     *
     * The scheme is used to determine the backend protocol and security.
     * The following schemes are accepted:
     *
     *    SCHEME        PROTOCOL    SECURITY
     *    http://       HTTP        None
     *    https://      HTTP        TLS
     *    grpc://       gRPC        None
     *    grpcs://      gRPC        TLS
     *
     * It is recommended to explicitly include a scheme. Leaving out the scheme
     * may cause constrasting behaviors across platforms.
     *
     * If the port is unspecified, the default is:
     * - 80 for schemes without TLS
     * - 443 for schemes with TLS
     *
     * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
     * to specify the protocol version.
     * 
* * string address = 2; * * @return The bytes for address. */ public com.google.protobuf.ByteString getAddressBytes() { java.lang.Object ref = address_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); address_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * The address of the API backend.
     *
     * The scheme is used to determine the backend protocol and security.
     * The following schemes are accepted:
     *
     *    SCHEME        PROTOCOL    SECURITY
     *    http://       HTTP        None
     *    https://      HTTP        TLS
     *    grpc://       gRPC        None
     *    grpcs://      gRPC        TLS
     *
     * It is recommended to explicitly include a scheme. Leaving out the scheme
     * may cause constrasting behaviors across platforms.
     *
     * If the port is unspecified, the default is:
     * - 80 for schemes without TLS
     * - 443 for schemes with TLS
     *
     * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
     * to specify the protocol version.
     * 
* * string address = 2; * * @param value The address to set. * @return This builder for chaining. */ public Builder setAddress(java.lang.String value) { if (value == null) { throw new NullPointerException(); } address_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** * * *
     * The address of the API backend.
     *
     * The scheme is used to determine the backend protocol and security.
     * The following schemes are accepted:
     *
     *    SCHEME        PROTOCOL    SECURITY
     *    http://       HTTP        None
     *    https://      HTTP        TLS
     *    grpc://       gRPC        None
     *    grpcs://      gRPC        TLS
     *
     * It is recommended to explicitly include a scheme. Leaving out the scheme
     * may cause constrasting behaviors across platforms.
     *
     * If the port is unspecified, the default is:
     * - 80 for schemes without TLS
     * - 443 for schemes with TLS
     *
     * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
     * to specify the protocol version.
     * 
* * string address = 2; * * @return This builder for chaining. */ public Builder clearAddress() { address_ = getDefaultInstance().getAddress(); bitField0_ = (bitField0_ & ~0x00000002); onChanged(); return this; } /** * * *
     * The address of the API backend.
     *
     * The scheme is used to determine the backend protocol and security.
     * The following schemes are accepted:
     *
     *    SCHEME        PROTOCOL    SECURITY
     *    http://       HTTP        None
     *    https://      HTTP        TLS
     *    grpc://       gRPC        None
     *    grpcs://      gRPC        TLS
     *
     * It is recommended to explicitly include a scheme. Leaving out the scheme
     * may cause constrasting behaviors across platforms.
     *
     * If the port is unspecified, the default is:
     * - 80 for schemes without TLS
     * - 443 for schemes with TLS
     *
     * For HTTP backends, use [protocol][google.api.BackendRule.protocol]
     * to specify the protocol version.
     * 
* * string address = 2; * * @param value The bytes for address to set. * @return This builder for chaining. */ public Builder setAddressBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); address_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } private double deadline_; /** * * *
     * The number of seconds to wait for a response from a request. The default
     * varies based on the request protocol and deployment environment.
     * 
* * double deadline = 3; * * @return The deadline. */ @java.lang.Override public double getDeadline() { return deadline_; } /** * * *
     * The number of seconds to wait for a response from a request. The default
     * varies based on the request protocol and deployment environment.
     * 
* * double deadline = 3; * * @param value The deadline to set. * @return This builder for chaining. */ public Builder setDeadline(double value) { deadline_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } /** * * *
     * The number of seconds to wait for a response from a request. The default
     * varies based on the request protocol and deployment environment.
     * 
* * double deadline = 3; * * @return This builder for chaining. */ public Builder clearDeadline() { bitField0_ = (bitField0_ & ~0x00000004); deadline_ = 0D; onChanged(); return this; } private double minDeadline_; /** * * *
     * Deprecated, do not use.
     * 
* * double min_deadline = 4 [deprecated = true]; * * @deprecated google.api.BackendRule.min_deadline is deprecated. See * google/api/backend.proto;l=124 * @return The minDeadline. */ @java.lang.Override @java.lang.Deprecated public double getMinDeadline() { return minDeadline_; } /** * * *
     * Deprecated, do not use.
     * 
* * double min_deadline = 4 [deprecated = true]; * * @deprecated google.api.BackendRule.min_deadline is deprecated. See * google/api/backend.proto;l=124 * @param value The minDeadline to set. * @return This builder for chaining. */ @java.lang.Deprecated public Builder setMinDeadline(double value) { minDeadline_ = value; bitField0_ |= 0x00000008; onChanged(); return this; } /** * * *
     * Deprecated, do not use.
     * 
* * double min_deadline = 4 [deprecated = true]; * * @deprecated google.api.BackendRule.min_deadline is deprecated. See * google/api/backend.proto;l=124 * @return This builder for chaining. */ @java.lang.Deprecated public Builder clearMinDeadline() { bitField0_ = (bitField0_ & ~0x00000008); minDeadline_ = 0D; onChanged(); return this; } private double operationDeadline_; /** * * *
     * The number of seconds to wait for the completion of a long running
     * operation. The default is no deadline.
     * 
* * double operation_deadline = 5; * * @return The operationDeadline. */ @java.lang.Override public double getOperationDeadline() { return operationDeadline_; } /** * * *
     * The number of seconds to wait for the completion of a long running
     * operation. The default is no deadline.
     * 
* * double operation_deadline = 5; * * @param value The operationDeadline to set. * @return This builder for chaining. */ public Builder setOperationDeadline(double value) { operationDeadline_ = value; bitField0_ |= 0x00000010; onChanged(); return this; } /** * * *
     * The number of seconds to wait for the completion of a long running
     * operation. The default is no deadline.
     * 
* * double operation_deadline = 5; * * @return This builder for chaining. */ public Builder clearOperationDeadline() { bitField0_ = (bitField0_ & ~0x00000010); operationDeadline_ = 0D; onChanged(); return this; } private int pathTranslation_ = 0; /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @return The enum numeric value on the wire for pathTranslation. */ @java.lang.Override public int getPathTranslationValue() { return pathTranslation_; } /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @param value The enum numeric value on the wire for pathTranslation to set. * @return This builder for chaining. */ public Builder setPathTranslationValue(int value) { pathTranslation_ = value; bitField0_ |= 0x00000020; onChanged(); return this; } /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @return The pathTranslation. */ @java.lang.Override public com.google.api.BackendRule.PathTranslation getPathTranslation() { com.google.api.BackendRule.PathTranslation result = com.google.api.BackendRule.PathTranslation.forNumber(pathTranslation_); return result == null ? com.google.api.BackendRule.PathTranslation.UNRECOGNIZED : result; } /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @param value The pathTranslation to set. * @return This builder for chaining. */ public Builder setPathTranslation(com.google.api.BackendRule.PathTranslation value) { if (value == null) { throw new NullPointerException(); } bitField0_ |= 0x00000020; pathTranslation_ = value.getNumber(); onChanged(); return this; } /** * .google.api.BackendRule.PathTranslation path_translation = 6; * * @return This builder for chaining. */ public Builder clearPathTranslation() { bitField0_ = (bitField0_ & ~0x00000020); pathTranslation_ = 0; onChanged(); return this; } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @return Whether the jwtAudience field is set. */ @java.lang.Override public boolean hasJwtAudience() { return authenticationCase_ == 7; } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @return The jwtAudience. */ @java.lang.Override public java.lang.String getJwtAudience() { java.lang.Object ref = ""; if (authenticationCase_ == 7) { ref = authentication_; } if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (authenticationCase_ == 7) { authentication_ = s; } return s; } else { return (java.lang.String) ref; } } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @return The bytes for jwtAudience. */ @java.lang.Override public com.google.protobuf.ByteString getJwtAudienceBytes() { java.lang.Object ref = ""; if (authenticationCase_ == 7) { ref = authentication_; } if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); if (authenticationCase_ == 7) { authentication_ = b; } return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @param value The jwtAudience to set. * @return This builder for chaining. */ public Builder setJwtAudience(java.lang.String value) { if (value == null) { throw new NullPointerException(); } authenticationCase_ = 7; authentication_ = value; onChanged(); return this; } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @return This builder for chaining. */ public Builder clearJwtAudience() { if (authenticationCase_ == 7) { authenticationCase_ = 0; authentication_ = null; onChanged(); } return this; } /** * * *
     * The JWT audience is used when generating a JWT ID token for the backend.
     * This ID token will be added in the HTTP "authorization" header, and sent
     * to the backend.
     * 
* * string jwt_audience = 7; * * @param value The bytes for jwtAudience to set. * @return This builder for chaining. */ public Builder setJwtAudienceBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); authenticationCase_ = 7; authentication_ = value; onChanged(); return this; } /** * * *
     * When disable_auth is true, a JWT ID token won't be generated and the
     * original "Authorization" HTTP header will be preserved. If the header is
     * used to carry the original token and is expected by the backend, this
     * field must be set to true to preserve the header.
     * 
* * bool disable_auth = 8; * * @return Whether the disableAuth field is set. */ public boolean hasDisableAuth() { return authenticationCase_ == 8; } /** * * *
     * When disable_auth is true, a JWT ID token won't be generated and the
     * original "Authorization" HTTP header will be preserved. If the header is
     * used to carry the original token and is expected by the backend, this
     * field must be set to true to preserve the header.
     * 
* * bool disable_auth = 8; * * @return The disableAuth. */ public boolean getDisableAuth() { if (authenticationCase_ == 8) { return (java.lang.Boolean) authentication_; } return false; } /** * * *
     * When disable_auth is true, a JWT ID token won't be generated and the
     * original "Authorization" HTTP header will be preserved. If the header is
     * used to carry the original token and is expected by the backend, this
     * field must be set to true to preserve the header.
     * 
* * bool disable_auth = 8; * * @param value The disableAuth to set. * @return This builder for chaining. */ public Builder setDisableAuth(boolean value) { authenticationCase_ = 8; authentication_ = value; onChanged(); return this; } /** * * *
     * When disable_auth is true, a JWT ID token won't be generated and the
     * original "Authorization" HTTP header will be preserved. If the header is
     * used to carry the original token and is expected by the backend, this
     * field must be set to true to preserve the header.
     * 
* * bool disable_auth = 8; * * @return This builder for chaining. */ public Builder clearDisableAuth() { if (authenticationCase_ == 8) { authenticationCase_ = 0; authentication_ = null; onChanged(); } return this; } private java.lang.Object protocol_ = ""; /** * * *
     * The protocol used for sending a request to the backend.
     * The supported values are "http/1.1" and "h2".
     *
     * The default value is inferred from the scheme in the
     * [address][google.api.BackendRule.address] field:
     *
     *    SCHEME        PROTOCOL
     *    http://       http/1.1
     *    https://      http/1.1
     *    grpc://       h2
     *    grpcs://      h2
     *
     * For secure HTTP backends (https://) that support HTTP/2, set this field
     * to "h2" for improved performance.
     *
     * Configuring this field to non-default values is only supported for secure
     * HTTP backends. This field will be ignored for all other backends.
     *
     * See
     * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
     * for more details on the supported values.
     * 
* * string protocol = 9; * * @return The protocol. */ public java.lang.String getProtocol() { java.lang.Object ref = protocol_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); protocol_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * The protocol used for sending a request to the backend.
     * The supported values are "http/1.1" and "h2".
     *
     * The default value is inferred from the scheme in the
     * [address][google.api.BackendRule.address] field:
     *
     *    SCHEME        PROTOCOL
     *    http://       http/1.1
     *    https://      http/1.1
     *    grpc://       h2
     *    grpcs://      h2
     *
     * For secure HTTP backends (https://) that support HTTP/2, set this field
     * to "h2" for improved performance.
     *
     * Configuring this field to non-default values is only supported for secure
     * HTTP backends. This field will be ignored for all other backends.
     *
     * See
     * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
     * for more details on the supported values.
     * 
* * string protocol = 9; * * @return The bytes for protocol. */ public com.google.protobuf.ByteString getProtocolBytes() { java.lang.Object ref = protocol_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); protocol_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * The protocol used for sending a request to the backend.
     * The supported values are "http/1.1" and "h2".
     *
     * The default value is inferred from the scheme in the
     * [address][google.api.BackendRule.address] field:
     *
     *    SCHEME        PROTOCOL
     *    http://       http/1.1
     *    https://      http/1.1
     *    grpc://       h2
     *    grpcs://      h2
     *
     * For secure HTTP backends (https://) that support HTTP/2, set this field
     * to "h2" for improved performance.
     *
     * Configuring this field to non-default values is only supported for secure
     * HTTP backends. This field will be ignored for all other backends.
     *
     * See
     * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
     * for more details on the supported values.
     * 
* * string protocol = 9; * * @param value The protocol to set. * @return This builder for chaining. */ public Builder setProtocol(java.lang.String value) { if (value == null) { throw new NullPointerException(); } protocol_ = value; bitField0_ |= 0x00000100; onChanged(); return this; } /** * * *
     * The protocol used for sending a request to the backend.
     * The supported values are "http/1.1" and "h2".
     *
     * The default value is inferred from the scheme in the
     * [address][google.api.BackendRule.address] field:
     *
     *    SCHEME        PROTOCOL
     *    http://       http/1.1
     *    https://      http/1.1
     *    grpc://       h2
     *    grpcs://      h2
     *
     * For secure HTTP backends (https://) that support HTTP/2, set this field
     * to "h2" for improved performance.
     *
     * Configuring this field to non-default values is only supported for secure
     * HTTP backends. This field will be ignored for all other backends.
     *
     * See
     * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
     * for more details on the supported values.
     * 
* * string protocol = 9; * * @return This builder for chaining. */ public Builder clearProtocol() { protocol_ = getDefaultInstance().getProtocol(); bitField0_ = (bitField0_ & ~0x00000100); onChanged(); return this; } /** * * *
     * The protocol used for sending a request to the backend.
     * The supported values are "http/1.1" and "h2".
     *
     * The default value is inferred from the scheme in the
     * [address][google.api.BackendRule.address] field:
     *
     *    SCHEME        PROTOCOL
     *    http://       http/1.1
     *    https://      http/1.1
     *    grpc://       h2
     *    grpcs://      h2
     *
     * For secure HTTP backends (https://) that support HTTP/2, set this field
     * to "h2" for improved performance.
     *
     * Configuring this field to non-default values is only supported for secure
     * HTTP backends. This field will be ignored for all other backends.
     *
     * See
     * https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids
     * for more details on the supported values.
     * 
* * string protocol = 9; * * @param value The bytes for protocol to set. * @return This builder for chaining. */ public Builder setProtocolBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); protocol_ = value; bitField0_ |= 0x00000100; onChanged(); return this; } private com.google.protobuf.MapField overridesByRequestProtocol_; private com.google.protobuf.MapField internalGetOverridesByRequestProtocol() { if (overridesByRequestProtocol_ == null) { return com.google.protobuf.MapField.emptyMapField( OverridesByRequestProtocolDefaultEntryHolder.defaultEntry); } return overridesByRequestProtocol_; } private com.google.protobuf.MapField internalGetMutableOverridesByRequestProtocol() { if (overridesByRequestProtocol_ == null) { overridesByRequestProtocol_ = com.google.protobuf.MapField.newMapField( OverridesByRequestProtocolDefaultEntryHolder.defaultEntry); } if (!overridesByRequestProtocol_.isMutable()) { overridesByRequestProtocol_ = overridesByRequestProtocol_.copy(); } bitField0_ |= 0x00000200; onChanged(); return overridesByRequestProtocol_; } public int getOverridesByRequestProtocolCount() { return internalGetOverridesByRequestProtocol().getMap().size(); } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public boolean containsOverridesByRequestProtocol(java.lang.String key) { if (key == null) { throw new NullPointerException("map key"); } return internalGetOverridesByRequestProtocol().getMap().containsKey(key); } /** Use {@link #getOverridesByRequestProtocolMap()} instead. */ @java.lang.Override @java.lang.Deprecated public java.util.Map getOverridesByRequestProtocol() { return getOverridesByRequestProtocolMap(); } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public java.util.Map getOverridesByRequestProtocolMap() { return internalGetOverridesByRequestProtocol().getMap(); } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public /* nullable */ com.google.api.BackendRule getOverridesByRequestProtocolOrDefault( java.lang.String key, /* nullable */ com.google.api.BackendRule defaultValue) { if (key == null) { throw new NullPointerException("map key"); } java.util.Map map = internalGetOverridesByRequestProtocol().getMap(); return map.containsKey(key) ? map.get(key) : defaultValue; } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ @java.lang.Override public com.google.api.BackendRule getOverridesByRequestProtocolOrThrow(java.lang.String key) { if (key == null) { throw new NullPointerException("map key"); } java.util.Map map = internalGetOverridesByRequestProtocol().getMap(); if (!map.containsKey(key)) { throw new java.lang.IllegalArgumentException(); } return map.get(key); } public Builder clearOverridesByRequestProtocol() { bitField0_ = (bitField0_ & ~0x00000200); internalGetMutableOverridesByRequestProtocol().getMutableMap().clear(); return this; } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ public Builder removeOverridesByRequestProtocol(java.lang.String key) { if (key == null) { throw new NullPointerException("map key"); } internalGetMutableOverridesByRequestProtocol().getMutableMap().remove(key); return this; } /** Use alternate mutation accessors instead. */ @java.lang.Deprecated public java.util.Map getMutableOverridesByRequestProtocol() { bitField0_ |= 0x00000200; return internalGetMutableOverridesByRequestProtocol().getMutableMap(); } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ public Builder putOverridesByRequestProtocol( java.lang.String key, com.google.api.BackendRule value) { if (key == null) { throw new NullPointerException("map key"); } if (value == null) { throw new NullPointerException("map value"); } internalGetMutableOverridesByRequestProtocol().getMutableMap().put(key, value); bitField0_ |= 0x00000200; return this; } /** * * *
     * The map between request protocol and the backend address.
     * 
* * map<string, .google.api.BackendRule> overrides_by_request_protocol = 10; */ public Builder putAllOverridesByRequestProtocol( java.util.Map values) { internalGetMutableOverridesByRequestProtocol().getMutableMap().putAll(values); bitField0_ |= 0x00000200; return this; } @java.lang.Override public final Builder setUnknownFields(final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.api.BackendRule) } // @@protoc_insertion_point(class_scope:google.api.BackendRule) private static final com.google.api.BackendRule DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.api.BackendRule(); } public static com.google.api.BackendRule getDefaultInstance() { return DEFAULT_INSTANCE; } private static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public BackendRule parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.api.BackendRule getDefaultInstanceForType() { return DEFAULT_INSTANCE; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy