community.general.hiera lookup – get info from hiera data

Note

This lookup plugin is part of the community.general collection (version 6.6.2).

You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.

To install it, use: ansible-galaxy collection install community.general. You need further requirements to be able to use this lookup plugin, see Requirements for details.

To use it in a playbook, specify: community.general.hiera.

Synopsis

  • Retrieves data from an Puppetmaster node using Hiera as ENC.

Requirements

The below requirements are needed on the local controller node that executes this lookup.

  • hiera (command line utility)

Terms

Parameter

Comments

Terms

list / elements=string / required

The list of keys to lookup on the Puppetmaster.

Parameters

Parameter

Comments

config_file

string

File that describes the hierarchy of Hiera.

Default: "/etc/hiera.yaml"

Configuration:

  • Environment variable: ANSIBLE_HIERA_CFG

executable

string

Binary file to execute Hiera.

Default: "/usr/bin/hiera"

Configuration:

  • Environment variable: ANSIBLE_HIERA_BIN

Examples

# All this examples depends on hiera.yml that describes the hierarchy

- name: "a value from Hiera 'DB'"
  ansible.builtin.debug:
    msg: "{{ lookup('community.general.hiera', 'foo') }}"

- name: "a value from a Hiera 'DB' on other environment"
  ansible.builtin.debug:
    msg: "{{ lookup('community.general.hiera', 'foo environment=production') }}"

- name: "a value from a Hiera 'DB' for a concrete node"
  ansible.builtin.debug:
    msg: "{{ lookup('community.general.hiera', 'foo fqdn=puppet01.localdomain') }}"

Return Value

Key

Description

Return value

list / elements=string

a value associated with input key

Returned: success

Authors

  • Juan Manuel Parrilla (@jparrill)

Hint

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.