--- description: | This data source has been deprecated, please use HCP Packer Version data source instead. The HCP Packer Iteration Data Source retrieves information about an iteration from the HCP Packer registry. This information can be used to query HCP for a source image for various Packer builders. page_title: HCP Packer Iteration - Data Sources --- # HCP Packer Iteration Data Source ~> **Note:** This data source has been deprecated, please use [HCP Packer Version](/packer/docs/datasources/hcp/hcp-packer-version) data source instead. Type: `hcp-packer-iteration` The `HCP Packer Iteration` Data Source retrieves information about an iteration from the HCP Packer registry. This information can be used to query HCP for a source image for various Packer builders. To get started with HCP Packer, refer to the [HCP Packer documentation](/hcp/docs/packer) or try the [Get Started with HCP Packer tutorials](/packer/tutorials/hcp-get-started). ~> **Note:** You will receive an error if you try to reference metadata from a deactivated or deleted registry. An administrator can manually deactivate or delete a registry, and HCP Packer automatically deactivates registries with billing issues. Contact [HashiCorp Support](https://support.hashicorp.com/) with questions. ## Revoked Iterations If an iteration is revoked, the `hcp-packer-iteration` data source will fail and Packer won't proceed with the build. Building new images from a revoked image is not compliant. Iterations that are scheduled to be revoked will still be considered valid until the revocation date. ## Basic Example Below is a fully functioning example. It stores information about an image iteration, which can then be accessed as a variable. ```hcl data "hcp-packer-iteration" "hardened-source" { bucket_name = "hardened-ubuntu-16-04" channel = "packer-test" } ``` ## Full Example This data source can be used in conjunction with the hcp-packer-image data source to retrieve an image ID using a channel. You provide the channel name to the iteration data source, then use the iteration source inside the image data source, then use the image data source inside your source block. ```hcl # Retrieves information about the HCP Packer "iteration"; an "iteration" can be # thought of as all the metadata created by a single call of `packer build`. data "hcp-packer-iteration" "hardened-source" { bucket_name = "hardened-ubuntu-16-04" channel = "packer-test" } # Retrieves information about the HCP Packer "image"; an image can be thought # of as all the metadata (including the artifact names) created by a single # "source" builder; this can include multiple images so we provide a cloud # region to disambiguate. data "hcp-packer-image" "foo" { bucket_name = "hardened-ubuntu-16-04" iteration_id = data.hcp-packer-iteration.hardened-source.id cloud_provider = "aws" region = "us-east-1" } # This source uses the output from a previous Packer build. By using the # HCP Packer registry in this way, you can easily create build pipelines where # a single base image can be customized in multiple secondary layers. source "amazon-ebs" "packer-secondary" { source_ami = data.hcp-packer-image.foo.id ... } ``` ## Configuration Reference Configuration options are organized below into two categories: required and optional. Within each category, the available options are alphabetized and described. ### Required: @include 'datasource/hcp-packer-iteration/Config-required.mdx' There are currently no optional fields for this datasource, though we intend to add filtering fields in the future. ### Output Fields: @include 'datasource/hcp-packer-iteration/DatasourceOutput.mdx'