blob: b467c2cb40f63e6d10463dfa20d31b73668236c9 [file] [log] [blame]
---
page_title: textencodebase64 - Functions - Configuration Language
description: >-
The textencodebase64 function encodes the unicode characters in a given string
using a
specified character encoding, returning the result base64 encoded.
---
# `textencodebase64` Function
-> **Note:** This function is supported only in Terraform v0.14 and later.
`textencodebase64` encodes the unicode characters in a given string using a
specified character encoding, returning the result base64 encoded because
Terraform language strings are always sequences of unicode characters.
```hcl
substr(string, encoding_name)
```
Terraform uses the "standard" Base64 alphabet as defined in
[RFC 4648 section 4](https://tools.ietf.org/html/rfc4648#section-4).
The `encoding_name` argument must contain one of the encoding names or aliases
recorded in
[the IANA character encoding registry](https://www.iana.org/assignments/character-sets/character-sets.xhtml).
Terraform supports only a subset of the registered encodings, and the encoding
support may vary between Terraform versions. In particular Terraform supports
`UTF-16LE`, which is the native character encoding for the Windows API and
therefore sometimes expected by Windows-originated software such as PowerShell.
Terraform also accepts the encoding name `UTF-8`, which will produce the same
result as [`base64encode`](/terraform/language/functions/base64encode).
## Examples
```
> textencodebase64("Hello World", "UTF-16LE")
SABlAGwAbABvACAAVwBvAHIAbABkAA==
```
## Related Functions
* [`textdecodebase64`](/terraform/language/functions/textdecodebase64) performs the opposite operation,
decoding Base64 data and interpreting it as a particular character encoding.
* [`base64encode`](/terraform/language/functions/base64encode) applies Base64 encoding of the UTF-8
encoding of a string.
* [`filebase64`](/terraform/language/functions/filebase64) reads a file from the local filesystem
and returns its raw bytes with Base64 encoding, without creating an
intermediate Unicode string.