उत्तर देने योग्य: नए यादृच्छिक स्ट्रिंग के साथ शब्दकोशों की सूची में एक तत्व जोड़ना

Aug 18 2020

मेरे पास एक अनुशीलन चर है जो डिक्सेस की सूची है:

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

मैं प्रत्येक प्रविष्टि में एक फ़ील्ड जोड़ना चाहूंगा, 'पासवर्ड' जिसमें प्रत्येक प्रविष्टि के लिए एक यादृच्छिक रूप से उत्पन्न 20 वर्ण अल्फा-न्यूमेरिक पासवर्ड है, इसलिए मैं इसका उपयोग प्लेबुक के दौरान उन कार्यों के लिए लागू कर सकता हूं, जिन्हें उस पासवर्ड को सिंक करने की आवश्यकता है सेवा मेरे। मैंने एक ब्लॉक करने की कोशिश की :, लेकिन सीखा कि आप उस with_items को नहीं कर सकते। मुझे भी with_items का उपयोग करने और उस आइटम के शब्दकोश में वापस सहेजने का कोई तरीका नहीं मिला। पासवर्ड लुकअप प्लगइन आशाजनक लगता है (https://docs.ansible.com/ansible/latest/plugins/lookup/password.html) एक फ़ाइल (/ देव / नल) को बचाने के लिए बिना एक यादृच्छिक पासवर्ड प्राप्त करने के लिए, लेकिन मैं इसे सूची के प्रत्येक तत्व में प्राप्त नहीं कर सकता।

अंत में, मैं इस तरह की संरचना करना चाहूंगा:

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}

जवाब

2 Zeitounator Aug 17 2020 at 23:20

आपको अपने मूल पर एक नई सूची बनाने की आवश्यकता है। प्रत्येक आइटम के लिए, आप मौजूदा पासवर्ड विशेषता के साथ गठबंधन करते हैं। निम्नलिखित एक उदाहरण है:

---
- 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

जो देता है:

$ 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