opentofu/website/docs/configuration/functions/fileset.html.md
Brian Flad 19cf34114f
lang/funcs: Switch fileset() function glob implementation to github.com/bmatcuk/doublestar to support additional glob patterns
This allows the usage of the glob patterns `**` and `{alternative1,...}` to simplify Terraform configuration logic for more complex file matching.
2019-08-30 20:22:03 -04:00

2.3 KiB

layout page_title sidebar_current description
functions fileset - Functions - Configuration Language docs-funcs-file-file-set The fileset function enumerates a set of regular file names given a pattern.

fileset Function

-> Note: This page is about Terraform 0.12 and later. For Terraform 0.11 and earlier, see 0.11 Configuration Language: Interpolation Syntax.

fileset enumerates a set of regular file names given a path and pattern. The path is automatically removed from the resulting set of file names and any result still containing path separators always returns forward slash (/) as the path separator for cross-system compatibility.

fileset(path, pattern)

Supported pattern matches:

  • * - matches any sequence of non-separator characters
  • ** - matches any sequence of characters, including separator characters
  • ? - matches any single non-separator character
  • {alternative1,...} - matches a sequence of characters if one of the comma-separated alternatives matches
  • [CLASS] - matches any single non-separator character inside a class of characters (see below)
  • [^CLASS] - matches any single non-separator character outside a class of characters (see below)

Character classes support the following:

  • [abc] - matches any single character within the set
  • [a-z] - matches any single character within the range

Functions are evaluated during configuration parsing rather than at apply time, so this function can only be used with files that are already present on disk before Terraform takes any actions.

Examples

> fileset(path.module, "files/*.txt")
[
  "files/hello.txt",
  "files/world.txt",
]

> fileset(path.module, "files/{hello,world}.txt")
[
  "files/hello.txt",
  "files/world.txt",
]

> fileset("${path.module}/files", "*")
[
  "hello.txt",
  "world.txt",
]

> fileset("${path.module}/files", "**")
[
  "hello.txt",
  "world.txt",
  "subdirectory/anotherfile.txt",
]

A common use of fileset is to create one resource instance per matched file, using the for_each meta-argument:

resource "example_thing" "example" {
  for_each = fileset(path.module, "files/*")

  # other configuration using each.value
}