com.oracle.bmc.loadbalancer.requests.UpdateRoutingPolicyRequest Maven / Gradle / Ivy
/**
* Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved.
* This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
*/
package com.oracle.bmc.loadbalancer.requests;
import com.oracle.bmc.loadbalancer.model.*;
/**
* Example: Click here to see how to use UpdateRoutingPolicyRequest.
*/
@jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20170115")
public class UpdateRoutingPolicyRequest
extends com.oracle.bmc.requests.BmcRequest<
com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails> {
/** The configuration details needed to update a routing policy. */
private com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails updateRoutingPolicyDetails;
/** The configuration details needed to update a routing policy. */
public com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails
getUpdateRoutingPolicyDetails() {
return updateRoutingPolicyDetails;
}
/**
* The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
* load balancer associated with the routing policy to update.
*/
private String loadBalancerId;
/**
* The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
* load balancer associated with the routing policy to update.
*/
public String getLoadBalancerId() {
return loadBalancerId;
}
/**
* The name of the routing policy to update.
*
* Example: {@code example_routing_policy_name}
*/
private String routingPolicyName;
/**
* The name of the routing policy to update.
*
*
Example: {@code example_routing_policy_name}
*/
public String getRoutingPolicyName() {
return routingPolicyName;
}
/**
* The unique Oracle-assigned identifier for the request. If you need to contact Oracle about a
* particular request, please provide the request ID.
*/
private String opcRequestId;
/**
* The unique Oracle-assigned identifier for the request. If you need to contact Oracle about a
* particular request, please provide the request ID.
*/
public String getOpcRequestId() {
return opcRequestId;
}
/**
* For optimistic concurrency control. In the PUT or DELETE call for a resource, set the
* if-match parameter to the value of the ETag for the load balancer. This value can be obtained
* from a GET or POST response for any resource of that load balancer.
*
*
For example, the eTag returned by getListener can be specified as the ifMatch for
* updateRuleSets.
*
*
The resource is updated or deleted only if the ETag you provide matches the resource's
* current ETag value.
*
*
Example: {@code example-etag}
*/
private String ifMatch;
/**
* For optimistic concurrency control. In the PUT or DELETE call for a resource, set the
* if-match parameter to the value of the ETag for the load balancer. This value can be obtained
* from a GET or POST response for any resource of that load balancer.
*
*
For example, the eTag returned by getListener can be specified as the ifMatch for
* updateRuleSets.
*
*
The resource is updated or deleted only if the ETag you provide matches the resource's
* current ETag value.
*
*
Example: {@code example-etag}
*/
public String getIfMatch() {
return ifMatch;
}
/**
* A token that uniquely identifies a request so it can be retried in case of a timeout or
* server error without risk of executing that same action again. Retry tokens expire after 24
* hours, but can be invalidated before then due to conflicting operations (e.g., if a resource
* has been deleted and purged from the system, then a retry of the original creation request
* may be rejected).
*/
private String opcRetryToken;
/**
* A token that uniquely identifies a request so it can be retried in case of a timeout or
* server error without risk of executing that same action again. Retry tokens expire after 24
* hours, but can be invalidated before then due to conflicting operations (e.g., if a resource
* has been deleted and purged from the system, then a retry of the original creation request
* may be rejected).
*/
public String getOpcRetryToken() {
return opcRetryToken;
}
/**
* Alternative accessor for the body parameter.
*
* @return body parameter
*/
@Override
@com.oracle.bmc.InternalSdk
public com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails getBody$() {
return updateRoutingPolicyDetails;
}
public static class Builder
implements com.oracle.bmc.requests.BmcRequest.Builder<
UpdateRoutingPolicyRequest,
com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails> {
private com.oracle.bmc.http.client.RequestInterceptor invocationCallback = null;
private com.oracle.bmc.retrier.RetryConfiguration retryConfiguration = null;
/** The configuration details needed to update a routing policy. */
private com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails
updateRoutingPolicyDetails = null;
/**
* The configuration details needed to update a routing policy.
*
* @param updateRoutingPolicyDetails the value to set
* @return this builder instance
*/
public Builder updateRoutingPolicyDetails(
com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails
updateRoutingPolicyDetails) {
this.updateRoutingPolicyDetails = updateRoutingPolicyDetails;
return this;
}
/**
* The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
* load balancer associated with the routing policy to update.
*/
private String loadBalancerId = null;
/**
* The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
* load balancer associated with the routing policy to update.
*
* @param loadBalancerId the value to set
* @return this builder instance
*/
public Builder loadBalancerId(String loadBalancerId) {
this.loadBalancerId = loadBalancerId;
return this;
}
/**
* The name of the routing policy to update.
*
*
Example: {@code example_routing_policy_name}
*/
private String routingPolicyName = null;
/**
* The name of the routing policy to update.
*
*
Example: {@code example_routing_policy_name}
*
* @param routingPolicyName the value to set
* @return this builder instance
*/
public Builder routingPolicyName(String routingPolicyName) {
this.routingPolicyName = routingPolicyName;
return this;
}
/**
* The unique Oracle-assigned identifier for the request. If you need to contact Oracle
* about a particular request, please provide the request ID.
*/
private String opcRequestId = null;
/**
* The unique Oracle-assigned identifier for the request. If you need to contact Oracle
* about a particular request, please provide the request ID.
*
* @param opcRequestId the value to set
* @return this builder instance
*/
public Builder opcRequestId(String opcRequestId) {
this.opcRequestId = opcRequestId;
return this;
}
/**
* For optimistic concurrency control. In the PUT or DELETE call for a resource, set the
* if-match parameter to the value of the ETag for the load balancer. This value can be
* obtained from a GET or POST response for any resource of that load balancer.
*
*
For example, the eTag returned by getListener can be specified as the ifMatch for
* updateRuleSets.
*
*
The resource is updated or deleted only if the ETag you provide matches the resource's
* current ETag value.
*
*
Example: {@code example-etag}
*/
private String ifMatch = null;
/**
* For optimistic concurrency control. In the PUT or DELETE call for a resource, set the
* if-match parameter to the value of the ETag for the load balancer. This value can be
* obtained from a GET or POST response for any resource of that load balancer.
*
*
For example, the eTag returned by getListener can be specified as the ifMatch for
* updateRuleSets.
*
*
The resource is updated or deleted only if the ETag you provide matches the resource's
* current ETag value.
*
*
Example: {@code example-etag}
*
* @param ifMatch the value to set
* @return this builder instance
*/
public Builder ifMatch(String ifMatch) {
this.ifMatch = ifMatch;
return this;
}
/**
* A token that uniquely identifies a request so it can be retried in case of a timeout or
* server error without risk of executing that same action again. Retry tokens expire after
* 24 hours, but can be invalidated before then due to conflicting operations (e.g., if a
* resource has been deleted and purged from the system, then a retry of the original
* creation request may be rejected).
*/
private String opcRetryToken = null;
/**
* A token that uniquely identifies a request so it can be retried in case of a timeout or
* server error without risk of executing that same action again. Retry tokens expire after
* 24 hours, but can be invalidated before then due to conflicting operations (e.g., if a
* resource has been deleted and purged from the system, then a retry of the original
* creation request may be rejected).
*
* @param opcRetryToken the value to set
* @return this builder instance
*/
public Builder opcRetryToken(String opcRetryToken) {
this.opcRetryToken = opcRetryToken;
return this;
}
/**
* Set the invocation callback for the request to be built.
*
* @param invocationCallback the invocation callback to be set for the request
* @return this builder instance
*/
public Builder invocationCallback(
com.oracle.bmc.http.client.RequestInterceptor invocationCallback) {
this.invocationCallback = invocationCallback;
return this;
}
/**
* Set the retry configuration for the request to be built.
*
* @param retryConfiguration the retry configuration to be used for the request
* @return this builder instance
*/
public Builder retryConfiguration(
com.oracle.bmc.retrier.RetryConfiguration retryConfiguration) {
this.retryConfiguration = retryConfiguration;
return this;
}
/**
* Copy method to populate the builder with values from the given instance.
*
* @return this builder instance
*/
public Builder copy(UpdateRoutingPolicyRequest o) {
updateRoutingPolicyDetails(o.getUpdateRoutingPolicyDetails());
loadBalancerId(o.getLoadBalancerId());
routingPolicyName(o.getRoutingPolicyName());
opcRequestId(o.getOpcRequestId());
ifMatch(o.getIfMatch());
opcRetryToken(o.getOpcRetryToken());
invocationCallback(o.getInvocationCallback());
retryConfiguration(o.getRetryConfiguration());
return this;
}
/**
* Build the instance of UpdateRoutingPolicyRequest as configured by this builder
*
*
Note that this method takes calls to {@link
* Builder#invocationCallback(com.oracle.bmc.http.client.RequestInterceptor)} into account,
* while the method {@link Builder#buildWithoutInvocationCallback} does not.
*
*
This is the preferred method to build an instance.
*
* @return instance of UpdateRoutingPolicyRequest
*/
public UpdateRoutingPolicyRequest build() {
UpdateRoutingPolicyRequest request = buildWithoutInvocationCallback();
request.setInvocationCallback(invocationCallback);
request.setRetryConfiguration(retryConfiguration);
return request;
}
/**
* Alternative setter for the body parameter.
*
* @param body the body parameter
* @return this builder instance
*/
@com.oracle.bmc.InternalSdk
public Builder body$(com.oracle.bmc.loadbalancer.model.UpdateRoutingPolicyDetails body) {
updateRoutingPolicyDetails(body);
return this;
}
/**
* Build the instance of UpdateRoutingPolicyRequest as configured by this builder
*
*
Note that this method does not take calls to {@link
* Builder#invocationCallback(com.oracle.bmc.http.client.RequestInterceptor)} into account,
* while the method {@link Builder#build} does
*
* @return instance of UpdateRoutingPolicyRequest
*/
public UpdateRoutingPolicyRequest buildWithoutInvocationCallback() {
UpdateRoutingPolicyRequest request = new UpdateRoutingPolicyRequest();
request.updateRoutingPolicyDetails = updateRoutingPolicyDetails;
request.loadBalancerId = loadBalancerId;
request.routingPolicyName = routingPolicyName;
request.opcRequestId = opcRequestId;
request.ifMatch = ifMatch;
request.opcRetryToken = opcRetryToken;
return request;
// new UpdateRoutingPolicyRequest(updateRoutingPolicyDetails, loadBalancerId,
// routingPolicyName, opcRequestId, ifMatch, opcRetryToken);
}
}
/**
* Return an instance of {@link Builder} that allows you to modify request properties.
*
* @return instance of {@link Builder} that allows you to modify request properties.
*/
public Builder toBuilder() {
return new Builder()
.updateRoutingPolicyDetails(updateRoutingPolicyDetails)
.loadBalancerId(loadBalancerId)
.routingPolicyName(routingPolicyName)
.opcRequestId(opcRequestId)
.ifMatch(ifMatch)
.opcRetryToken(opcRetryToken);
}
/**
* Return a new builder for this request object.
*
* @return builder for the request object
*/
public static Builder builder() {
return new Builder();
}
@Override
public String toString() {
java.lang.StringBuilder sb = new java.lang.StringBuilder();
sb.append("(");
sb.append("super=").append(super.toString());
sb.append(",updateRoutingPolicyDetails=")
.append(String.valueOf(this.updateRoutingPolicyDetails));
sb.append(",loadBalancerId=").append(String.valueOf(this.loadBalancerId));
sb.append(",routingPolicyName=").append(String.valueOf(this.routingPolicyName));
sb.append(",opcRequestId=").append(String.valueOf(this.opcRequestId));
sb.append(",ifMatch=").append(String.valueOf(this.ifMatch));
sb.append(",opcRetryToken=").append(String.valueOf(this.opcRetryToken));
sb.append(")");
return sb.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof UpdateRoutingPolicyRequest)) {
return false;
}
UpdateRoutingPolicyRequest other = (UpdateRoutingPolicyRequest) o;
return super.equals(o)
&& java.util.Objects.equals(
this.updateRoutingPolicyDetails, other.updateRoutingPolicyDetails)
&& java.util.Objects.equals(this.loadBalancerId, other.loadBalancerId)
&& java.util.Objects.equals(this.routingPolicyName, other.routingPolicyName)
&& java.util.Objects.equals(this.opcRequestId, other.opcRequestId)
&& java.util.Objects.equals(this.ifMatch, other.ifMatch)
&& java.util.Objects.equals(this.opcRetryToken, other.opcRetryToken);
}
@Override
public int hashCode() {
final int PRIME = 59;
int result = super.hashCode();
result =
(result * PRIME)
+ (this.updateRoutingPolicyDetails == null
? 43
: this.updateRoutingPolicyDetails.hashCode());
result =
(result * PRIME)
+ (this.loadBalancerId == null ? 43 : this.loadBalancerId.hashCode());
result =
(result * PRIME)
+ (this.routingPolicyName == null ? 43 : this.routingPolicyName.hashCode());
result = (result * PRIME) + (this.opcRequestId == null ? 43 : this.opcRequestId.hashCode());
result = (result * PRIME) + (this.ifMatch == null ? 43 : this.ifMatch.hashCode());
result =
(result * PRIME)
+ (this.opcRetryToken == null ? 43 : this.opcRetryToken.hashCode());
return result;
}
}