/* * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file 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. */ package com.amazonaws.services.eks.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* An object representing an Amazon EKS cluster VPC configuration response. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class VpcConfigResponse implements Serializable, Cloneable, StructuredPojo { /** ** The subnets associated with your cluster. *
*/ private java.util.List* The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. *
*/ private java.util.List* The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this security * group for control-plane-to-data-plane communication. *
*/ private String clusterSecurityGroupId; /** ** The VPC associated with your cluster. *
*/ private String vpcId; /** ** This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS public * API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests that originate * from within the cluster VPC. *
*/ private Boolean endpointPublicAccess; /** *
     * This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If the Amazon EKS private
     * API server endpoint is enabled, Kubernetes API requests that originate from within your cluster's VPC use the
     * private VPC endpoint instead of traversing the internet. If this value is disabled and you have nodes or Fargate
     * pods in the cluster, then ensure that publicAccessCidrs includes the necessary CIDR blocks for
     * communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
     * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. Communication to
     * the endpoint from addresses outside of the listed CIDR blocks is denied. The default value is
     * 0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate pods in the
     * cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
* The subnets associated with your cluster. *
* * @return The subnets associated with your cluster. */ public java.util.List* The subnets associated with your cluster. *
* * @param subnetIds * The subnets associated with your cluster. */ public void setSubnetIds(java.util.Collection* The subnets associated with your cluster. *
** NOTE: This method appends the values to the existing list (if any). Use * {@link #setSubnetIds(java.util.Collection)} or {@link #withSubnetIds(java.util.Collection)} if you want to * override the existing values. *
* * @param subnetIds * The subnets associated with your cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withSubnetIds(String... subnetIds) { if (this.subnetIds == null) { setSubnetIds(new java.util.ArrayList* The subnets associated with your cluster. *
* * @param subnetIds * The subnets associated with your cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withSubnetIds(java.util.Collection* The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. *
* * @return The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. */ public java.util.List* The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. *
* * @param securityGroupIds * The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. */ public void setSecurityGroupIds(java.util.Collection* The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. *
** NOTE: This method appends the values to the existing list (if any). Use * {@link #setSecurityGroupIds(java.util.Collection)} or {@link #withSecurityGroupIds(java.util.Collection)} if you * want to override the existing values. *
* * @param securityGroupIds * The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withSecurityGroupIds(String... securityGroupIds) { if (this.securityGroupIds == null) { setSecurityGroupIds(new java.util.ArrayList* The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. *
* * @param securityGroupIds * The security groups associated with the cross-account elastic network interfaces that are used to allow * communication between your nodes and the Kubernetes control plane. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withSecurityGroupIds(java.util.Collection* The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this security * group for control-plane-to-data-plane communication. *
* * @param clusterSecurityGroupId * The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this * security group for control-plane-to-data-plane communication. */ public void setClusterSecurityGroupId(String clusterSecurityGroupId) { this.clusterSecurityGroupId = clusterSecurityGroupId; } /** ** The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this security * group for control-plane-to-data-plane communication. *
* * @return The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this * security group for control-plane-to-data-plane communication. */ public String getClusterSecurityGroupId() { return this.clusterSecurityGroupId; } /** ** The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this security * group for control-plane-to-data-plane communication. *
* * @param clusterSecurityGroupId * The cluster security group that was created by Amazon EKS for the cluster. Managed node groups use this * security group for control-plane-to-data-plane communication. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withClusterSecurityGroupId(String clusterSecurityGroupId) { setClusterSecurityGroupId(clusterSecurityGroupId); return this; } /** ** The VPC associated with your cluster. *
* * @param vpcId * The VPC associated with your cluster. */ public void setVpcId(String vpcId) { this.vpcId = vpcId; } /** ** The VPC associated with your cluster. *
* * @return The VPC associated with your cluster. */ public String getVpcId() { return this.vpcId; } /** ** The VPC associated with your cluster. *
* * @param vpcId * The VPC associated with your cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withVpcId(String vpcId) { setVpcId(vpcId); return this; } /** ** This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS public * API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests that originate * from within the cluster VPC. *
* * @param endpointPublicAccess * This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS * public API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests * that originate from within the cluster VPC. */ public void setEndpointPublicAccess(Boolean endpointPublicAccess) { this.endpointPublicAccess = endpointPublicAccess; } /** ** This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS public * API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests that originate * from within the cluster VPC. *
* * @return This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS * public API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests * that originate from within the cluster VPC. */ public Boolean getEndpointPublicAccess() { return this.endpointPublicAccess; } /** ** This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS public * API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests that originate * from within the cluster VPC. *
* * @param endpointPublicAccess * This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS * public API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests * that originate from within the cluster VPC. * @return Returns a reference to this object so that method calls can be chained together. */ public VpcConfigResponse withEndpointPublicAccess(Boolean endpointPublicAccess) { setEndpointPublicAccess(endpointPublicAccess); return this; } /** ** This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS public * API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests that originate * from within the cluster VPC. *
* * @return This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If the Amazon EKS * public API server endpoint is disabled, your cluster's Kubernetes API server can only receive requests * that originate from within the cluster VPC. */ public Boolean isEndpointPublicAccess() { return this.endpointPublicAccess; } /** *
     * This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If the Amazon EKS private
     * API server endpoint is enabled, Kubernetes API requests that originate from within your cluster's VPC use the
     * private VPC endpoint instead of traversing the internet. If this value is disabled and you have nodes or Fargate
     * pods in the cluster, then ensure that publicAccessCidrs includes the necessary CIDR blocks for
     * communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
publicAccessCidrs includes the
     *        necessary CIDR blocks for communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint
     *        access control in the  Amazon EKS User Guide .
     */
    public void setEndpointPrivateAccess(Boolean endpointPrivateAccess) {
        this.endpointPrivateAccess = endpointPrivateAccess;
    }
    /**
     * 
     * This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If the Amazon EKS private
     * API server endpoint is enabled, Kubernetes API requests that originate from within your cluster's VPC use the
     * private VPC endpoint instead of traversing the internet. If this value is disabled and you have nodes or Fargate
     * pods in the cluster, then ensure that publicAccessCidrs includes the necessary CIDR blocks for
     * communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
publicAccessCidrs includes the
     *         necessary CIDR blocks for communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint
     *         access control in the  Amazon EKS User Guide .
     */
    public Boolean getEndpointPrivateAccess() {
        return this.endpointPrivateAccess;
    }
    /**
     * 
     * This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If the Amazon EKS private
     * API server endpoint is enabled, Kubernetes API requests that originate from within your cluster's VPC use the
     * private VPC endpoint instead of traversing the internet. If this value is disabled and you have nodes or Fargate
     * pods in the cluster, then ensure that publicAccessCidrs includes the necessary CIDR blocks for
     * communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
publicAccessCidrs includes the
     *        necessary CIDR blocks for communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint
     *        access control in the  Amazon EKS User Guide .
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public VpcConfigResponse withEndpointPrivateAccess(Boolean endpointPrivateAccess) {
        setEndpointPrivateAccess(endpointPrivateAccess);
        return this;
    }
    /**
     * 
     * This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If the Amazon EKS private
     * API server endpoint is enabled, Kubernetes API requests that originate from within your cluster's VPC use the
     * private VPC endpoint instead of traversing the internet. If this value is disabled and you have nodes or Fargate
     * pods in the cluster, then ensure that publicAccessCidrs includes the necessary CIDR blocks for
     * communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
publicAccessCidrs includes the
     *         necessary CIDR blocks for communication with the nodes or Fargate pods. For more information, see Amazon EKS cluster endpoint
     *         access control in the  Amazon EKS User Guide .
     */
    public Boolean isEndpointPrivateAccess() {
        return this.endpointPrivateAccess;
    }
    /**
     * 
     * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. Communication to
     * the endpoint from addresses outside of the listed CIDR blocks is denied. The default value is
     * 0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate pods in the
     * cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate
     *         pods in the cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint
     *         access control in the  Amazon EKS User Guide .
     */
    public java.util.List
     * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. Communication to
     * the endpoint from addresses outside of the listed CIDR blocks is denied. The default value is
     * 0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate pods in the
     * cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate
     *        pods in the cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint
     *        access control in the  Amazon EKS User Guide .
     */
    public void setPublicAccessCidrs(java.util.Collection
     * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. Communication to
     * the endpoint from addresses outside of the listed CIDR blocks is denied. The default value is
     * 0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate pods in the
     * cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
* NOTE: This method appends the values to the existing list (if any). Use * {@link #setPublicAccessCidrs(java.util.Collection)} or {@link #withPublicAccessCidrs(java.util.Collection)} if * you want to override the existing values. *
* * @param publicAccessCidrs * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. * Communication to the endpoint from addresses outside of the listed CIDR blocks is denied. The default * value is0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate
     *        pods in the cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint
     *        access control in the  Amazon EKS User Guide .
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public VpcConfigResponse withPublicAccessCidrs(String... publicAccessCidrs) {
        if (this.publicAccessCidrs == null) {
            setPublicAccessCidrs(new java.util.ArrayList
     * The CIDR blocks that are allowed access to your cluster's public Kubernetes API server endpoint. Communication to
     * the endpoint from addresses outside of the listed CIDR blocks is denied. The default value is
     * 0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate pods in the
     * cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint access
     * control in the  Amazon EKS User Guide .
     * 
0.0.0.0/0. If you've disabled private endpoint access and you have nodes or Fargate
     *        pods in the cluster, then ensure that the necessary CIDR blocks are listed. For more information, see Amazon EKS cluster endpoint
     *        access control in the  Amazon EKS User Guide .
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public VpcConfigResponse withPublicAccessCidrs(java.util.Collection