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

com.oracle.bmc.streaming.model.PrivateEndpointDetails Maven / Gradle / Ivy

There is a newer version: 3.49.0
Show newest version
/**
 * 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.streaming.model;

/**
 * Optional parameters if a private stream pool is requested. 
* Note: Objects should always be created or deserialized using the {@link Builder}. This model * distinguishes fields that are {@code null} because they are unset from fields that are explicitly * set to {@code null}. This is done in the setter methods of the {@link Builder}, which maintain a * set of all explicitly set fields called {@link Builder#__explicitlySet__}. The {@link * #hashCode()} and {@link #equals(Object)} methods are implemented to take the explicitly set * fields into account. The constructor, on the other hand, does not take the explicitly set fields * into account (since the constructor cannot distinguish explicit {@code null} from unset {@code * null}). */ @jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20180418") @com.fasterxml.jackson.databind.annotation.JsonDeserialize( builder = PrivateEndpointDetails.Builder.class) @com.fasterxml.jackson.annotation.JsonFilter( com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel.EXPLICITLY_SET_FILTER_NAME) public final class PrivateEndpointDetails extends com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel { @Deprecated @java.beans.ConstructorProperties({"subnetId", "privateEndpointIp", "nsgIds"}) public PrivateEndpointDetails( String subnetId, String privateEndpointIp, java.util.List nsgIds) { super(); this.subnetId = subnetId; this.privateEndpointIp = privateEndpointIp; this.nsgIds = nsgIds; } @com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "") public static class Builder { /** * If specified, the stream pool will be private and only accessible from inside that * subnet. Producing-to and consuming-from a stream inside a private stream pool can also * only be done from inside the subnet. That value cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("subnetId") private String subnetId; /** * If specified, the stream pool will be private and only accessible from inside that * subnet. Producing-to and consuming-from a stream inside a private stream pool can also * only be done from inside the subnet. That value cannot be changed. * * @param subnetId the value to set * @return this builder */ public Builder subnetId(String subnetId) { this.subnetId = subnetId; this.__explicitlySet__.add("subnetId"); return this; } /** * The optional private IP you want to be associated with your private stream pool. That * parameter can only be specified when the subnetId parameter is set. It cannot be changed. * The private IP needs to be part of the CIDR range of the specified subnetId or the * creation will fail. If not specified a random IP inside the subnet will be chosen. After * the stream pool is created, a custom FQDN, pointing to this private IP, is created. The * FQDN is then used to access the service instead of the private IP. */ @com.fasterxml.jackson.annotation.JsonProperty("privateEndpointIp") private String privateEndpointIp; /** * The optional private IP you want to be associated with your private stream pool. That * parameter can only be specified when the subnetId parameter is set. It cannot be changed. * The private IP needs to be part of the CIDR range of the specified subnetId or the * creation will fail. If not specified a random IP inside the subnet will be chosen. After * the stream pool is created, a custom FQDN, pointing to this private IP, is created. The * FQDN is then used to access the service instead of the private IP. * * @param privateEndpointIp the value to set * @return this builder */ public Builder privateEndpointIp(String privateEndpointIp) { this.privateEndpointIp = privateEndpointIp; this.__explicitlySet__.add("privateEndpointIp"); return this; } /** * The optional list of network security groups to be used with the private endpoint of the * stream pool. That value cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("nsgIds") private java.util.List nsgIds; /** * The optional list of network security groups to be used with the private endpoint of the * stream pool. That value cannot be changed. * * @param nsgIds the value to set * @return this builder */ public Builder nsgIds(java.util.List nsgIds) { this.nsgIds = nsgIds; this.__explicitlySet__.add("nsgIds"); return this; } @com.fasterxml.jackson.annotation.JsonIgnore private final java.util.Set __explicitlySet__ = new java.util.HashSet(); public PrivateEndpointDetails build() { PrivateEndpointDetails model = new PrivateEndpointDetails(this.subnetId, this.privateEndpointIp, this.nsgIds); for (String explicitlySetProperty : this.__explicitlySet__) { model.markPropertyAsExplicitlySet(explicitlySetProperty); } return model; } @com.fasterxml.jackson.annotation.JsonIgnore public Builder copy(PrivateEndpointDetails model) { if (model.wasPropertyExplicitlySet("subnetId")) { this.subnetId(model.getSubnetId()); } if (model.wasPropertyExplicitlySet("privateEndpointIp")) { this.privateEndpointIp(model.getPrivateEndpointIp()); } if (model.wasPropertyExplicitlySet("nsgIds")) { this.nsgIds(model.getNsgIds()); } return this; } } /** Create a new builder. */ public static Builder builder() { return new Builder(); } public Builder toBuilder() { return new Builder().copy(this); } /** * If specified, the stream pool will be private and only accessible from inside that subnet. * Producing-to and consuming-from a stream inside a private stream pool can also only be done * from inside the subnet. That value cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("subnetId") private final String subnetId; /** * If specified, the stream pool will be private and only accessible from inside that subnet. * Producing-to and consuming-from a stream inside a private stream pool can also only be done * from inside the subnet. That value cannot be changed. * * @return the value */ public String getSubnetId() { return subnetId; } /** * The optional private IP you want to be associated with your private stream pool. That * parameter can only be specified when the subnetId parameter is set. It cannot be changed. The * private IP needs to be part of the CIDR range of the specified subnetId or the creation will * fail. If not specified a random IP inside the subnet will be chosen. After the stream pool is * created, a custom FQDN, pointing to this private IP, is created. The FQDN is then used to * access the service instead of the private IP. */ @com.fasterxml.jackson.annotation.JsonProperty("privateEndpointIp") private final String privateEndpointIp; /** * The optional private IP you want to be associated with your private stream pool. That * parameter can only be specified when the subnetId parameter is set. It cannot be changed. The * private IP needs to be part of the CIDR range of the specified subnetId or the creation will * fail. If not specified a random IP inside the subnet will be chosen. After the stream pool is * created, a custom FQDN, pointing to this private IP, is created. The FQDN is then used to * access the service instead of the private IP. * * @return the value */ public String getPrivateEndpointIp() { return privateEndpointIp; } /** * The optional list of network security groups to be used with the private endpoint of the * stream pool. That value cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("nsgIds") private final java.util.List nsgIds; /** * The optional list of network security groups to be used with the private endpoint of the * stream pool. That value cannot be changed. * * @return the value */ public java.util.List getNsgIds() { return nsgIds; } @Override public String toString() { return this.toString(true); } /** * Return a string representation of the object. * * @param includeByteArrayContents true to include the full contents of byte arrays * @return string representation */ public String toString(boolean includeByteArrayContents) { java.lang.StringBuilder sb = new java.lang.StringBuilder(); sb.append("PrivateEndpointDetails("); sb.append("super=").append(super.toString()); sb.append("subnetId=").append(String.valueOf(this.subnetId)); sb.append(", privateEndpointIp=").append(String.valueOf(this.privateEndpointIp)); sb.append(", nsgIds=").append(String.valueOf(this.nsgIds)); sb.append(")"); return sb.toString(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof PrivateEndpointDetails)) { return false; } PrivateEndpointDetails other = (PrivateEndpointDetails) o; return java.util.Objects.equals(this.subnetId, other.subnetId) && java.util.Objects.equals(this.privateEndpointIp, other.privateEndpointIp) && java.util.Objects.equals(this.nsgIds, other.nsgIds) && super.equals(other); } @Override public int hashCode() { final int PRIME = 59; int result = 1; result = (result * PRIME) + (this.subnetId == null ? 43 : this.subnetId.hashCode()); result = (result * PRIME) + (this.privateEndpointIp == null ? 43 : this.privateEndpointIp.hashCode()); result = (result * PRIME) + (this.nsgIds == null ? 43 : this.nsgIds.hashCode()); result = (result * PRIME) + super.hashCode(); return result; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy