due to refactor, shortened and renamed file to only take care of spawning the server and adding SSH public keys to root user account
This commit is contained in:
91
roles/init-server/tasks/spawn.yml
Normal file
91
roles/init-server/tasks/spawn.yml
Normal file
@@ -0,0 +1,91 @@
|
||||
#SPDX-License-Identifier: MIT-0
|
||||
---
|
||||
# tasks file for roles/init-vps
|
||||
# @NOTE server deployment method is based on task tags compiled herein
|
||||
# @TODO review 'loop' task attribute return values and make compliant changes
|
||||
- name: Finding SSH public keys for root
|
||||
ansible.builtin.find:
|
||||
paths: "{{ cnode_homedir | default('/home/' ~ ansible_user ~ '/.ssh') }}" # @TODO define 'cnode_homedir' in playbook
|
||||
patterns: "{{ ['^'] | product(keys) | map('join') | list }}"
|
||||
file_type: file
|
||||
use_regex: true
|
||||
register: ssh_keypairs
|
||||
- name: Bootstrapping VPS
|
||||
block:
|
||||
- name: Creating VPS via Linode VPS service API
|
||||
block:
|
||||
- name: Creating the VPS
|
||||
linode.cloud.instance:
|
||||
api_token: "{{ token }}"
|
||||
label: "{{ instance }}"
|
||||
type: g6-standard-2
|
||||
image: "{{ operating_system }}"
|
||||
disk_encryption: enabled
|
||||
region: "{{ origin }}"
|
||||
private_ip: true
|
||||
root_pass: "{{ password }}"
|
||||
authorized_keys: "{{ ssh_keypairs.files | selectattr('path', 'search', '\\.pub$') | map(attribute='path') | map('lookup', 'file') | list }}"
|
||||
state: present
|
||||
register: new_instance
|
||||
- name: Waiting for that VPS to come online
|
||||
delegate_to: "{{ new_instance.instance[ip_pref][0] }}"
|
||||
delegate_facts: true
|
||||
ansible.builtin.wait_for_connection:
|
||||
delay: 20
|
||||
timeout: 300
|
||||
vars:
|
||||
ansible_ssh_private_key_file: "{{ chosen_privkey | default(ssh_keypairs.files | rejectattr('path', 'search', '\\.pub$') | map(attribute='path') | list | random) }}" # @TODO define 'chosen_privkey'in playbook
|
||||
ansible_user: root
|
||||
tags:
|
||||
- linode
|
||||
tags:
|
||||
- vps
|
||||
- name: Bootstrapping homeserver
|
||||
block:
|
||||
- name: Installing operating system or distro in server
|
||||
when: operating_system != None
|
||||
block:
|
||||
- name: Creating a server
|
||||
block: []
|
||||
tags:
|
||||
- unimplemented
|
||||
- name: Waiting for that server to come online
|
||||
delegate_to: "{{ hostvars[instance]['ansible_default_' ~ ip_pref].address }}"
|
||||
delegate_facts: true
|
||||
remote_user: root
|
||||
ansible.builtin.wait_for_connection:
|
||||
delay: 20
|
||||
timeout: 300
|
||||
vars:
|
||||
ansible_user: root
|
||||
- name: Checking if that server has required operating system
|
||||
delegate_to: "{{ hostvars[instance]['ansible_default_' ~ ip_pref].address }}"
|
||||
delegate_facts: true
|
||||
remote_user: root
|
||||
when: ansible_facts["system"] != "Linux"
|
||||
ansible.builtin.fail:
|
||||
msg: Unsupported operating system found
|
||||
vars:
|
||||
ansible_user: root
|
||||
- name: Checking if that server has required Linux distro
|
||||
delegate_to: "{{ hostvars[instance]['ansible_default_' ~ ip_pref].address }}"
|
||||
delegate_facts: true
|
||||
remote_user: root
|
||||
when: ansible_facts["system"] == "Linux" and ansible_facts["os_family"] != "Debian"
|
||||
ansible.builtin.fail:
|
||||
msg: Unsupported Linux distro found
|
||||
vars:
|
||||
ansible_user: root
|
||||
- name: Providing authorized keys for server root account
|
||||
delegate_to: "{{ hostvars[instance]['ansible_default_' ~ ip_pref].address }}"
|
||||
delegate_facts: true
|
||||
remote_user: root
|
||||
ansible.posix.authorized_key:
|
||||
user: "{{ ansible_user }}"
|
||||
key: "{{ lookup('file', item) }}"
|
||||
state: present
|
||||
vars:
|
||||
ansible_root: root
|
||||
loop: "{{ ssh_keypairs.files | selectattr('path', 'search', '\\.pub$') | map(attribute='path') | list }}"
|
||||
tags:
|
||||
- lan
|
||||
Reference in New Issue
Block a user