2019-06-06 17:26:12 -04:00
|
|
|
---
|
|
|
|
description: |
|
2020-03-18 18:46:47 -04:00
|
|
|
The `packer console` command allows you to experiment with Packer variable
|
|
|
|
interpolations.
|
2019-06-06 17:26:12 -04:00
|
|
|
layout: docs
|
2020-03-18 18:46:47 -04:00
|
|
|
page_title: packer console - Commands
|
2020-04-02 19:39:47 -04:00
|
|
|
sidebar_title: <tt>console</tt>
|
2019-06-06 17:26:12 -04:00
|
|
|
---
|
|
|
|
|
|
|
|
# `console` Command
|
|
|
|
|
|
|
|
The `packer console` command allows you to experiment with Packer variable
|
|
|
|
interpolations. You may access variables in the Packer config you called the
|
|
|
|
console with, or provide variables when you call console using the -var or
|
|
|
|
-var-file command line options.
|
|
|
|
|
2019-09-06 03:02:30 -04:00
|
|
|
~> **Note:** `console` is available from version 1.4.2 and above.
|
|
|
|
|
2020-06-05 11:23:54 -04:00
|
|
|
~> **Note:** For HCL2 `console` is available from version 1.6.0 and above, use
|
|
|
|
`packer console --config-type=hcl2` to try it without a config file. Go
|
|
|
|
templating ( or `{{..}}` calls ) will not work in HCL2 mode.
|
2019-06-06 17:26:12 -04:00
|
|
|
|
2020-06-05 11:23:54 -04:00
|
|
|
Type in the interpolation to test and hit `<enter>` to see the result.
|
|
|
|
|
|
|
|
To exit the console, type "exit" and hit `<enter>`, or use Control-C.
|
2019-06-06 17:26:12 -04:00
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
$ packer console my_template.json
|
|
|
|
```
|
|
|
|
|
|
|
|
The full list of options that the console command will accept is visible in the
|
|
|
|
help output, which can be seen via `packer console -h`.
|
|
|
|
|
|
|
|
## Options
|
|
|
|
|
2020-03-18 18:46:47 -04:00
|
|
|
- `-var` - Set a variable in your packer template. This option can be used
|
|
|
|
multiple times. This is useful for setting version numbers for your build.
|
|
|
|
example: `-var "myvar=asdf"`
|
2019-06-06 17:26:12 -04:00
|
|
|
|
2020-03-18 18:46:47 -04:00
|
|
|
- `-var-file` - Set template variables from a file.
|
|
|
|
example: `-var-file myvars.json`
|
2019-06-06 17:26:12 -04:00
|
|
|
|
|
|
|
## REPL commands
|
|
|
|
|
2020-03-18 18:46:47 -04:00
|
|
|
- `help` - displays help text for Packer console.
|
2019-06-06 17:26:12 -04:00
|
|
|
|
2020-03-18 18:46:47 -04:00
|
|
|
- `exit` - exits the console
|
|
|
|
|
|
|
|
- `variables` - prints a list of all variables read into the console from the
|
|
|
|
`-var` option, `-var-files` option, and template.
|
2019-06-06 17:26:12 -04:00
|
|
|
|
2020-06-05 11:23:54 -04:00
|
|
|
## Usage Examples - repl session ( JSON )
|
2019-06-06 17:26:12 -04:00
|
|
|
|
|
|
|
Let's say you launch a console using a Packer template `example_template.json`:
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
$ packer console example_template.json
|
|
|
|
```
|
|
|
|
|
|
|
|
You'll be dropped into a prompt that allows you to enter template functions and
|
|
|
|
see how they're evaluated; for example, if the variable `myvar` is defined in
|
|
|
|
your example_template's variable section:
|
|
|
|
|
2020-03-31 18:47:06 -04:00
|
|
|
```json
|
2019-06-06 17:26:12 -04:00
|
|
|
"variables":{
|
|
|
|
"myvar": "asdfasdf"
|
|
|
|
},
|
|
|
|
...
|
|
|
|
```
|
2020-03-18 18:46:47 -04:00
|
|
|
|
|
|
|
and you enter `` {{user `myvar`}} `` in the Packer console, you'll see the value of
|
2019-06-06 17:26:12 -04:00
|
|
|
myvar:
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
> {{user `myvar`}}
|
2020-06-05 11:23:54 -04:00
|
|
|
asdfasdf
|
2019-06-06 17:26:12 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
From there you can test more complicated interpolations:
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
> {{user `myvar`}}-{{timestamp}}
|
2020-06-05 11:23:54 -04:00
|
|
|
asdfasdf-1559854396
|
2019-06-06 17:26:12 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
And when you're done using the console, just type "exit" or CTRL-C
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
> exit
|
|
|
|
$
|
|
|
|
```
|
|
|
|
|
|
|
|
If you'd like to provide a variable or variable files, you'd do this:
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
|
|
|
$ packer console -var "myvar=fdsafdsa" -var-file myvars.json example_template.json
|
2019-06-06 17:26:12 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
If you don't have specific variables or var files you want to test, and just
|
|
|
|
want to experiment with a particular template engine, you can do so by simply
|
|
|
|
calling `packer console` without a template file.
|
|
|
|
|
2020-06-05 11:23:54 -04:00
|
|
|
## Usage Examples - piped commands ( JSON )
|
|
|
|
|
2019-06-06 17:26:12 -04:00
|
|
|
If you'd like to just see a specific single interpolation without launching
|
|
|
|
the REPL, you can do so by echoing and piping the string into the console
|
|
|
|
command:
|
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell-session
|
2019-06-06 17:26:12 -04:00
|
|
|
$ echo {{timestamp}} | packer console
|
|
|
|
1559855090
|
2019-08-09 10:43:23 -04:00
|
|
|
```
|
2020-06-05 11:23:54 -04:00
|
|
|
|
|
|
|
## Usage Examples - repl session ( HCL2 )
|
|
|
|
|
|
|
|
~> **Note:** For HCL2 `console` is available from version 1.6.0 and above, use
|
|
|
|
`packer console --config-type=hcl2` to try it without a config file. Go
|
|
|
|
templating ( or `{{..}}` calls ) will not work in HCL2 mode.
|
|
|
|
|
|
|
|
Without a config file, `packer console` can be used to experiment with the
|
|
|
|
expression syntax and [built-in functions](/docs/from-1.5/functions).
|
|
|
|
|
|
|
|
### Starting
|
|
|
|
|
|
|
|
To start a session on a folder containing HCL2 config files, run:
|
|
|
|
|
|
|
|
```shell-session
|
|
|
|
packer console folder/
|
|
|
|
```
|
|
|
|
|
|
|
|
Because `folder/` is a folder Packer will start in HCL2 mode, you can also
|
|
|
|
directly pass an HCL2 formatted config file:
|
|
|
|
|
|
|
|
```shell-session
|
|
|
|
packer console file.pkr.hcl
|
|
|
|
```
|
|
|
|
|
|
|
|
Because the file is suffixed with `.pkr.hcl` Packer will start in HCL2 mode.
|
|
|
|
|
|
|
|
When you just want to play arround without a config file you can set the
|
|
|
|
`--config-type=hcl2` option and Packer will start in HCL2 mode:
|
|
|
|
|
|
|
|
```shell-session
|
|
|
|
packer console --config-type=hcl2
|
|
|
|
```
|
|
|
|
|
|
|
|
### Scripting
|
|
|
|
|
|
|
|
The `packer console` command can be used in non-interactive scripts by piping
|
|
|
|
newline-separated commands to it. Only the output from the final command is
|
|
|
|
printed unless an error occurs earlier.
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
```shell-session
|
2020-06-12 17:29:40 -04:00
|
|
|
$ echo "1 + 5" | packer console
|
2020-06-05 11:23:54 -04:00
|
|
|
6
|
2020-06-12 17:29:40 -04:00
|
|
|
```
|