Ansible: agregar un elemento a una lista de diccionarios con una nueva cadena aleatoria

Aug 18 2020

Tengo una variable ansible que es una lista de dictados:

userdata:
  - { first: Mike, last: Smith, username: msmith}
  - { first: Jane, last: Largo, username: jlargo}
  - { first: Evan, last: Jones, username: ejones}

Me gustaría agregar un campo a cada entrada, 'contraseña' que tiene una contraseña alfanumérica de 20 caracteres generada aleatoriamente asignada a cada entrada para que pueda usarla según corresponda durante el libro de jugadas para las diversas acciones que necesitan para sincronizar esa contraseña a. Intenté hacer un bloque:, pero aprendí que no puedes hacer eso con_elementos. Tampoco pude encontrar una manera de usar with_items y guardar de nuevo en el diccionario de ese elemento. El complemento de búsqueda de contraseña parece prometedor (https://docs.ansible.com/ansible/latest/plugins/lookup/password.html) para obtener una contraseña aleatoria sin tener que guardarla en un archivo (/dev/null), pero parece que no puedo obtenerla en cada elemento de la lista.

Al final, me gustaría una estructura como esta:

userdata:
  - { first: Mike, last: Smith, username: msmith, password: FdUChpPtfonoPexMZmt0}
  - { first: Jane, last: Largo, username: jlargo, password: QR13sN7CP00LbdXZ0gON}
  - { first: Evan, last: Jones, username: ejones, password: OCQSmqCbO8239jHpQiRm}

Respuestas

2 Zeitounator Aug 17 2020 at 23:20

Debe crear una nueva lista que se repita sobre la original. Para cada elemento, combina el existente con el atributo de contraseña. Lo siguiente es un ejemplo:

---
- hosts: localhost
  gather_facts: false

  vars:
    userdata:
      - { first: Mike, last: Smith, username: msmith }
      - { first: Jane, last: Largo, username: jlargo }
      - { first: Evan, last: Jones, username: ejones }

  tasks:

    - name: Create a new list with random password
      vars:
        user_entry: "{{ item | combine({'password': lookup('password', '/dev/null')}) }}"
      set_fact:
        users_with_pass: "{{ users_with_pass | default([]) + [user_entry] }}"
      loop: "{{ userdata }}"

    - name: Show result
      debug:
        var: users_with_pass

Lo que da:

$ ansible-playbook test.yml 

PLAY [localhost] **************************************************************************************************************************************************************************************************

TASK [Create a new list with random password] *********************************************************************************************************************************************************************
ok: [localhost] => (item={'first': 'Mike', 'last': 'Smith', 'username': 'msmith'})
ok: [localhost] => (item={'first': 'Jane', 'last': 'Largo', 'username': 'jlargo'})
ok: [localhost] => (item={'first': 'Evan', 'last': 'Jones', 'username': 'ejones'})

TASK [Show result] ************************************************************************************************************************************************************************************************
ok: [localhost] => {
    "users_with_pass": [
        {
            "first": "Mike",
            "last": "Smith",
            "password": "w-zk-BAqJuJ090mTy8g0",
            "username": "msmith"
        },
        {
            "first": "Jane",
            "last": "Largo",
            "password": "J6g07utP.ANtbY7Z58Za",
            "username": "jlargo"
        },
        {
            "first": "Evan",
            "last": "Jones",
            "password": "eqHdpKDpkpEBY21qTyz5",
            "username": "ejones"
        }
    ]
}

PLAY RECAP ********************************************************************************************************************************************************************************************************
localhost                  : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0