mirror of
https://github.com/kasmtech/ansible
synced 2025-01-24 09:05:01 +00:00
111 lines
3 KiB
YAML
111 lines
3 KiB
YAML
- include_tasks:
|
|
file: default_credentials.yml
|
|
|
|
- name: Check if Kasm is installed
|
|
stat:
|
|
path: /opt/kasm/current
|
|
register: kasm_path
|
|
|
|
- assert:
|
|
that:
|
|
- not kasm_path.stat.exists
|
|
fail_msg: /opt/kasm/current exists, kasm appears to be installed. Please ensure kasm is uninstalled before continuing.
|
|
|
|
- set_fact:
|
|
db_ip: "{{ hostvars[groups['db'][0]]['ansible_default_ipv4']['address'] }}"
|
|
web_ip: "{{ hostvars[groups['web'][0]]['ansible_default_ipv4']['address'] }}"
|
|
# IP of the host that ansible is being ran against
|
|
target_ip: "{{ ansible_default_ipv4.address }}"
|
|
|
|
- name: Override manager hostname if configured
|
|
set_fact:
|
|
web_ip: "{{ manager_hostname }}"
|
|
when: manager_hostname is defined
|
|
|
|
- name: Check if kasm swapfile exists
|
|
stat:
|
|
path: /mnt/kasm.swap
|
|
register: kasm_swapfile
|
|
|
|
- name: Get current swapsize in bytes
|
|
# Meminfo outputs in Kb for some reason so we convert to bytes
|
|
shell: cat /proc/meminfo | grep SwapTotal | awk '{print $2 * 1024}'
|
|
register: current_swap_size
|
|
|
|
- set_fact:
|
|
# We only want to make a swapfile large enough to make up the difference between
|
|
# the current swapsize and our desired size.
|
|
new_swap_size: "{{ desired_swap_size | human_to_bytes - current_swap_size.stdout | int }}"
|
|
|
|
- debug:
|
|
var: new_swap_size
|
|
|
|
- name: Run swap tasks
|
|
include_tasks:
|
|
file: mkswap.yml
|
|
when:
|
|
- new_swap_size | int > 0
|
|
- not kasm_swapfile.stat.exists
|
|
|
|
- name: Create temporary directory
|
|
tempfile:
|
|
state: directory
|
|
register: tempdir
|
|
|
|
# Debian 10 doesn't ship with the ca-certificates package installed by default
|
|
# installing curl is portable to to ensure that ca-certificates is installed
|
|
- name: Ensure we have curl installed
|
|
package:
|
|
name: curl
|
|
state: present
|
|
become: true
|
|
|
|
- name: Download kasm installer
|
|
get_url:
|
|
url: "{{ kasm_installer_url }}"
|
|
dest: "{{ tempdir.path }}/kasm.tar.gz"
|
|
checksum: "{{ kasm_installer_checksum }}"
|
|
register: kasm_installer
|
|
|
|
- name: unarchive kasm installer
|
|
unarchive:
|
|
remote_src: yes
|
|
src: "{{ kasm_installer.dest }}"
|
|
dest: "{{ tempdir.path }}"
|
|
|
|
- name: Run Kasm db install tasks
|
|
include_tasks:
|
|
file: db_install.yml
|
|
when: "'db' in group_names"
|
|
|
|
- name: Run Kasm web install tasks
|
|
include_tasks:
|
|
file: web_install.yml
|
|
when: "'web' in group_names"
|
|
|
|
- name: Run Kasm agent install tasks
|
|
include_tasks:
|
|
file: agent_install.yml
|
|
when: "'agent' in group_names"
|
|
|
|
- name: enable the docker service to run at boot
|
|
service:
|
|
name: docker
|
|
enabled: true
|
|
become: true
|
|
when: start_docker_on_boot
|
|
|
|
- name: Delete temporary directory
|
|
file:
|
|
path: "{{ tempdir.path }}"
|
|
state: absent
|
|
|
|
- name: Print credentials
|
|
debug:
|
|
msg:
|
|
- "Database Password: {{ database_password }}"
|
|
- "Redis Password: {{ redis_password }}"
|
|
- "Manager Token: {{ manager_token }}"
|
|
- "user@kasm.local password: {{ user_password }}"
|
|
- "admin@kasm.local password: {{ admin_password }}"
|
|
run_once: true
|