mirror of
https://github.com/trailofbits/algo.git
synced 2025-04-11 11:47:08 +02:00
* bump ansible to 2.8.3 * DigitalOcean: move to the latest modules * Add Hetzner Cloud * Scaleway and Lightsail fixes * lint missing roles * Update roles/cloud-hetzner/tasks/main.yml Add api_token Co-Authored-By: phaer <phaer@phaer.org> * Update roles/cloud-hetzner/tasks/main.yml Add api_token Co-Authored-By: phaer <phaer@phaer.org> * Try to run apt until succeeded * Scaleway modules upgrade * GCP: Refactoring, remove deprecated modules * Doc updates (#1552) * Update README.md Adding links and mentions of Exoscale aka CloudStack and Hetzner Cloud. * Update index.md Add the Hetzner Cloud to the docs index * Remove link to Win 10 IPsec instructions * Delete client-windows.md Unnecessary since the deprecation of IPsec for Win10. * Update deploy-from-ansible.md Added sections and required variables for CloudStack and Hetzner Cloud. * Update deploy-from-ansible.md Added sections for CloudStack and Hetzner, added req variables and examples, mentioned environment variables, and added links to the provider role section. * Update deploy-from-ansible.md Cosmetic changes to links, fix typo. * Update GCE variables * Update deploy-from-script-or-cloud-init-to-localhost.md Fix a finer point, and make variables list more readable. * update azure requirements * Python3 draft * set LANG=c to the p12 password generation task * Update README * Install cloud requirements to the existing venv * FreeBSD fix * env->.env fixes * lightsail_region_facts fix * yaml syntax fix * Update README for Python 3 (#1564) * Update README for Python 3 * Remove tabs and tweak instructions * Remove cosmetic command indentation * Update README.md * Update README for Python 3 (#1565) * DO fix for "found unpermitted parameters: id" * Verify Python version * Remove ubuntu 16.04 from readme * Revert back DigitalOcean module * Update deploy-from-script-or-cloud-init-to-localhost.md * env to .env
52 lines
1.8 KiB
YAML
52 lines
1.8 KiB
YAML
---
|
|
- name: Set subjectAltName as a fact
|
|
set_fact:
|
|
IP_subject_alt_name: "{{ (IP_subject_alt_name if algo_provider == 'local' else cloud_instance_ip) | lower }}"
|
|
|
|
- name: Add the server to an inventory group
|
|
add_host:
|
|
name: "{% if cloud_instance_ip == 'localhost' %}localhost{% else %}{{ cloud_instance_ip }}{% endif %}"
|
|
groups: vpn-host
|
|
ansible_connection: "{% if cloud_instance_ip == 'localhost' %}local{% else %}ssh{% endif %}"
|
|
ansible_ssh_user: "{{ ansible_ssh_user }}"
|
|
ansible_python_interpreter: "/usr/bin/python3"
|
|
algo_provider: "{{ algo_provider }}"
|
|
algo_server_name: "{{ algo_server_name }}"
|
|
algo_ondemand_cellular: "{{ algo_ondemand_cellular }}"
|
|
algo_ondemand_wifi: "{{ algo_ondemand_wifi }}"
|
|
algo_ondemand_wifi_exclude: "{{ algo_ondemand_wifi_exclude }}"
|
|
algo_dns_adblocking: "{{ algo_dns_adblocking }}"
|
|
algo_ssh_tunneling: "{{ algo_ssh_tunneling }}"
|
|
algo_store_pki: "{{ algo_store_pki }}"
|
|
IP_subject_alt_name: "{{ IP_subject_alt_name }}"
|
|
|
|
- name: Additional variables for the server
|
|
add_host:
|
|
name: "{% if cloud_instance_ip == 'localhost' %}localhost{% else %}{{ cloud_instance_ip }}{% endif %}"
|
|
ansible_ssh_private_key_file: "{{ SSH_keys.private }}"
|
|
when: algo_provider != 'local'
|
|
|
|
- name: Wait until SSH becomes ready...
|
|
wait_for:
|
|
port: 22
|
|
host: "{{ cloud_instance_ip }}"
|
|
search_regex: "OpenSSH"
|
|
delay: 10
|
|
timeout: 320
|
|
state: present
|
|
when: cloud_instance_ip != "localhost"
|
|
|
|
- name: Mount tmpfs
|
|
import_tasks: tmpfs/main.yml
|
|
when:
|
|
- pki_in_tmpfs
|
|
- not algo_store_pki
|
|
- ansible_system == "Darwin" or
|
|
ansible_system == "Linux"
|
|
|
|
- debug:
|
|
var: IP_subject_alt_name
|
|
|
|
- name: A short pause, in order to be sure the instance is ready
|
|
pause:
|
|
seconds: 20
|