Ansible role for XOA installation or update using sources
This commit is contained in:
parent
bfc606a207
commit
53a0132680
|
@ -0,0 +1,15 @@
|
||||||
|
# defaults file
|
||||||
|
# The default username and password are applied, and admin for the password
|
||||||
|
xoa_install_url: https://raw.githubusercontent.com/Jarli01/xenorchestra_installer/master/xo_install.sh
|
||||||
|
xoa_install_script: xo_install.sh
|
||||||
|
xoa_update_url: https://raw.githubusercontent.com/Jarli01/xenorchestra_updater/master/xo-update.sh
|
||||||
|
xoa_update_script: xo_update.sh
|
||||||
|
git_email: ""
|
||||||
|
git_user: ""
|
||||||
|
xoa_default_user: "admin@admin.net"
|
||||||
|
xoa_default_password: "admin"
|
||||||
|
xoa_user: xoa
|
||||||
|
xoa_password: xoa
|
||||||
|
xcpng_servers: [{"label": "localhost", "ip": "127.0.1"}]
|
||||||
|
xcpng_user: root
|
||||||
|
xcpng_password: xcpng
|
|
@ -0,0 +1,22 @@
|
||||||
|
- name: reload_systemd
|
||||||
|
shell: systemctl daemon-reload
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
|
||||||
|
- name: cleaning_packages_metadata
|
||||||
|
shell: yum clean all && rm -rf /var/cache/yum
|
||||||
|
when: ansible_distribution == 'Red Hat Enterprise Linux' or ansible_distribution == 'XCP-ng'
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
|
||||||
|
- name: cleaning_packages_metadata
|
||||||
|
shell: zypper clean && rm -rf /var/cache/zypp
|
||||||
|
when: ansible_distribution == 'openSUSE Leap'
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
|
||||||
|
- name: cleaning_packages_metadata
|
||||||
|
shell: apt clean
|
||||||
|
when: ansible_distribution == 'Debian'
|
||||||
|
args:
|
||||||
|
warn: no
|
|
@ -0,0 +1,57 @@
|
||||||
|
galaxy_info:
|
||||||
|
author: your name
|
||||||
|
description: your description
|
||||||
|
company: your company (optional)
|
||||||
|
|
||||||
|
# If the issue tracker for your role is not on github, uncomment the
|
||||||
|
# next line and provide a value
|
||||||
|
# issue_tracker_url: http://example.com/issue/tracker
|
||||||
|
|
||||||
|
# Some suggested licenses:
|
||||||
|
# - BSD (default)
|
||||||
|
# - MIT
|
||||||
|
# - GPLv2
|
||||||
|
# - GPLv3
|
||||||
|
# - Apache
|
||||||
|
# - CC-BY
|
||||||
|
license: license (GPLv2, CC-BY, etc)
|
||||||
|
|
||||||
|
min_ansible_version: 1.2
|
||||||
|
|
||||||
|
# If this a Container Enabled role, provide the minimum Ansible Container version.
|
||||||
|
# min_ansible_container_version:
|
||||||
|
|
||||||
|
# Optionally specify the branch Galaxy will use when accessing the GitHub
|
||||||
|
# repo for this role. During role install, if no tags are available,
|
||||||
|
# Galaxy will use this branch. During import Galaxy will access files on
|
||||||
|
# this branch. If Travis integration is configured, only notifications for this
|
||||||
|
# branch will be accepted. Otherwise, in all cases, the repo's default branch
|
||||||
|
# (usually master) will be used.
|
||||||
|
#github_branch:
|
||||||
|
|
||||||
|
#
|
||||||
|
# platforms is a list of platforms, and each platform has a name and a list of versions.
|
||||||
|
#
|
||||||
|
# platforms:
|
||||||
|
# - name: Fedora
|
||||||
|
# versions:
|
||||||
|
# - all
|
||||||
|
# - 25
|
||||||
|
# - name: SomePlatform
|
||||||
|
# versions:
|
||||||
|
# - all
|
||||||
|
# - 1.0
|
||||||
|
# - 7
|
||||||
|
# - 99.99
|
||||||
|
|
||||||
|
galaxy_tags: []
|
||||||
|
# List tags for your role here, one per line. A tag is a keyword that describes
|
||||||
|
# and categorizes the role. Users find roles by searching for tags. Be sure to
|
||||||
|
# remove the '[]' above, if you add tags to this list.
|
||||||
|
#
|
||||||
|
# NOTE: A tag is limited to a single word comprised of alphanumeric characters.
|
||||||
|
# Maximum 20 tags per role.
|
||||||
|
|
||||||
|
dependencies: []
|
||||||
|
# List your role dependencies here, one per line. Be sure to remove the '[]' above,
|
||||||
|
# if you add dependencies to this list.
|
|
@ -0,0 +1,250 @@
|
||||||
|
- name: Updating packages
|
||||||
|
shell: apt-get update -y && apt-get upgrade -y
|
||||||
|
when: ansible_distribution == 'Debian'
|
||||||
|
ignore_errors: True
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
notify: cleaning_packages_metadata
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Installing packages
|
||||||
|
package: name={{item}} state=present
|
||||||
|
when: ansible_distribution == 'Debian'
|
||||||
|
with_items:
|
||||||
|
- curl
|
||||||
|
- git
|
||||||
|
notify: cleaning_packages_metadata
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Check if xoa is already installed
|
||||||
|
stat:
|
||||||
|
path: /opt/xen-orchestra
|
||||||
|
register: xen_orchestra_directory
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Ensure group xoa exists
|
||||||
|
ansible.builtin.group:
|
||||||
|
name: xoa
|
||||||
|
state: present
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Check if xoa is already registered in sudoers.d
|
||||||
|
stat:
|
||||||
|
path: /etc/sudoers.d/xoa
|
||||||
|
register: xoa_sudoers_file
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Add the xoa user
|
||||||
|
ansible.builtin.user:
|
||||||
|
name: xoa
|
||||||
|
shell: /bin/bash
|
||||||
|
home: /home/xoa
|
||||||
|
comment: xen-orchestra user
|
||||||
|
uid: 1040
|
||||||
|
groups: xoa,users
|
||||||
|
append: yes
|
||||||
|
when: not xoa_sudoers_file.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Register xoa in sudoers.d
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: /etc/sudoers.d/xoa
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: '0640'
|
||||||
|
when: not xoa_sudoers_file.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Allow xoa to have passwordless sudo
|
||||||
|
lineinfile:
|
||||||
|
dest: /etc/sudoers.d/xoa
|
||||||
|
state: present
|
||||||
|
regexp: '^%xoa'
|
||||||
|
line: '%xoa ALL=(ALL) NOPASSWD: ALL'
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Setting git user email
|
||||||
|
git_config:
|
||||||
|
name: user.email
|
||||||
|
scope: global
|
||||||
|
value: "{{git_email}}"
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Setting git user
|
||||||
|
git_config:
|
||||||
|
name: user.name
|
||||||
|
scope: global
|
||||||
|
value: "{{git_user}}"
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Download installation script
|
||||||
|
ansible.builtin.get_url:
|
||||||
|
url: "{{xoa_install_url}}"
|
||||||
|
dest: "/tmp/{{xoa_install_script}}"
|
||||||
|
mode: '0770'
|
||||||
|
when: not xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Download update script
|
||||||
|
ansible.builtin.get_url:
|
||||||
|
url: "{{xoa_update_url}}"
|
||||||
|
dest: "/home/xoa/{{xoa_update_script}}"
|
||||||
|
mode: '0770'
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Create symbolic link to
|
||||||
|
file:
|
||||||
|
src: "/home/xoa/{{xoa_update_script}}"
|
||||||
|
dest: "/etc/cron.weekly/{{xoa_update_script}}"
|
||||||
|
state: link
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Removing existing data structures
|
||||||
|
shell: "rm -R /var/lib/xo-server"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
when: not xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
|
||||||
|
- name: Removing existing data structures
|
||||||
|
shell: "rm -R /var/lib/xo-updater"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
when: not xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
|
||||||
|
- name: Removing existing redis data
|
||||||
|
shell: "redis-cli -n 0 FLUSHALL"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
when: not xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
|
||||||
|
- name: Installing
|
||||||
|
shell: "/tmp/{{xoa_install_script}}"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
when: not xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Updating
|
||||||
|
shell: "/home/xoa/{{xoa_update_script}} -n stable"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
when: xen_orchestra_directory.stat.exists
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Installing xo-cli
|
||||||
|
shell: "npm install -g xo-cli"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Closing existing session using xo-cli
|
||||||
|
shell: "xo-cli --unregister"
|
||||||
|
ignore_errors: True
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Opening session using xo-cli
|
||||||
|
shell: "xo-cli --register --au http://127.0.0.1 {{xoa_default_user}} {{xoa_default_password}}"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
|
||||||
|
- name: Adding user session using xo-cli
|
||||||
|
shell: "xo-cli user.create email='{{xoa_user}}' password='{{xoa_password}}' permission='admin'"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- install
|
||||||
|
|
||||||
|
- name: Closing existing session using xo-cli
|
||||||
|
shell: "xo-cli --unregister"
|
||||||
|
ignore_errors: True
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Opening session using xo-cli
|
||||||
|
shell: "xo-cli --register --au http://127.0.0.1 {{xoa_user}} {{xoa_password}}"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Adding xcp-ng servers using xo-cli
|
||||||
|
shell: "xo-cli server.add label='{{item.label}}' host='{{item.ip}}' username={{xcpng_user}} password='{{xcpng_password}}' autoConnect=true allowUnauthorized=true"
|
||||||
|
ignore_errors: False
|
||||||
|
with_items: "{{xcpng_servers}}"
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
||||||
|
|
||||||
|
- name: Closing session using xo-cli
|
||||||
|
shell: "xo-cli --unregister"
|
||||||
|
ignore_errors: False
|
||||||
|
args:
|
||||||
|
warn: no
|
||||||
|
tags:
|
||||||
|
- add-servers
|
||||||
|
- install
|
||||||
|
- update
|
|
@ -0,0 +1,2 @@
|
||||||
|
localhost
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
- hosts: localhost
|
||||||
|
remote_user: root
|
||||||
|
roles:
|
||||||
|
- xoa
|
|
@ -0,0 +1,2 @@
|
||||||
|
---
|
||||||
|
# vars file
|
Loading…
Reference in New Issue