/* * 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).
*