2019-10-20 16:07:13 -04:00
|
|
|
---
|
|
|
|
title: "Templates"
|
|
|
|
permalink: /docs/templates
|
|
|
|
---
|
|
|
|
Templates are a special kind of [alternate](/docs/alternates) file. The template
|
|
|
|
content and host specific data are combined as input to a template processor
|
|
|
|
which produces a new file as its output.
|
|
|
|
|
|
|
|
This can be very useful if you need to vary a small part of a file, but it
|
|
|
|
doesn't support any kind of include directive.
|
|
|
|
|
|
|
|
## Template suffixes
|
|
|
|
|
|
|
|
To create a template, append an alternate suffix to the file name.
|
|
|
|
The suffix has the format:
|
|
|
|
|
|
|
|
##template.<template processor>
|
|
|
|
|
2019-11-15 08:49:55 -05:00
|
|
|
<sub><sup>
|
2019-10-20 16:07:13 -04:00
|
|
|
"template" can also be shortened to "t".
|
2019-11-15 08:49:55 -05:00
|
|
|
</sup></sub>
|
2019-10-20 16:07:13 -04:00
|
|
|
|
|
|
|
The supported template processors are:
|
|
|
|
|
|
|
|
| Processor | Suffixes | Dependencies |
|
|
|
|
| - | - | - |
|
|
|
|
| default | `##template`, `##template.default` | `awk` must be installed. (This should be installed on all *nix systems) |
|
2020-08-08 22:24:04 -04:00
|
|
|
| esh | `##template.esh` | `esh` must be installed. |
|
2019-10-20 16:07:13 -04:00
|
|
|
| j2cli | `##template.j2`, `##template.j2cli` | `j2cli` must be installed. |
|
|
|
|
| envtpl | `##template.j2`, `##template.envtpl` | `envtpl` must be installed. |
|
|
|
|
|
|
|
|
The processor can be omitted for "default".
|
|
|
|
Also, `j2` will be processed by either j2cli or envtpl, whichever is found.
|
|
|
|
|
|
|
|
## Exposed data
|
|
|
|
|
|
|
|
When template processors run, they will be provided the following set of data.
|
|
|
|
|
|
|
|
|
2022-02-21 13:17:50 -05:00
|
|
|
| Default (built-in) | Jinja or ESH | Description | Source |
|
|
|
|
| - | - | - | - |
|
2022-02-21 14:17:16 -05:00
|
|
|
| `yadm.arch` | `YADM_ARCH` | Architecture | <code>uname ‑m</code> |
|
2022-02-21 13:17:50 -05:00
|
|
|
| `yadm.class` | `YADM_CLASS` | Last defined class | <code>yadm config local.class</code> |
|
|
|
|
| `yadm.classes` | `YADM_CLASSES` | All classes | <code>yadm config ‑‑get‑all local.class</code> |
|
|
|
|
| `yadm.distro` | `YADM_DISTRO` | Distribution | <code>lsb_release ‑si</code><br/>or <code>/etc/os-release</code> |
|
|
|
|
| `yadm.distro_family` | `YADM_DISTRO_FAMILY` | Distribution Family | `ID_LIKE` from<code>/etc/os‑release</code> |
|
|
|
|
| `yadm.hostname` | `YADM_HOSTNAME` | Hostname | <code>uname ‑n</code> (without domain) |
|
|
|
|
| `yadm.os` | `YADM_OS` | Operating system | <code>uname ‑s</code> <sup>*</sup> |
|
|
|
|
| `yadm.source` | `YADM_SOURCE` | Template filename | (fully qualified path) |
|
2022-02-21 14:17:16 -05:00
|
|
|
| `yadm.user` | `YADM_USER` | Current user | <code>id ‑u ‑n</code> |
|
2022-02-21 13:47:17 -05:00
|
|
|
| `env.VAR` | | Env variables | Any VAR in the environment while yadm templates are processed |
|
2019-10-20 16:07:13 -04:00
|
|
|
|
2019-11-14 09:10:06 -05:00
|
|
|
<sub><sup>*
|
|
|
|
The OS for "Windows Subsystem for Linux" is reported as "WSL", even though uname identifies as "Linux".
|
2020-06-30 17:30:31 -04:00
|
|
|
<br/>
|
|
|
|
*
|
|
|
|
If `lsb_release` is not available, "distro" will be the ID specified in `/etc/os-release`.
|
2019-11-14 09:10:06 -05:00
|
|
|
</sup></sub>
|
|
|
|
|
2019-10-20 16:07:13 -04:00
|
|
|
## Supported template processors
|
|
|
|
|
|
|
|
default
|
|
|
|
: This built-in processor requires no additional software (assuming your distro
|
|
|
|
contains `awk`). This processor has a syntax _similar_ to the Jinja processors
|
|
|
|
below, however it only supports a small set of directives. Those directives are
|
|
|
|
detailed in the section below.
|
|
|
|
|
2020-08-08 22:24:04 -04:00
|
|
|
esh
|
|
|
|
: [esh][esh] is a template processor written in POSIX compliant shell. It allows
|
|
|
|
executing shell commands within templates. This can be used to reference
|
2020-12-09 18:29:39 -05:00
|
|
|
your own configurations within templates.
|
2020-08-08 22:24:04 -04:00
|
|
|
|
2019-10-20 16:07:13 -04:00
|
|
|
j2cli
|
|
|
|
: [j2cli][j2cli] (or `j2`) is a Python-based Jinja2 template processor. This
|
|
|
|
fully supports all directives of the [Jinja2 library][jinja]. When your template is
|
|
|
|
processed, the YADM_* values are provided to j2cli as environment variables.
|
|
|
|
|
|
|
|
envtpl
|
|
|
|
: [envtpl][envtpl] is another Python-based Jinja2 template processor. Online
|
|
|
|
comments suggest this software might not be maintained anymore.
|
|
|
|
|
|
|
|
## Built-in directives
|
|
|
|
yadm's "default" (built-in) template processor supports the following directives.
|
|
|
|
|
|
|
|
{% raw %}
|
|
|
|
variables
|
|
|
|
: Variables should be surrounded by `{{ }}`. It is fine for there to be
|
|
|
|
whitespace between the variable name and the double braces. The `{{` and
|
|
|
|
`}}` must be on the same line. For example:
|
|
|
|
|
|
|
|
```jinja
|
|
|
|
# WARNING: Do not edit this file.
|
|
|
|
# It was generated by processing {{ yadm.source }}
|
|
|
|
```
|
|
|
|
|
|
|
|
if-else-endif
|
|
|
|
: Entire blocks of content can be included or excluded based on the value of a
|
2024-12-05 16:29:13 -05:00
|
|
|
variable. Both equality (`==`) and inequality (`!=`) can be tested. These
|
|
|
|
blocks must start with `{% if yadm.variable == "value" %}` and end with
|
|
|
|
`{% endif %}`. An alternative block can also be specified using the directive
|
|
|
|
`{% else %}`. These directives must appear on lines by themselves. They may not
|
|
|
|
appear on the same line. The "if" directive only supports testing a single
|
|
|
|
variable, and there is no "elif" directive as there is in Jinja. <br><br> If
|
|
|
|
multiple classes are defined, `yadm.class=="someclass"` will be true if *any*
|
|
|
|
of the defined classes are "someclass". <br><br> Here is an example.
|
2019-10-20 16:07:13 -04:00
|
|
|
|
|
|
|
```jinja
|
|
|
|
{% if yadm.os == "Darwin" %}
|
|
|
|
This block is included for MacOS
|
|
|
|
{% else %}
|
2020-03-31 20:17:23 -04:00
|
|
|
This block is included for any other OS
|
2019-10-20 16:07:13 -04:00
|
|
|
{% endif %}
|
|
|
|
```
|
|
|
|
|
2020-10-10 15:18:16 -04:00
|
|
|
include
|
|
|
|
: Content can be included from external files using the
|
|
|
|
`{% include "filename" %}` syntax. The filename may include variables and
|
|
|
|
should be either a path relative to the current template or an absolute
|
2024-12-05 16:29:13 -05:00
|
|
|
path. The included file may itself also use variables, if-else-endif and
|
|
|
|
include directives. An example:
|
2020-10-10 15:18:16 -04:00
|
|
|
|
|
|
|
```jinja
|
|
|
|
{% include "extra/config.{{ yadm.os }}" %}
|
|
|
|
```
|
|
|
|
|
2019-10-20 16:07:13 -04:00
|
|
|
{% endraw %}
|
|
|
|
|
|
|
|
[envtpl]: https://github.com/andreasjansson/envtpl
|
2020-08-08 22:24:04 -04:00
|
|
|
[esh]: https://github.com/jirutka/esh
|
2019-10-20 16:07:13 -04:00
|
|
|
[j2cli]: https://github.com/kolypto/j2cli
|
|
|
|
[jinja]: https://jinja.palletsprojects.com
|