Ansible authorized key module unable to read public key

前端 未结 2 447
无人共我
无人共我 2021-01-27 11:35

I\'m trying to use ansible (version 2.1.2.0) to create named ssh access across our network of servers. Running ansible from a jump box I\'m creating a set of users and creating

相关标签:
2条回答
  • 2021-01-27 12:25

    On most linux/unix machines only two accounts have access to /home/testuser/.ssh/id_rsa.pub: root and testuser, so if you would like to modify those files you need to be either root, or testuser.

    You can use privilige escalation using become. You said you don't want to run ansible as root, which is perfectly fine. You haven't mentioned if the user you are running ansible with has sudo access or not. If it does, and using sudo is fine for you then you can simply do:

      - authorized_key:
          user: "{{ item }}"
          state: present
          key: "{{ lookup('file', '/home/{{ item }}/.ssh/id_rsa.pub') }}"
        with_items:
          - "{{ list_of_usernames }}"
        become: yes
    

    This by default will run these command as root using sudo, while keeping the rest of the tasks run by the non-root user. This is also the preferred way of doing runs with ansible.

    If you don't want this, and you want to keep your user as root-free as possible, then you need to run the command as testuser (and any other user you want to modify). This would mean you still need to patch up the sudoers file to allow your ansible user to transform into any of these users (which can also open up a few security issues - albeit not as much as being able to run anything as root), after which you can do:

      - authorized_key:
          user: "{{ item }}"
          state: present
          key: "{{ lookup('file', '/home/{{ item }}/.ssh/id_rsa.pub') }}"
        with_items:
          - "{{ list_of_usernames }}"
        become: yes
        become_user: "{{ item }}"
    

    There are some caveats using this approach, so you might want to read the full Privilege Escalation page on ansible's documentation, especially the section on Unpriviliged Users before you try this.

    0 讨论(0)
  • 2021-01-27 12:33

    OK, the problem is with lookup plugin.
    It is executed on ansible control host with permissions of user that run ansible-playbook and become: yes don't elevate plugins' permissions.

    To overcome this, capture result of user task and use its output in further tasks:

    - user:
        name: "{{ item }}"
        shell: /bin/bash
        group: docker
        generate_ssh_key: yes
        ssh_key_comment: "ansible-generated for {{ item }}"
      with_items:
        - ansible5
        - ansible6
      register: new_users
      become: yes
    
    - debug: msg="user {{ item.item }} pubkey {{ item.ssh_public_key }}"
      with_items: "{{ new_users.results }}"
    

    Although you need to delegate some of this tasks, the idea will be the same.

    0 讨论(0)
提交回复
热议问题