/* * Copyright 2010-2018 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.DescribeImagesRequestMarshaller; /** * Container for the parameters to the {@link com.amazonaws.services.ec2.AmazonEC2#describeImages(DescribeImagesRequest) DescribeImages operation}. *
* Describes one or more of the images (AMIs, AKIs, and ARIs) available * to you. Images available to you include public images, private images * that you own, and private images owned by other AWS accounts but for * which you have explicit launch permissions. *
** NOTE: Deregistered images are included in the returned results * for an unspecified interval after deregistration. *
* * @see com.amazonaws.services.ec2.AmazonEC2#describeImages(DescribeImagesRequest) */ public class DescribeImagesRequest extends AmazonWebServiceRequest implements Serializable, DryRunSupportedRequestDefault: Describes all images available to
     * you.
     */
    private com.amazonaws.internal.ListWithAutoConstructFlag Default: Describes all images available to
     * you.
     *
     * @return One or more image IDs.  Default: Describes all images available to
     *         you.
     */
    public java.util.List Default: Describes all images available to
     * you.
     *
     * @param imageIds One or more image IDs.  Default: Describes all images available to
     *         you.
     */
    public void setImageIds(java.util.Collection Default: Describes all images available to
     * you.
     *  
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param imageIds One or more image IDs.  Default: Describes all images available to
     *         you.
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withImageIds(String... imageIds) {
        if (getImageIds() == null) setImageIds(new java.util.ArrayList Default: Describes all images available to
     * you.
     *  
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param imageIds One or more image IDs.  Default: Describes all images available to
     *         you.
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withImageIds(java.util.Collection 
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param owners Filters the images by the owner. Specify an AWS account ID,
     *          
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param owners Filters the images by the owner. Specify an AWS account ID,
     *          
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param executableUsers Scopes the images by users with explicit launch permissions. Specify
     *         an AWS account ID,  
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param executableUsers Scopes the images by users with explicit launch permissions. Specify
     *         an AWS account ID,  
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param filters One or more filters.  
     * Returns a reference to this object so that method calls can be chained together.
     *
     * @param filters One or more filters. amazon (owner is Amazon), aws-marketplace
     * (owner is AWS Marketplace), self (owner is the sender of
     * the request). Omitting this option returns all images for which you
     * have launch permissions, regardless of ownership.
     */
    private com.amazonaws.internal.ListWithAutoConstructFlagself (the sender of the request), or
     * all (public AMIs).
     */
    private com.amazonaws.internal.ListWithAutoConstructFlag 
*/
    private com.amazonaws.internal.ListWithAutoConstructFlagarchitecture - The
     * image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     * Boolean value that indicates whether the Amazon EBS volume is deleted
     * on instance termination. block-device-mapping.device-name - The device name for
     * the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     * snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     * the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     * the EBS volume (gp2 | io1 | st1
     * | sc1 | standard). description - The description of the image (provided
     * during image creation). hypervisor - The
     * hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     * kernel | ramdisk). is-public - A Boolean that indicates whether the image
     * is public. kernel-id - The kernel ID. manifest-location - The location of the image
     * manifest. name - The name of the AMI
     * (provided during image creation). owner-alias - The AWS account alias (for example,
     * amazon). owner-id - The AWS
     * account ID of the image owner. platform -
     * The platform. To only list Windows-based AMIs, use
     * windows. product-code - The
     * product code. product-code.type - The type
     * of the product code (devpay | marketplace).
     * ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     * (for example, /dev/sda1). root-device-type - The type of the root device volume
     * (ebs | instance-store). state - The state of the image (available
     * | pending | failed). state-reason-code - The reason code for the state
     * change. state-reason-message - The message
     * for the state change. tag:key=value - The key/value
     * combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     * This filter is independent of the tag-value filter. For example, if
     * you use both the filter "tag-key=Purpose" and the filter
     * "tag-value=X", you get any resources assigned both the tag key Purpose
     * (regardless of what the tag's value is), and the tag value X
     * (regardless of what the tag's key is). If you want to list only
     * resources where Purpose is X, see the
     * tag:key=value filter. tag-value - The value of a tag assigned to the
     * resource. This filter is independent of the tag-key
     * filter. virtualization-type - The
     * virtualization type (paravirtual | hvm).
     * amazon (owner is Amazon), aws-marketplace
     * (owner is AWS Marketplace), self (owner is the sender of
     * the request). Omitting this option returns all images for which you
     * have launch permissions, regardless of ownership.
     *
     * @return Filters the images by the owner. Specify an AWS account ID,
     *         amazon (owner is Amazon), aws-marketplace
     *         (owner is AWS Marketplace), self (owner is the sender of
     *         the request). Omitting this option returns all images for which you
     *         have launch permissions, regardless of ownership.
     */
    public java.util.Listamazon (owner is Amazon), aws-marketplace
     * (owner is AWS Marketplace), self (owner is the sender of
     * the request). Omitting this option returns all images for which you
     * have launch permissions, regardless of ownership.
     *
     * @param owners Filters the images by the owner. Specify an AWS account ID,
     *         amazon (owner is Amazon), aws-marketplace
     *         (owner is AWS Marketplace), self (owner is the sender of
     *         the request). Omitting this option returns all images for which you
     *         have launch permissions, regardless of ownership.
     */
    public void setOwners(java.util.Collectionamazon (owner is Amazon), aws-marketplace
     * (owner is AWS Marketplace), self (owner is the sender of
     * the request). Omitting this option returns all images for which you
     * have launch permissions, regardless of ownership.
     * amazon (owner is Amazon), aws-marketplace
     *         (owner is AWS Marketplace), self (owner is the sender of
     *         the request). Omitting this option returns all images for which you
     *         have launch permissions, regardless of ownership.
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withOwners(String... owners) {
        if (getOwners() == null) setOwners(new java.util.ArrayListamazon (owner is Amazon), aws-marketplace
     * (owner is AWS Marketplace), self (owner is the sender of
     * the request). Omitting this option returns all images for which you
     * have launch permissions, regardless of ownership.
     * amazon (owner is Amazon), aws-marketplace
     *         (owner is AWS Marketplace), self (owner is the sender of
     *         the request). Omitting this option returns all images for which you
     *         have launch permissions, regardless of ownership.
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withOwners(java.util.Collectionself (the sender of the request), or
     * all (public AMIs).
     *
     * @return Scopes the images by users with explicit launch permissions. Specify
     *         an AWS account ID, self (the sender of the request), or
     *         all (public AMIs).
     */
    public java.util.Listself (the sender of the request), or
     * all (public AMIs).
     *
     * @param executableUsers Scopes the images by users with explicit launch permissions. Specify
     *         an AWS account ID, self (the sender of the request), or
     *         all (public AMIs).
     */
    public void setExecutableUsers(java.util.Collectionself (the sender of the request), or
     * all (public AMIs).
     * self (the sender of the request), or
     *         all (public AMIs).
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withExecutableUsers(String... executableUsers) {
        if (getExecutableUsers() == null) setExecutableUsers(new java.util.ArrayListself (the sender of the request), or
     * all (public AMIs).
     * self (the sender of the request), or
     *         all (public AMIs).
     *
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withExecutableUsers(java.util.Collection 
*
     * @return One or more filters.architecture - The
     * image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     * Boolean value that indicates whether the Amazon EBS volume is deleted
     * on instance termination. block-device-mapping.device-name - The device name for
     * the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     * snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     * the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     * the EBS volume (gp2 | io1 | st1
     * | sc1 | standard). description - The description of the image (provided
     * during image creation). hypervisor - The
     * hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     * kernel | ramdisk). is-public - A Boolean that indicates whether the image
     * is public. kernel-id - The kernel ID. manifest-location - The location of the image
     * manifest. name - The name of the AMI
     * (provided during image creation). owner-alias - The AWS account alias (for example,
     * amazon). owner-id - The AWS
     * account ID of the image owner. platform -
     * The platform. To only list Windows-based AMIs, use
     * windows. product-code - The
     * product code. product-code.type - The type
     * of the product code (devpay | marketplace).
     * ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     * (for example, /dev/sda1). root-device-type - The type of the root device volume
     * (ebs | instance-store). state - The state of the image (available
     * | pending | failed). state-reason-code - The reason code for the state
     * change. state-reason-message - The message
     * for the state change. tag:key=value - The key/value
     * combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     * This filter is independent of the tag-value filter. For example, if
     * you use both the filter "tag-key=Purpose" and the filter
     * "tag-value=X", you get any resources assigned both the tag key Purpose
     * (regardless of what the tag's value is), and the tag value X
     * (regardless of what the tag's key is). If you want to list only
     * resources where Purpose is X, see the
     * tag:key=value filter. tag-value - The value of a tag assigned to the
     * resource. This filter is independent of the tag-key
     * filter. virtualization-type - The
     * virtualization type (paravirtual | hvm).
     *  
*/
    public java.util.Listarchitecture - The
     *         image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     *         Boolean value that indicates whether the Amazon EBS volume is deleted
     *         on instance termination. block-device-mapping.device-name - The device name for
     *         the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     *         snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     *         the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     *         the EBS volume (gp2 | io1 | st1
     *         | sc1 | standard). description - The description of the image (provided
     *         during image creation). hypervisor - The
     *         hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     *         kernel | ramdisk). is-public - A Boolean that indicates whether the image
     *         is public. kernel-id - The kernel ID. manifest-location - The location of the image
     *         manifest. name - The name of the AMI
     *         (provided during image creation). owner-alias - The AWS account alias (for example,
     *         amazon). owner-id - The AWS
     *         account ID of the image owner. platform -
     *         The platform. To only list Windows-based AMIs, use
     *         windows. product-code - The
     *         product code. product-code.type - The type
     *         of the product code (devpay | marketplace).
     *         ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     *         (for example, /dev/sda1). root-device-type - The type of the root device volume
     *         (ebs | instance-store). state - The state of the image (available
     *         | pending | failed). state-reason-code - The reason code for the state
     *         change. state-reason-message - The message
     *         for the state change. tag:key=value - The key/value
     *         combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     *         This filter is independent of the tag-value filter. For example, if
     *         you use both the filter "tag-key=Purpose" and the filter
     *         "tag-value=X", you get any resources assigned both the tag key Purpose
     *         (regardless of what the tag's value is), and the tag value X
     *         (regardless of what the tag's key is). If you want to list only
     *         resources where Purpose is X, see the
     *         tag:key=value filter. tag-value - The value of a tag assigned to the
     *         resource. This filter is independent of the tag-key
     *         filter. virtualization-type - The
     *         virtualization type (paravirtual | hvm).
     *          
*
     * @param filters One or more filters.architecture - The
     * image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     * Boolean value that indicates whether the Amazon EBS volume is deleted
     * on instance termination. block-device-mapping.device-name - The device name for
     * the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     * snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     * the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     * the EBS volume (gp2 | io1 | st1
     * | sc1 | standard). description - The description of the image (provided
     * during image creation). hypervisor - The
     * hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     * kernel | ramdisk). is-public - A Boolean that indicates whether the image
     * is public. kernel-id - The kernel ID. manifest-location - The location of the image
     * manifest. name - The name of the AMI
     * (provided during image creation). owner-alias - The AWS account alias (for example,
     * amazon). owner-id - The AWS
     * account ID of the image owner. platform -
     * The platform. To only list Windows-based AMIs, use
     * windows. product-code - The
     * product code. product-code.type - The type
     * of the product code (devpay | marketplace).
     * ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     * (for example, /dev/sda1). root-device-type - The type of the root device volume
     * (ebs | instance-store). state - The state of the image (available
     * | pending | failed). state-reason-code - The reason code for the state
     * change. state-reason-message - The message
     * for the state change. tag:key=value - The key/value
     * combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     * This filter is independent of the tag-value filter. For example, if
     * you use both the filter "tag-key=Purpose" and the filter
     * "tag-value=X", you get any resources assigned both the tag key Purpose
     * (regardless of what the tag's value is), and the tag value X
     * (regardless of what the tag's key is). If you want to list only
     * resources where Purpose is X, see the
     * tag:key=value filter. tag-value - The value of a tag assigned to the
     * resource. This filter is independent of the tag-key
     * filter. virtualization-type - The
     * virtualization type (paravirtual | hvm).
     *  
*/
    public void setFilters(java.util.Collectionarchitecture - The
     *         image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     *         Boolean value that indicates whether the Amazon EBS volume is deleted
     *         on instance termination. block-device-mapping.device-name - The device name for
     *         the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     *         snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     *         the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     *         the EBS volume (gp2 | io1 | st1
     *         | sc1 | standard). description - The description of the image (provided
     *         during image creation). hypervisor - The
     *         hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     *         kernel | ramdisk). is-public - A Boolean that indicates whether the image
     *         is public. kernel-id - The kernel ID. manifest-location - The location of the image
     *         manifest. name - The name of the AMI
     *         (provided during image creation). owner-alias - The AWS account alias (for example,
     *         amazon). owner-id - The AWS
     *         account ID of the image owner. platform -
     *         The platform. To only list Windows-based AMIs, use
     *         windows. product-code - The
     *         product code. product-code.type - The type
     *         of the product code (devpay | marketplace).
     *         ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     *         (for example, /dev/sda1). root-device-type - The type of the root device volume
     *         (ebs | instance-store). state - The state of the image (available
     *         | pending | failed). state-reason-code - The reason code for the state
     *         change. state-reason-message - The message
     *         for the state change. tag:key=value - The key/value
     *         combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     *         This filter is independent of the tag-value filter. For example, if
     *         you use both the filter "tag-key=Purpose" and the filter
     *         "tag-value=X", you get any resources assigned both the tag key Purpose
     *         (regardless of what the tag's value is), and the tag value X
     *         (regardless of what the tag's key is). If you want to list only
     *         resources where Purpose is X, see the
     *         tag:key=value filter. tag-value - The value of a tag assigned to the
     *         resource. This filter is independent of the tag-key
     *         filter. virtualization-type - The
     *         virtualization type (paravirtual | hvm).
     *          
*architecture - The
     * image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     * Boolean value that indicates whether the Amazon EBS volume is deleted
     * on instance termination. block-device-mapping.device-name - The device name for
     * the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     * snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     * the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     * the EBS volume (gp2 | io1 | st1
     * | sc1 | standard). description - The description of the image (provided
     * during image creation). hypervisor - The
     * hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     * kernel | ramdisk). is-public - A Boolean that indicates whether the image
     * is public. kernel-id - The kernel ID. manifest-location - The location of the image
     * manifest. name - The name of the AMI
     * (provided during image creation). owner-alias - The AWS account alias (for example,
     * amazon). owner-id - The AWS
     * account ID of the image owner. platform -
     * The platform. To only list Windows-based AMIs, use
     * windows. product-code - The
     * product code. product-code.type - The type
     * of the product code (devpay | marketplace).
     * ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     * (for example, /dev/sda1). root-device-type - The type of the root device volume
     * (ebs | instance-store). state - The state of the image (available
     * | pending | failed). state-reason-code - The reason code for the state
     * change. state-reason-message - The message
     * for the state change. tag:key=value - The key/value
     * combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     * This filter is independent of the tag-value filter. For example, if
     * you use both the filter "tag-key=Purpose" and the filter
     * "tag-value=X", you get any resources assigned both the tag key Purpose
     * (regardless of what the tag's value is), and the tag value X
     * (regardless of what the tag's key is). If you want to list only
     * resources where Purpose is X, see the
     * tag:key=value filter. tag-value - The value of a tag assigned to the
     * resource. This filter is independent of the tag-key
     * filter. virtualization-type - The
     * virtualization type (paravirtual | hvm).
     *  
*
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withFilters(Filter... filters) {
        if (getFilters() == null) setFilters(new java.util.ArrayListarchitecture - The
     *         image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     *         Boolean value that indicates whether the Amazon EBS volume is deleted
     *         on instance termination. block-device-mapping.device-name - The device name for
     *         the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     *         snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     *         the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     *         the EBS volume (gp2 | io1 | st1
     *         | sc1 | standard). description - The description of the image (provided
     *         during image creation). hypervisor - The
     *         hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     *         kernel | ramdisk). is-public - A Boolean that indicates whether the image
     *         is public. kernel-id - The kernel ID. manifest-location - The location of the image
     *         manifest. name - The name of the AMI
     *         (provided during image creation). owner-alias - The AWS account alias (for example,
     *         amazon). owner-id - The AWS
     *         account ID of the image owner. platform -
     *         The platform. To only list Windows-based AMIs, use
     *         windows. product-code - The
     *         product code. product-code.type - The type
     *         of the product code (devpay | marketplace).
     *         ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     *         (for example, /dev/sda1). root-device-type - The type of the root device volume
     *         (ebs | instance-store). state - The state of the image (available
     *         | pending | failed). state-reason-code - The reason code for the state
     *         change. state-reason-message - The message
     *         for the state change. tag:key=value - The key/value
     *         combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     *         This filter is independent of the tag-value filter. For example, if
     *         you use both the filter "tag-key=Purpose" and the filter
     *         "tag-value=X", you get any resources assigned both the tag key Purpose
     *         (regardless of what the tag's value is), and the tag value X
     *         (regardless of what the tag's key is). If you want to list only
     *         resources where Purpose is X, see the
     *         tag:key=value filter. tag-value - The value of a tag assigned to the
     *         resource. This filter is independent of the tag-key
     *         filter. virtualization-type - The
     *         virtualization type (paravirtual | hvm).
     *          
*architecture - The
     * image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     * Boolean value that indicates whether the Amazon EBS volume is deleted
     * on instance termination. block-device-mapping.device-name - The device name for
     * the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     * snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     * the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     * the EBS volume (gp2 | io1 | st1
     * | sc1 | standard). description - The description of the image (provided
     * during image creation). hypervisor - The
     * hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     * kernel | ramdisk). is-public - A Boolean that indicates whether the image
     * is public. kernel-id - The kernel ID. manifest-location - The location of the image
     * manifest. name - The name of the AMI
     * (provided during image creation). owner-alias - The AWS account alias (for example,
     * amazon). owner-id - The AWS
     * account ID of the image owner. platform -
     * The platform. To only list Windows-based AMIs, use
     * windows. product-code - The
     * product code. product-code.type - The type
     * of the product code (devpay | marketplace).
     * ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     * (for example, /dev/sda1). root-device-type - The type of the root device volume
     * (ebs | instance-store). state - The state of the image (available
     * | pending | failed). state-reason-code - The reason code for the state
     * change. state-reason-message - The message
     * for the state change. tag:key=value - The key/value
     * combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     * This filter is independent of the tag-value filter. For example, if
     * you use both the filter "tag-key=Purpose" and the filter
     * "tag-value=X", you get any resources assigned both the tag key Purpose
     * (regardless of what the tag's value is), and the tag value X
     * (regardless of what the tag's key is). If you want to list only
     * resources where Purpose is X, see the
     * tag:key=value filter. tag-value - The value of a tag assigned to the
     * resource. This filter is independent of the tag-key
     * filter. virtualization-type - The
     * virtualization type (paravirtual | hvm).
     *  
*
     * @return A reference to this updated object so that method calls can be chained
     *         together.
     */
    public DescribeImagesRequest withFilters(java.util.Collectionarchitecture - The
     *         image architecture (i386 | x86_64). block-device-mapping.delete-on-termination - A
     *         Boolean value that indicates whether the Amazon EBS volume is deleted
     *         on instance termination. block-device-mapping.device-name - The device name for
     *         the EBS volume (for example, /dev/sdh). block-device-mapping.snapshot-id - The ID of the
     *         snapshot used for the EBS volume. block-device-mapping.volume-size - The volume size of
     *         the EBS volume, in GiB. block-device-mapping.volume-type - The volume type of
     *         the EBS volume (gp2 | io1 | st1
     *         | sc1 | standard). description - The description of the image (provided
     *         during image creation). hypervisor - The
     *         hypervisor type (ovm | xen). image-id - The ID of the image. image-type - The image type (machine |
     *         kernel | ramdisk). is-public - A Boolean that indicates whether the image
     *         is public. kernel-id - The kernel ID. manifest-location - The location of the image
     *         manifest. name - The name of the AMI
     *         (provided during image creation). owner-alias - The AWS account alias (for example,
     *         amazon). owner-id - The AWS
     *         account ID of the image owner. platform -
     *         The platform. To only list Windows-based AMIs, use
     *         windows. product-code - The
     *         product code. product-code.type - The type
     *         of the product code (devpay | marketplace).
     *         ramdisk-id - The RAM disk ID. root-device-name - The name of the root device volume
     *         (for example, /dev/sda1). root-device-type - The type of the root device volume
     *         (ebs | instance-store). state - The state of the image (available
     *         | pending | failed). state-reason-code - The reason code for the state
     *         change. state-reason-message - The message
     *         for the state change. tag:key=value - The key/value
     *         combination of a tag assigned to the resource. tag-key - The key of a tag assigned to the resource.
     *         This filter is independent of the tag-value filter. For example, if
     *         you use both the filter "tag-key=Purpose" and the filter
     *         "tag-value=X", you get any resources assigned both the tag key Purpose
     *         (regardless of what the tag's value is), and the tag value X
     *         (regardless of what the tag's key is). If you want to list only
     *         resources where Purpose is X, see the
     *         tag:key=value filter. tag-value - The value of a tag assigned to the
     *         resource. This filter is independent of the tag-key
     *         filter. virtualization-type - The
     *         virtualization type (paravirtual | hvm).
     *