The CONGA Ansible Plugin extends CONGA using its extensibility model.

Ansible supports reading dynamic files (executable scripts) for inventories, password files etc. - the CONGA Ansible plugin supports the following files/scripts:

  • Static files
  • Python scripts (.py extension)

Provided Plugins

Value Provider Plugins

Plugin name Description
ansible-vault Allows to variables from encrypted Ansible Vault files.
ansible-inventory Allows to read Ansible Inventory files.

You can also define multiple value providers of the same plugin type. See value provider configuration for details.

URL File plugins

Plugin name Description
ansible-vault Decrypts a file encrypted with [Ansible Vault][ansible-vault. Can be combined with other URL file plugins.

Value Encryption plugins

Plugin name Description
ansible-vault Encrypts a single configuration parameter value with Ansible vault, to be stored as !vault tagged encrypted value in YAML file.

YAML Represent plugins

Plugin name Description
ansible-vault Registers a custom represent implementations that controls the rendering of !vault tagged encrypted values in the node model export YAML file.

Ansible Vault

Please note: You need to install the Java Cryptography Extension (JCE) Unlimited Strength policy files from Oracle, because Ansible uses 256 bit keys to handle encryption and decryption of the vault files. If you are using Java 8u162 or higher they are already active by default.

Ansible Vault files are files encrypted with Ansible Vault. Ansible Vault requires a vault password to be set in the environment to decrypt the files. You can set the vault password by either:

  • Setting the password via the system property:
    -Dansible.vault.password=mypassword
  • Setting the password via the system property pointing to a password file:
    -Dansible.vault.password.file=/path/to/password-file
  • Setting the system environment variable ANSIBLE_VAULT_PASSWORD.
  • Setting the system environment variable ANSIBLE_VAULT_PASSWORD_FILE pointing to the vault password file. This variable is used by Ansible itself as well.

Reading variables from Ansible Vault files

If you have an Ansible Vault-encrypted file containing password or other parameters in YAML format, you can use the Ansible Vault value provider plugin to read them in CONGA.

Example YAML file before encryption:

pwd1: abc

Using the value provider plugin for Ansible Vault you can the variables defined in the encrypted file.

Example:

  • ${ansible-vault::pwd1} = abc

Via configuration you need to tell the CONGA Maven Plugin (via the pom.xml or via system property) where to look up the file containing the encrypted variables, and the password to decrypt the data.

Example:

<plugin>
  <groupId>io.wcm.devops.conga</groupId>
  <artifactId>conga-maven-plugin</artifactId>
  <configuration>
    <valueProvider>
      ansible-vault;file=${project.basedir}/vault/myvars
    </valueProvider>
  </configuration>
</plugin>

Reading and decrypting Ansible Vault-encrypted files

The URL File plugin for Ansible Vault allows to access (and decrypt) Ansible Vault-encrpyted files anywhere in CONGA where a URL path to a file can be given - e.g. in file definitions for roles. This can be combined with other URL file plugins, e.g. getting an encrypted file from classpath, HTTP URL or other sources and then decrypting it.

Example:

# Copy file from classpath and decrypt it
- file: mysample.txt
  url: ansible-vault:classpath:/sample.txt

Ansible Inventory

Reading Ansible Inventory files

Ansible Inventory files are expected in a special format as used by the Ansible roles for AEM deployment with CONGA.

Example inventory:

[aem-author]
host-01

[aem-publish]
host-02
host-03

Using the value provider plugin for Ansible Inventory you can reference the list of host names for each group.

Example:

  • ${ansible-inventory::aem-author} = host-01
  • ${ansible-inventory::aem-publish} = host-02,host-03

Via configuration you need to tell the CONGA Maven Plugin (via the pom.xml or via system environment property) where to look up the Ansible Inventory file.

Example:

<plugin>
  <groupId>io.wcm.devops.conga</groupId>
  <artifactId>conga-maven-plugin</artifactId>
  <configuration>
    <valueProvider>
      ansible-inventory;file=${project.basedir}/inventory/inventory-example
    </valueProvider>
  </configuration>
</plugin>

The implementation supports both the “INI-style” inventory format as shown above, as well as JSON-style inventories as documented here.

If JSON-style inventories are used it's also possible to use a JsonPath expression for fetching data from the inventory. This example returns an array of matching values in the JSON data:

${ansible-inventory::$._meta.hostvars..[?(@.ec2_tag_Name == 'tag2')].ec2_private_ip_address}

Back to top

Version: 1.4.7-SNAPSHOT. Last Published: 2024-03-06.