Commit 21b8a4d3 by Joseph Mulloy

Add optional fail when ssh keys missing OPS-1433

parent fc3c121b
......@@ -38,3 +38,13 @@ user_info: []
user_debian_pkgs:
# This is needed for the uri module to work correctly.
- python-httplib2
# Boolean variable that will cause the user module to stop Ansible with a
# failure if a user that has been configured to have their keys pulled from
# GitHub does not have any ssh keys configured on GitHub. This is set to
# false by default as we normally do not wish to interrupt Ansible, but
# we wish to selectively enable it for a particular Jenkins job that adds
# users. In the default false state this playbook will only print a warning
# message, but not halt.
#
user_fail_missing_keys: false
......@@ -124,16 +124,23 @@
- name: Check the ssh key(s) for user(s) over github
uri:
url: "https://github.com/{{ item.name }}.keys"
return_content: true
# We don't care if absent users lack ssh keys
when: item.get('state', 'present') == 'present'
with_items: "{{ user_info }}"
register: github_users_return
- debug:
msg: "User {{ item.item.name }} doesn't have an SSH key associated with their account"
msg: "User {{ item.item.name }} doesn't have an SSH key associated with their github account"
with_items: "{{ github_users_return.results | default([]) }}"
# We skip users in the previous task, and they end up with no content_length
when: item.get('content_length') and item.content_length == "0"
when: ('content' in item and item.content == "")
- fail:
msg: "User {{ item.item.name }} doesn't have an SSH key associated with their github account"
with_items: "{{ github_users_return.results | default([]) }}"
# We skip users in the previous task, and they end up with no content_length
when: (user_fail_missing_keys and 'content' in item and item.content == "")
- name: Get github key(s) and update the authorized_keys file
authorized_key:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment