2022-08-05 14:03:38 +02:00
|
|
|
---
|
|
|
|
# Copyright (c) Ansible Project
|
|
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: Check name of gpg2 binary
|
|
|
|
command: which gpg2
|
|
|
|
register: gpg2_check
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: Set gpg2 binary name
|
|
|
|
set_fact:
|
|
|
|
gpg2_bin: '{{ "gpg2" if gpg2_check is successful else "gpg" }}'
|
|
|
|
|
|
|
|
- name: Stop gpg-agent so we can remove any locks on the GnuPG dir
|
|
|
|
command: gpgconf --kill gpg-agent
|
2023-02-15 22:55:23 +01:00
|
|
|
ignore_errors: true
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
- name: Remove previous password files and directory
|
|
|
|
file:
|
|
|
|
dest: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
loop:
|
|
|
|
- "~/.gnupg"
|
|
|
|
- "~/.password-store"
|
|
|
|
|
2022-06-15 08:08:04 +02:00
|
|
|
- name: Get path of pass executable
|
|
|
|
command: which pass
|
|
|
|
register: result
|
|
|
|
|
|
|
|
- name: Store path of pass executable
|
|
|
|
set_fact:
|
|
|
|
passpath: "{{ result.stdout }}"
|
|
|
|
|
|
|
|
- name: Move original pass into place if there was a leftover
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ passpath }}.testorig"
|
|
|
|
- "{{ passpath }}"
|
|
|
|
args:
|
|
|
|
removes: "{{ passpath }}.testorig"
|
|
|
|
|
|
|
|
# having gopass is not required for this test, but we store
|
|
|
|
# its path in case it is installed, so we can restore it
|
|
|
|
- name: Try to find gopass in path
|
|
|
|
command: which gopass
|
|
|
|
register: result
|
|
|
|
|
|
|
|
- name: Store path of gopass executable
|
|
|
|
set_fact:
|
2022-07-31 22:13:27 +02:00
|
|
|
gopasspath: "{{ result.stdout }}"
|
2022-06-15 08:08:04 +02:00
|
|
|
|
|
|
|
- name: Move original gopass into place if there was a leftover
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ gopasspath }}.testorig"
|
|
|
|
- "{{ gopasspath }}"
|
|
|
|
args:
|
|
|
|
removes: "{{ gopasspath }}.testorig"
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Get versions of tools
|
|
|
|
command: "{{ item }} --version"
|
|
|
|
register: versions
|
|
|
|
loop:
|
|
|
|
- "{{ gpg2_bin }}"
|
|
|
|
- pass
|
|
|
|
- gopass
|
|
|
|
|
|
|
|
- name: Output versions of tools
|
|
|
|
debug:
|
|
|
|
msg: "{{ versions.results | map(attribute='stdout_lines') }}"
|
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
# How to generate a new GPG key:
|
|
|
|
# gpg2 --batch --gen-key input # See templates/input
|
|
|
|
# gpg2 --list-secret-keys --keyid-format LONG
|
|
|
|
# gpg2 --armor --export-secret-keys [key id]
|
|
|
|
# # Get the fingerprint
|
|
|
|
# gpg2 --fingerprint --keyid-format LONG | grep [key id] -A 1 | tail -1 | tr -d '[:space:]' | awk -F '=' '{print $2":6:"}'
|
|
|
|
|
|
|
|
- name: Import GPG private key
|
|
|
|
shell: echo "{{ passwordstore_privkey }}" | {{ gpg2_bin }} --import --allow-secret-key-import -
|
|
|
|
|
|
|
|
- name: Trust key
|
|
|
|
shell: echo "D3E1CC8934E97270CEB066023AF1BD3619AB496A:6:" | {{ gpg2_bin }} --import-ownertrust
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Initialise pass passwordstore
|
2020-03-09 09:11:07 +00:00
|
|
|
command: pass init ansible-test
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Initialise gopass passwordstore
|
|
|
|
command: gopass init --path $HOME/.gopass-store ansible-test
|
|
|
|
args:
|
|
|
|
creates: "{{ lookup('env','HOME') }}/.gopass-store"
|
2022-06-15 08:08:04 +02:00
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
# these tests should apply to all backends
|
|
|
|
- name: Password tests
|
|
|
|
include_tasks: password_tests.yml
|
|
|
|
loop:
|
|
|
|
- pass
|
|
|
|
- gopass
|
|
|
|
loop_control:
|
|
|
|
loop_var: backend
|
2022-06-15 08:08:04 +02:00
|
|
|
|
|
|
|
- name: Change passwordstore location explicitly
|
|
|
|
set_fact:
|
|
|
|
passwordstore: "{{ lookup('env','HOME') }}/.password-store"
|
|
|
|
|
|
|
|
- name: Make sure password store still works with explicit location set
|
|
|
|
set_fact:
|
|
|
|
newpass: "{{ lookup('community.general.passwordstore', 'test-pass') }}"
|
|
|
|
|
|
|
|
- name: Change passwordstore location to a non-existent place
|
|
|
|
set_fact:
|
|
|
|
passwordstore: "somenonexistentplace"
|
|
|
|
|
|
|
|
- name: Try reading from non-existent passwordstore location
|
|
|
|
set_fact:
|
|
|
|
newpass: "{{ lookup('community.general.passwordstore', 'test-pass') }}"
|
|
|
|
ignore_errors: true
|
|
|
|
register: eval_error
|
|
|
|
|
|
|
|
- name: Make sure reading from non-existent passwordstore location failed
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- eval_error is failed
|
|
|
|
- >-
|
2022-11-02 20:17:08 +01:00
|
|
|
"Passwordstore directory '" in eval_error.msg
|
|
|
|
- >-
|
|
|
|
"/somenonexistentplace' does not exist" in eval_error.msg
|
2022-06-15 08:08:04 +02:00
|
|
|
|
|
|
|
- name: Test pass compatibility shim detection
|
|
|
|
block:
|
|
|
|
- name: Move original pass out of the way
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ passpath }}"
|
|
|
|
- "{{ passpath }}.testorig"
|
|
|
|
args:
|
|
|
|
creates: "{{ passpath }}.testorig"
|
|
|
|
|
|
|
|
- name: Create dummy pass script
|
|
|
|
ansible.builtin.copy:
|
|
|
|
content: |
|
|
|
|
#!/bin/sh
|
|
|
|
echo "shim_ok"
|
|
|
|
dest: "{{ passpath }}"
|
|
|
|
mode: '0755'
|
|
|
|
|
|
|
|
- name: Try reading from non-existent passwordstore location with different pass utility
|
|
|
|
set_fact:
|
|
|
|
newpass: "{{ lookup('community.general.passwordstore', 'test-pass') }}"
|
|
|
|
environment:
|
|
|
|
PATH: "/tmp"
|
|
|
|
|
|
|
|
- name: Verify password received from shim
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- newpass == "shim_ok"
|
|
|
|
|
|
|
|
- name: Try to read folder as passname with a different pass utility
|
|
|
|
set_fact:
|
|
|
|
newpass: "{{ lookup('community.general.passwordstore', 'folder') }}"
|
|
|
|
|
|
|
|
- name: Verify password received from shim
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- newpass == "shim_ok"
|
|
|
|
|
|
|
|
always:
|
|
|
|
- name: Move original pass back into place
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ passpath }}.testorig"
|
|
|
|
- "{{ passpath }}"
|
|
|
|
args:
|
|
|
|
removes: "{{ passpath }}.testorig"
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
# This are in addition to the real gopass tests above
|
|
|
|
# and verify plugin logic
|
|
|
|
- name: gopass plugin logic tests
|
2022-06-15 08:08:04 +02:00
|
|
|
vars:
|
|
|
|
passwordstore_backend: "gopass"
|
|
|
|
block:
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Check if gopass executable exists
|
2022-06-15 08:08:04 +02:00
|
|
|
stat:
|
|
|
|
path: "{{ gopasspath }}"
|
|
|
|
register: gopass_check
|
|
|
|
|
|
|
|
- name: Move original gopass out of the way
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ gopasspath }}"
|
|
|
|
- "{{ gopasspath }}.testorig"
|
|
|
|
args:
|
|
|
|
creates: "{{ gopasspath }}.testorig"
|
|
|
|
when: gopass_check.stat.exists == true
|
|
|
|
|
|
|
|
- name: Create mocked gopass script
|
|
|
|
ansible.builtin.copy:
|
|
|
|
content: |
|
|
|
|
#!/bin/sh
|
|
|
|
if [ "$GOPASS_NO_REMINDER" != "YES" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
if [ "$1" = "--version" ]; then
|
|
|
|
exit 2
|
|
|
|
fi
|
|
|
|
echo "gopass_ok"
|
|
|
|
dest: "{{ gopasspath }}"
|
|
|
|
mode: '0755'
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Try to read folder as passname using gopass mock
|
2022-06-15 08:08:04 +02:00
|
|
|
set_fact:
|
|
|
|
newpass: "{{ lookup('community.general.passwordstore', 'folder') }}"
|
|
|
|
|
2022-07-31 22:13:27 +02:00
|
|
|
- name: Verify password received from gopass mock
|
2022-06-15 08:08:04 +02:00
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- newpass == "gopass_ok"
|
|
|
|
|
|
|
|
always:
|
|
|
|
- name: Remove mocked gopass
|
|
|
|
ansible.builtin.file:
|
|
|
|
path: "{{ gopasspath }}"
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: Move original gopass back into place
|
|
|
|
command:
|
|
|
|
argv:
|
|
|
|
- mv
|
|
|
|
- "{{ gopasspath }}.testorig"
|
|
|
|
- "{{ gopasspath }}"
|
|
|
|
args:
|
|
|
|
removes: "{{ gopasspath }}.testorig"
|
|
|
|
when: gopass_check.stat.exists == true
|