Compare commits
2 Commits
28123cf513
...
97802668da
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
97802668da
|
||
|
|
c551192d2c
|
@@ -1,5 +1,6 @@
|
||||
---
|
||||
- name: Acquire GPG private keys from other system
|
||||
when: not files_mode
|
||||
delegate_to: "{{ gpg_private_keys_origin_host }}"
|
||||
ansible.builtin.command:
|
||||
argv:
|
||||
@@ -12,7 +13,7 @@
|
||||
- name: Create GPG private keys
|
||||
ansible.builtin.copy:
|
||||
content: "{{ item }}"
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.gnupg/{{ ansible_facts['user_dir'] }}-{{ idx }}.priv.asc"
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.gnupg/{{ ansible_facts['user_id'] }}-{{ idx }}.priv.asc"
|
||||
force: yes
|
||||
backup: yes
|
||||
mode: "0600"
|
||||
|
||||
@@ -22,6 +22,24 @@
|
||||
prompt: Enter space-wrapped colon -separated list of GPG private key passwords
|
||||
unsafe: yes
|
||||
private: yes
|
||||
- name: gpg_or_ssh_git_signing
|
||||
prompt: Enter preferred signing key type (e.g., ssh or gpg)
|
||||
unsafe: yes
|
||||
private: no
|
||||
default: "ssh"
|
||||
- name: gpg_preferred_signing
|
||||
prompt: Enter index or number of preferred signing key (negative number for random)
|
||||
unsafe: yes
|
||||
private: no
|
||||
default: -1
|
||||
- name: git_config_name
|
||||
prompt: Enter name for your git configuration
|
||||
unsafe: yes
|
||||
private: no
|
||||
- name: git_config_email
|
||||
prompt: Enter email for your git configuration
|
||||
unsafe: yes
|
||||
private: no
|
||||
tasks:
|
||||
- name: Disable shell access for root
|
||||
ansible.builtin.include_role:
|
||||
@@ -179,5 +197,133 @@
|
||||
tags:
|
||||
- default
|
||||
- import_gpg_privkeys
|
||||
|
||||
|
||||
# @TODO separate below task as lockdown role task, and maybe associated variables to lockdown role defaults/vars dirs
|
||||
# @NOTE below depends on variable 'gpg_signing_key' and 'gpg_or_ssh_git_signing' from 'vars_prompt' playbook field
|
||||
# @NOTE below depends on variable 'gpg_origin_private_keyids' and 'files_mode' found in lockdown role defaults/vars dirs
|
||||
- name: Install and configure git
|
||||
block:
|
||||
- name: Install git package
|
||||
ansible.builtin.package:
|
||||
name: git
|
||||
state: latest
|
||||
- name: Configure git installation
|
||||
block:
|
||||
- name: Configure git name
|
||||
community.general.git_config:
|
||||
name: user.name
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ git_config_name }}"
|
||||
- name: Configure git email
|
||||
community.general.git_config:
|
||||
name: user.email
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ git_config_email }}"
|
||||
- name: Configure git signing key
|
||||
block:
|
||||
- name: Configure git signing GPG key
|
||||
when: gpg_or_ssh_git_signing == "gpg"
|
||||
block:
|
||||
- name: Configure specified git signing GPG key
|
||||
when: gpg_preferred_signing > -1
|
||||
community.general.git_config:
|
||||
name: user.signingkey
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ gpg_origin_private_keyids[gpg_preferred_signing] }}"
|
||||
- name: Configure random git signing GPG key
|
||||
when: gpg_preferred_signing <= -1
|
||||
community.general.git_config:
|
||||
name: user.signingkey
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ gpg_origin_private_keyids | random }}"
|
||||
register: randomized_gpg_key_preference
|
||||
- name: Configure git signing SSH key
|
||||
when: gpg_or_ssh_git_signing == "ssh"
|
||||
block:
|
||||
- name: Acquire SSH key-pairs from other system
|
||||
when: not files_mode
|
||||
block:
|
||||
- name: Acquire private SSH keys from other system
|
||||
delegate_to: "{{ ssh_keypairs_origin_host }}" # @TODO variable needs declaration/definition
|
||||
ansible.builtin.command:
|
||||
argv:
|
||||
- cat
|
||||
- ~/.ssh/"{{ item }}.ppk"
|
||||
loop: "{{ ssh_origin_keypairs_paths }}" # @TODO variable needs declaration/definition--should have max 2 items each without file extension, with private and then public keys having same basename
|
||||
register: ssh_secrets
|
||||
- name: Find SSH public keys in other system
|
||||
delegate_to: "{{ ssh_keypairs_origin_host }}" # @TODO variable needs declaration/definition
|
||||
ansible.builtin.command:
|
||||
argv:
|
||||
- cat
|
||||
- ~/.ssh/"{{ item }}.pub"
|
||||
loop: "{{ ssh_origin_keypairs_paths }}" # @TODO variable needs declaration/definition--should have max 2 items each without file extension, with private and then public keys having same basename
|
||||
register: ssh_nonsecrets
|
||||
- name: Create private SSH keys
|
||||
ansible.builtin.copy:
|
||||
content: "{{ item }}"
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.ssh/id_ed25519_git.ppk"
|
||||
force: yes
|
||||
backup: yes
|
||||
mode: "0600"
|
||||
state: present
|
||||
loop: "{{ ssh_secrets.results }}"
|
||||
register: created_ssh_private_keys
|
||||
- name: Create public SSH keys
|
||||
ansible.builtin.copy:
|
||||
content: "{{ item }}"
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.ssh/id_ed25519_git.pub"
|
||||
force: yes
|
||||
backup: yes
|
||||
mode: "0644"
|
||||
state: present
|
||||
loop: "{{ ssh_nonsecrets.results }}"
|
||||
register: created_ssh_public_keys
|
||||
- name: Acquire SSH key-pairs
|
||||
when: files_mode
|
||||
block:
|
||||
- name: Transfer private SSH keys
|
||||
ansible.builtin.copy:
|
||||
src: files/all/ssh/id_ed25519_git.ppk # @TODO change path if and when moved into lockdown role task file and create corresponding file in lockdown role files dir
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.ssh/id_ed25519_git.ppk"
|
||||
force: yes
|
||||
backup: yes
|
||||
mode: "0600"
|
||||
state: present
|
||||
register: created_ssh_private_key
|
||||
- name: Transfer public SSH keys
|
||||
ansible.builtin.copy:
|
||||
src: files/all/ssh/id_ed25519_git.pub # @TODO change path if and when moved into lockdown role task file and create corresponding file in lockdown role files dir
|
||||
dest: "{{ ansible_facts['user_dir'] }}/.ssh/id_ed25519_git.pub"
|
||||
force: yes
|
||||
backup: yes
|
||||
mode: "0644"
|
||||
state: present
|
||||
register: created_ssh_public_key
|
||||
- name: Configure acquired, specified SSH public key as git signing key
|
||||
when: ssh_preferred_signing > -1 and not files_mode
|
||||
community.general.git_config:
|
||||
name: user.signingkey
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ created_ssh_public_keys.results[ssh_preferred_signing] }}" # @TODO this variable needs declaration/definition
|
||||
- name: Configure acquired, random SSH public key as git signing key
|
||||
when: ssh_preferred_signing <= -1 and not files_mode
|
||||
community.general.git_config:
|
||||
name: user.signingkey
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ created_ssh_public_keys.results | random }}" # @TODO this variable needs declaration/definition
|
||||
register: randomized_ssh_pubkey_preference
|
||||
- name: Configure transferred SSH public key as git signing key
|
||||
when: ssh_preferred_signing <= -1 and files_mode
|
||||
community.general.git_config:
|
||||
name: user.signingkey
|
||||
scope: global
|
||||
state: present
|
||||
value: "{{ created_ssh_public_key.dest }}"
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user