a773bd7ad5
Currently the check() method for idempotence only assumes the public key is under the form of a PEM file when its not always the case. The module openssl_publickey allows one to generate OpenSSH format publickey. This leads to idempotence not being detected.
71 lines
2.6 KiB
YAML
71 lines
2.6 KiB
YAML
- block:
|
|
- name: Generate privatekey
|
|
openssl_privatekey:
|
|
path: '{{ output_dir }}/privatekey.pem'
|
|
|
|
- name: Generate publickey - PEM format
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
|
|
- name: Generate publickey - OpenSSH format
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey-ssh.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
format: OpenSSH
|
|
# cryptography.hazmat.primitives import serialization.Encoding.OpenSSH and
|
|
# cryptography.hazmat.primitives import serialization.PublicFormat.OpenSSH constants
|
|
# appeared in version 1.4 of cryptography
|
|
when: cryptography_version.stdout is version('1.4.0', '>=')
|
|
|
|
- name: Generate publickey - OpenSSH format - test idempotence (issue 33256)
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey-ssh.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
format: OpenSSH
|
|
when: cryptography_version.stdout|version_compare('1.4.0', '>=')
|
|
register: publickey_ssh_idempotence
|
|
|
|
- name: Generate publickey2 - standard
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey2.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
|
|
- name: Delete publickey2 - standard
|
|
openssl_publickey:
|
|
state: absent
|
|
path: '{{ output_dir }}/publickey2.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
|
|
- name: Generate privatekey3 - with passphrase
|
|
openssl_privatekey:
|
|
path: '{{ output_dir }}/privatekey3.pem'
|
|
passphrase: ansible
|
|
cipher: aes256
|
|
|
|
- name: Generate publickey3 - with passphrase protected privatekey
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey3.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey3.pem'
|
|
privatekey_passphrase: ansible
|
|
|
|
- name: Generate publickey3 - with passphrase protected privatekey - idempotence
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey3.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey3.pem'
|
|
privatekey_passphrase: ansible
|
|
register: publickey3_idempotence
|
|
|
|
- name: Generate empty file that will hold a public key (issue 33072)
|
|
file:
|
|
path: '{{ output_dir }}/publickey4.pub'
|
|
state: touch
|
|
|
|
- name: Generate publickey in empty existing file (issue 33072)
|
|
openssl_publickey:
|
|
path: '{{ output_dir }}/publickey4.pub'
|
|
privatekey_path: '{{ output_dir }}/privatekey.pem'
|
|
|
|
- import_tasks: ../tests/validate.yml
|
|
|
|
when: pyopenssl_version.stdout is version('16.0.0', '>=')
|