2020-02-02 13:54:28 +01:00
|
|
|
---
|
2018-10-24 12:51:45 +02:00
|
|
|
- name: Generate privatekey1 - standard
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey1'
|
2019-06-06 07:58:51 +02:00
|
|
|
register: privatekey1_result
|
2018-10-24 12:51:45 +02:00
|
|
|
|
2019-11-20 21:02:26 +01:00
|
|
|
- name: Generate privatekey1 - standard (idempotent)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey1'
|
|
|
|
register: privatekey1_idem_result
|
|
|
|
|
2018-10-24 12:51:45 +02:00
|
|
|
- name: Generate privatekey2 - size 2048
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey2'
|
|
|
|
size: 2048
|
|
|
|
|
|
|
|
- name: Generate privatekey3 - type dsa
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey3'
|
|
|
|
type: dsa
|
|
|
|
|
|
|
|
- name: Generate privatekey4 - standard
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey4'
|
|
|
|
|
|
|
|
- name: Delete privatekey4 - standard
|
|
|
|
openssh_keypair:
|
|
|
|
state: absent
|
|
|
|
path: '{{ output_dir }}/privatekey4'
|
|
|
|
|
2019-03-05 17:07:43 +01:00
|
|
|
- name: Generate privatekey5 - standard
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey5'
|
|
|
|
register: publickey_gen
|
|
|
|
|
2019-06-24 21:45:49 +02:00
|
|
|
- name: Generate privatekey6
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey6'
|
|
|
|
type: rsa
|
|
|
|
|
|
|
|
- name: Regenerate privatekey6 via force
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey6'
|
|
|
|
type: rsa
|
|
|
|
force: yes
|
|
|
|
register: output_regenerated_via_force
|
|
|
|
|
|
|
|
- name: Create broken key
|
|
|
|
copy:
|
|
|
|
dest: '{{ item }}'
|
|
|
|
content: ''
|
|
|
|
mode: '0700'
|
|
|
|
loop:
|
|
|
|
- '{{ output_dir }}/privatekeybroken'
|
|
|
|
- '{{ output_dir }}/privatekeybroken.pub'
|
|
|
|
|
2020-02-02 13:54:28 +01:00
|
|
|
- name: Regenerate broken key - should fail
|
2019-06-24 21:45:49 +02:00
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekeybroken'
|
|
|
|
type: rsa
|
|
|
|
register: output_broken
|
2020-02-02 13:54:28 +01:00
|
|
|
ignore_errors: yes
|
|
|
|
|
|
|
|
- name: Regenerate broken key with force
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekeybroken'
|
|
|
|
type: rsa
|
|
|
|
force: yes
|
|
|
|
register: output_broken_force
|
2019-06-24 21:45:49 +02:00
|
|
|
|
|
|
|
- name: Generate read-only private key
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekeyreadonly'
|
|
|
|
type: rsa
|
|
|
|
mode: '0200'
|
|
|
|
|
|
|
|
- name: Regenerate read-only private key via force
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekeyreadonly'
|
|
|
|
type: rsa
|
|
|
|
force: yes
|
|
|
|
register: output_read_only
|
|
|
|
|
2019-08-11 00:57:35 +02:00
|
|
|
- name: Generate privatekey7 - standard with comment
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey7'
|
|
|
|
comment: 'test@privatekey7'
|
|
|
|
register: privatekey7_result
|
|
|
|
|
|
|
|
- name: Modify privatekey7 comment
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey7'
|
|
|
|
comment: 'test_modified@privatekey7'
|
|
|
|
register: privatekey7_modified_result
|
|
|
|
|
2019-12-02 08:12:38 +01:00
|
|
|
- name: Generate password protected key
|
|
|
|
command: 'ssh-keygen -f {{ output_dir }}/privatekey8 -N password'
|
|
|
|
|
2020-02-02 13:54:28 +01:00
|
|
|
- name: Try to modify the password protected key - should fail
|
2019-12-02 08:12:38 +01:00
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey8'
|
|
|
|
register: privatekey8_result
|
2020-02-02 13:54:28 +01:00
|
|
|
ignore_errors: yes
|
|
|
|
|
|
|
|
- name: Try to modify the password protected key with force=yes
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/privatekey8'
|
|
|
|
force: yes
|
|
|
|
register: privatekey8_result_force
|
2019-12-02 08:12:38 +01:00
|
|
|
|
2018-10-24 12:51:45 +02:00
|
|
|
- import_tasks: ../tests/validate.yml
|
2020-02-15 15:39:36 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Test regenerate option
|
|
|
|
|
|
|
|
- name: Regenerate - setup simple keys
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
- name: Regenerate - setup password protected keys
|
|
|
|
command: 'ssh-keygen -f {{ output_dir }}/regenerate-b-{{ item }} -N password'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
- name: Regenerate - setup broken keys
|
|
|
|
copy:
|
|
|
|
dest: '{{ output_dir }}/regenerate-c-{{ item.0 }}{{ item.1 }}'
|
|
|
|
content: 'broken key'
|
|
|
|
mode: '0700'
|
|
|
|
with_nested:
|
|
|
|
- "{{ regenerate_values }}"
|
|
|
|
- [ '', '.pub' ]
|
|
|
|
|
|
|
|
- name: Regenerate - modify broken keys (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-c-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[0].msg"
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[2].msg"
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - modify broken keys
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-c-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[0].msg"
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[2].msg"
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - modify password protected keys (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-b-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[0].msg"
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[2].msg"
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - modify password protected keys
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-b-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[0].msg"
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is failed
|
|
|
|
- "'Unable to read the key. The key is protected with a passphrase or broken. Will not proceed.' in result.results[2].msg"
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - not modify regular keys (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is not changed
|
|
|
|
- result.results[1] is not changed
|
|
|
|
- result.results[2] is not changed
|
|
|
|
- result.results[3] is not changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - not modify regular keys
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is not changed
|
|
|
|
- result.results[1] is not changed
|
|
|
|
- result.results[2] is not changed
|
|
|
|
- result.results[3] is not changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - adjust key size (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1048
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is success and result.results[0] is not changed
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Key has wrong type and/or size. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is changed
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - adjust key size
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: rsa
|
|
|
|
size: 1048
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is success and result.results[0] is not changed
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Key has wrong type and/or size. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is changed
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - redistribute keys
|
|
|
|
copy:
|
|
|
|
src: '{{ output_dir }}/regenerate-a-always{{ item.1 }}'
|
|
|
|
dest: '{{ output_dir }}/regenerate-a-{{ item.0 }}{{ item.1 }}'
|
|
|
|
remote_src: true
|
|
|
|
with_nested:
|
|
|
|
- "{{ regenerate_values }}"
|
|
|
|
- [ '', '.pub' ]
|
|
|
|
when: "item.0 != 'always'"
|
|
|
|
|
|
|
|
- name: Regenerate - adjust key type (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: dsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is success and result.results[0] is not changed
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Key has wrong type and/or size. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is changed
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - adjust key type
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: dsa
|
|
|
|
size: 1024
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.results[0] is success and result.results[0] is not changed
|
|
|
|
- result.results[1] is failed
|
|
|
|
- "'Key has wrong type and/or size. Will not proceed.' in result.results[1].msg"
|
|
|
|
- result.results[2] is changed
|
|
|
|
- result.results[3] is changed
|
|
|
|
- result.results[4] is changed
|
|
|
|
|
|
|
|
- name: Regenerate - redistribute keys
|
|
|
|
copy:
|
|
|
|
src: '{{ output_dir }}/regenerate-a-always{{ item.1 }}'
|
|
|
|
dest: '{{ output_dir }}/regenerate-a-{{ item.0 }}{{ item.1 }}'
|
|
|
|
remote_src: true
|
|
|
|
with_nested:
|
|
|
|
- "{{ regenerate_values }}"
|
|
|
|
- [ '', '.pub' ]
|
|
|
|
when: "item.0 != 'always'"
|
|
|
|
|
|
|
|
- name: Regenerate - adjust comment (check mode)
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: dsa
|
|
|
|
size: 1024
|
|
|
|
comment: test comment
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
check_mode: yes
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
ignore_errors: yes
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
|
|
|
|
- name: Regenerate - adjust comment
|
|
|
|
openssh_keypair:
|
|
|
|
path: '{{ output_dir }}/regenerate-a-{{ item }}'
|
|
|
|
type: dsa
|
|
|
|
size: 1024
|
|
|
|
comment: test comment
|
|
|
|
regenerate: '{{ item }}'
|
|
|
|
loop: "{{ regenerate_values }}"
|
|
|
|
register: result
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
# for all values but 'always', the key should have not been regenerated.
|
|
|
|
# verify this by comparing fingerprints:
|
|
|
|
- result.results[0].fingerprint == result.results[1].fingerprint
|
|
|
|
- result.results[0].fingerprint == result.results[2].fingerprint
|
|
|
|
- result.results[0].fingerprint == result.results[3].fingerprint
|
|
|
|
- result.results[0].fingerprint != result.results[4].fingerprint
|