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

com.oracle.bmc.loadbalancer.requests.CreateRoutingPolicyRequest 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 CreateRoutingPolicyRequest.
 */
@jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20170115")
public class CreateRoutingPolicyRequest
        extends com.oracle.bmc.requests.BmcRequest<
                com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails> {

    /** The details of the routing policy rules to add. */
    private com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails createRoutingPolicyDetails;

    /** The details of the routing policy rules to add. */
    public com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails
            getCreateRoutingPolicyDetails() {
        return createRoutingPolicyDetails;
    }
    /**
     * The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
     * load balancer to add the routing policy rule list to.
     */
    private String loadBalancerId;

    /**
     * The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the
     * load balancer to add the routing policy rule list to.
     */
    public String getLoadBalancerId() {
        return loadBalancerId;
    }
    /**
     * 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;
    }
    /**
     * 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;
    }
    /**
     * 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; } /** * Alternative accessor for the body parameter. * * @return body parameter */ @Override @com.oracle.bmc.InternalSdk public com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails getBody$() { return createRoutingPolicyDetails; } public static class Builder implements com.oracle.bmc.requests.BmcRequest.Builder< CreateRoutingPolicyRequest, com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails> { private com.oracle.bmc.http.client.RequestInterceptor invocationCallback = null; private com.oracle.bmc.retrier.RetryConfiguration retryConfiguration = null; /** The details of the routing policy rules to add. */ private com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails createRoutingPolicyDetails = null; /** * The details of the routing policy rules to add. * * @param createRoutingPolicyDetails the value to set * @return this builder instance */ public Builder createRoutingPolicyDetails( com.oracle.bmc.loadbalancer.model.CreateRoutingPolicyDetails createRoutingPolicyDetails) { this.createRoutingPolicyDetails = createRoutingPolicyDetails; return this; } /** * The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the * load balancer to add the routing policy rule list to. */ private String loadBalancerId = null; /** * The [OCID](https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the * load balancer to add the routing policy rule list to. * * @param loadBalancerId the value to set * @return this builder instance */ public Builder loadBalancerId(String loadBalancerId) { this.loadBalancerId = loadBalancerId; 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; } /** * 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; } /** * 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; } /** * 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(CreateRoutingPolicyRequest o) { createRoutingPolicyDetails(o.getCreateRoutingPolicyDetails()); loadBalancerId(o.getLoadBalancerId()); opcRequestId(o.getOpcRequestId()); opcRetryToken(o.getOpcRetryToken()); ifMatch(o.getIfMatch()); invocationCallback(o.getInvocationCallback()); retryConfiguration(o.getRetryConfiguration()); return this; } /** * Build the instance of CreateRoutingPolicyRequest 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 CreateRoutingPolicyRequest */ public CreateRoutingPolicyRequest build() { CreateRoutingPolicyRequest 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.CreateRoutingPolicyDetails body) { createRoutingPolicyDetails(body); return this; } /** * Build the instance of CreateRoutingPolicyRequest 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 CreateRoutingPolicyRequest */ public CreateRoutingPolicyRequest buildWithoutInvocationCallback() { CreateRoutingPolicyRequest request = new CreateRoutingPolicyRequest(); request.createRoutingPolicyDetails = createRoutingPolicyDetails; request.loadBalancerId = loadBalancerId; request.opcRequestId = opcRequestId; request.opcRetryToken = opcRetryToken; request.ifMatch = ifMatch; return request; // new CreateRoutingPolicyRequest(createRoutingPolicyDetails, loadBalancerId, // opcRequestId, opcRetryToken, ifMatch); } } /** * 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() .createRoutingPolicyDetails(createRoutingPolicyDetails) .loadBalancerId(loadBalancerId) .opcRequestId(opcRequestId) .opcRetryToken(opcRetryToken) .ifMatch(ifMatch); } /** * 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(",createRoutingPolicyDetails=") .append(String.valueOf(this.createRoutingPolicyDetails)); sb.append(",loadBalancerId=").append(String.valueOf(this.loadBalancerId)); sb.append(",opcRequestId=").append(String.valueOf(this.opcRequestId)); sb.append(",opcRetryToken=").append(String.valueOf(this.opcRetryToken)); sb.append(",ifMatch=").append(String.valueOf(this.ifMatch)); sb.append(")"); return sb.toString(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof CreateRoutingPolicyRequest)) { return false; } CreateRoutingPolicyRequest other = (CreateRoutingPolicyRequest) o; return super.equals(o) && java.util.Objects.equals( this.createRoutingPolicyDetails, other.createRoutingPolicyDetails) && java.util.Objects.equals(this.loadBalancerId, other.loadBalancerId) && java.util.Objects.equals(this.opcRequestId, other.opcRequestId) && java.util.Objects.equals(this.opcRetryToken, other.opcRetryToken) && java.util.Objects.equals(this.ifMatch, other.ifMatch); } @Override public int hashCode() { final int PRIME = 59; int result = super.hashCode(); result = (result * PRIME) + (this.createRoutingPolicyDetails == null ? 43 : this.createRoutingPolicyDetails.hashCode()); result = (result * PRIME) + (this.loadBalancerId == null ? 43 : this.loadBalancerId.hashCode()); result = (result * PRIME) + (this.opcRequestId == null ? 43 : this.opcRequestId.hashCode()); result = (result * PRIME) + (this.opcRetryToken == null ? 43 : this.opcRetryToken.hashCode()); result = (result * PRIME) + (this.ifMatch == null ? 43 : this.ifMatch.hashCode()); return result; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy