github.com/jmbataller/terraform@v0.6.8-0.20151125192640-b7a12e3a580c/website/source/docs/providers/atlas/r/artifact.html.markdown (about)

     1  ---
     2  layout: "atlas"
     3  page_title: "Atlas: atlas_artifact"
     4  sidebar_current: "docs-atlas-resource-artifact"
     5  description: |-
     6    Provides access to deployment artifacts managed by Atlas. This can
     7    be used to dynamically configure instantiation and provisioning
     8    of resources.
     9  ---
    10  
    11  # atlas\_artifact
    12  
    13  Provides access to deployment artifacts managed by Atlas. This can
    14  be used to dynamically configure instantiation and provisioning
    15  of resources.
    16  
    17  ## Example Usage
    18  
    19  An artifact can be created that has metadata representing
    20  an AMI in AWS. This AMI can be used to configure an instance. Any changes
    21  to this artifact will trigger a change to that instance.
    22  
    23  ```
    24  # Read the AMI
    25  resource "atlas_artifact" "web" {
    26      name = "hashicorp/web"
    27      type = "amazon.image"
    28      build = "latest"
    29      metadata {
    30          arch = "386"
    31      }
    32  }
    33  
    34  # Start our instance with the dynamic ami value
    35  # Remember to include the AWS region as it is part of the full ID
    36  resource "aws_instance" "app" {
    37      ami = "${atlas_artifact.web.metadata_full.region-us-east-1}"
    38      ...
    39  }
    40  ```
    41  
    42  ## Argument Reference
    43  
    44  The following arguments are supported:
    45  
    46  * `name` - (Required) Name of the artifact in Atlas. This is given
    47    in slug format like "organization/artifact".
    48  
    49  * `type` - (Required) The type of artifact to query for.
    50  
    51  * `build` - (Optional) The build number responsible for creating
    52    the version of the artifact to filter on. This can be "latest",
    53    to find a matching artifact in the latest build, "any" to find a
    54    matching artifact in any build, or a specific number to pin to that
    55    build. If `build` and `version` are unspecified, `version` will default
    56    to "latest". Cannot be specified with `version`.
    57  
    58  * `version` - (Optional)  The version of the artifact to filter on. This can
    59    be "latest", to match against the latest version, "any" to find a matching artifact
    60    in any version, or a specific number to pin to that version. Defaults to
    61    "latest" if neither `build` or `version` is specified. Cannot be specified
    62    with `build`.
    63  
    64  * `metadata_keys` - (Optional) If given, only an artifact containing
    65    the given keys will be returned. This is used to disambiguate when
    66    multiple potential artifacts match. An example is "aws" to filter
    67    on an AMI.
    68  
    69  * `metadata` - (Optional) If given, only an artifact matching the
    70    metadata filters will be returned. This is used to disambiguate when
    71    multiple potential artifacts match. An example is "arch" = "386" to
    72    filter on architecture.
    73  
    74  
    75  ## Attributes Reference
    76  
    77  The following attributes are exported:
    78  
    79  * `id` - The ID of the artifact. This could be an AMI ID, GCE Image ID, etc.
    80  * `file_url` - For artifacts that are binaries, this is a download path.
    81  * `metadata_full` - Contains the full metadata of the artifact. The keys are sanitized
    82    to replace any characters that are invalid in a resource name with a hyphen.
    83    For example, the "region.us-east-1" key will become "region-us-east-1".
    84  * `version_real` - The matching version of the artifact
    85  * `slug` - The artifact slug in Atlas