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

com.amazonaws.services.ec2.model.DescribeSecurityGroupsRequest Maven / Gradle / Ivy

Go to download

The Amazon Web Services SDK for Java provides Java APIs for building software on AWS' cost-effective, scalable, and reliable infrastructure products. The AWS Java SDK allows developers to code against APIs for all of Amazon's infrastructure web services (Amazon S3, Amazon EC2, Amazon SQS, Amazon Relational Database Service, Amazon AutoScaling, etc).

The newest version!
/*
 * Copyright 2010-2014 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.ec2.model;

import java.io.Serializable;

import com.amazonaws.AmazonWebServiceRequest;
import com.amazonaws.Request;
import com.amazonaws.services.ec2.model.transform.DescribeSecurityGroupsRequestMarshaller;

/**
 * Container for the parameters to the {@link com.amazonaws.services.ec2.AmazonEC2#describeSecurityGroups(DescribeSecurityGroupsRequest) DescribeSecurityGroups operation}.
 * 

* Describes one or more of your security groups. *

*

* A security group is for use with instances either in the EC2-Classic * platform or in a specific VPC. For more information, see * Amazon EC2 Security Groups in the Amazon Elastic Compute Cloud User Guide and Security Groups for Your VPC * in the Amazon Virtual Private Cloud User Guide . *

* * @see com.amazonaws.services.ec2.AmazonEC2#describeSecurityGroups(DescribeSecurityGroupsRequest) */ public class DescribeSecurityGroupsRequest extends AmazonWebServiceRequest implements Serializable, DryRunSupportedRequest { /** * [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. */ private com.amazonaws.internal.ListWithAutoConstructFlag groupNames; /** * One or more security group IDs.

Default: Describes all your * security groups. */ private com.amazonaws.internal.ListWithAutoConstructFlag groupIds; /** * One or more filters.

  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

*/ private com.amazonaws.internal.ListWithAutoConstructFlag filters; /** * [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. * * @return [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. */ public java.util.List getGroupNames() { if (groupNames == null) { groupNames = new com.amazonaws.internal.ListWithAutoConstructFlag(); groupNames.setAutoConstruct(true); } return groupNames; } /** * [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. * * @param groupNames [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. */ public void setGroupNames(java.util.Collection groupNames) { if (groupNames == null) { this.groupNames = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag groupNamesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(groupNames.size()); groupNamesCopy.addAll(groupNames); this.groupNames = groupNamesCopy; } /** * [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. *

* Returns a reference to this object so that method calls can be chained together. * * @param groupNames [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. * * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withGroupNames(String... groupNames) { if (getGroupNames() == null) setGroupNames(new java.util.ArrayList(groupNames.length)); for (String value : groupNames) { getGroupNames().add(value); } return this; } /** * [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. *

* Returns a reference to this object so that method calls can be chained together. * * @param groupNames [EC2-Classic, default VPC] One or more security group names. *

Default: Describes all your security groups. * * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withGroupNames(java.util.Collection groupNames) { if (groupNames == null) { this.groupNames = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag groupNamesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(groupNames.size()); groupNamesCopy.addAll(groupNames); this.groupNames = groupNamesCopy; } return this; } /** * One or more security group IDs.

Default: Describes all your * security groups. * * @return One or more security group IDs.

Default: Describes all your * security groups. */ public java.util.List getGroupIds() { if (groupIds == null) { groupIds = new com.amazonaws.internal.ListWithAutoConstructFlag(); groupIds.setAutoConstruct(true); } return groupIds; } /** * One or more security group IDs.

Default: Describes all your * security groups. * * @param groupIds One or more security group IDs.

Default: Describes all your * security groups. */ public void setGroupIds(java.util.Collection groupIds) { if (groupIds == null) { this.groupIds = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag groupIdsCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(groupIds.size()); groupIdsCopy.addAll(groupIds); this.groupIds = groupIdsCopy; } /** * One or more security group IDs.

Default: Describes all your * security groups. *

* Returns a reference to this object so that method calls can be chained together. * * @param groupIds One or more security group IDs.

Default: Describes all your * security groups. * * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withGroupIds(String... groupIds) { if (getGroupIds() == null) setGroupIds(new java.util.ArrayList(groupIds.length)); for (String value : groupIds) { getGroupIds().add(value); } return this; } /** * One or more security group IDs.

Default: Describes all your * security groups. *

* Returns a reference to this object so that method calls can be chained together. * * @param groupIds One or more security group IDs.

Default: Describes all your * security groups. * * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withGroupIds(java.util.Collection groupIds) { if (groupIds == null) { this.groupIds = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag groupIdsCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(groupIds.size()); groupIdsCopy.addAll(groupIds); this.groupIds = groupIdsCopy; } return this; } /** * One or more filters.

  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

* * @return One or more filters.
  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

*/ public java.util.List getFilters() { if (filters == null) { filters = new com.amazonaws.internal.ListWithAutoConstructFlag(); filters.setAutoConstruct(true); } return filters; } /** * One or more filters.
  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

* * @param filters One or more filters.
  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

*/ public void setFilters(java.util.Collection filters) { if (filters == null) { this.filters = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag filtersCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(filters.size()); filtersCopy.addAll(filters); this.filters = filtersCopy; } /** * One or more filters.
  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

*

* Returns a reference to this object so that method calls can be chained together. * * @param filters One or more filters.

  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

* * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withFilters(Filter... filters) { if (getFilters() == null) setFilters(new java.util.ArrayList(filters.length)); for (Filter value : filters) { getFilters().add(value); } return this; } /** * One or more filters.
  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

*

* Returns a reference to this object so that method calls can be chained together. * * @param filters One or more filters.

  • description - The * description of the security group.

  • group-id * - The ID of the security group.

  • group-name * - The name of the security group.

  • *

    ip-permission.cidr - A CIDR range that has been * granted permission.

  • ip-permission.from-port * - The start of port range for the TCP and UDP protocols, or an ICMP * type number.

  • ip-permission.group-id - The * ID of a security group that has been granted permission.

  • *

    ip-permission.group-name - The name of a security * group that has been granted permission.

  • *

    ip-permission.protocol - The IP protocol for the * permission (tcp | udp | icmp or * a protocol number).

  • ip-permission.to-port - * The end of port range for the TCP and UDP protocols, or an ICMP code. *

  • ip-permission.user-id - The ID of an AWS * account that has been granted permission.

  • *

    owner-id - The AWS account ID of the owner of the * security group.

  • tag-key - The key of a tag * assigned to the security group.

  • tag-value - * The value of a tag assigned to the security group.

  • *

    vpc-id - The ID of the VPC specified when the security * group was created.

* * @return A reference to this updated object so that method calls can be chained * together. */ public DescribeSecurityGroupsRequest withFilters(java.util.Collection filters) { if (filters == null) { this.filters = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag filtersCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(filters.size()); filtersCopy.addAll(filters); this.filters = filtersCopy; } return this; } /** * This method is intended for internal use only. * Returns the marshaled request configured with additional parameters to * enable operation dry-run. */ @Override public Request getDryRunRequest() { Request request = new DescribeSecurityGroupsRequestMarshaller().marshall(this); request.addParameter("DryRun", Boolean.toString(true)); return request; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getGroupNames() != null) sb.append("GroupNames: " + getGroupNames() + ","); if (getGroupIds() != null) sb.append("GroupIds: " + getGroupIds() + ","); if (getFilters() != null) sb.append("Filters: " + getFilters() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getGroupNames() == null) ? 0 : getGroupNames().hashCode()); hashCode = prime * hashCode + ((getGroupIds() == null) ? 0 : getGroupIds().hashCode()); hashCode = prime * hashCode + ((getFilters() == null) ? 0 : getFilters().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DescribeSecurityGroupsRequest == false) return false; DescribeSecurityGroupsRequest other = (DescribeSecurityGroupsRequest)obj; if (other.getGroupNames() == null ^ this.getGroupNames() == null) return false; if (other.getGroupNames() != null && other.getGroupNames().equals(this.getGroupNames()) == false) return false; if (other.getGroupIds() == null ^ this.getGroupIds() == null) return false; if (other.getGroupIds() != null && other.getGroupIds().equals(this.getGroupIds()) == false) return false; if (other.getFilters() == null ^ this.getFilters() == null) return false; if (other.getFilters() != null && other.getFilters().equals(this.getFilters()) == false) return false; return true; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy