reworked by Gemini
This commit is contained in:
@@ -2,36 +2,22 @@
|
||||
---
|
||||
# tasks file for roles/omada-controller
|
||||
# roles/omada-controller/tasks/main.yml
|
||||
- name: Check if Omada Controller package 'tpeap' is already installed (using command)
|
||||
command: dpkg-query -W -f='${Status}' tpeap
|
||||
register: omada_pkg_status
|
||||
# Fail silently if package is not found, and never report a change.
|
||||
failed_when: false
|
||||
changed_when: false
|
||||
|
||||
- name: Install Omada Controller
|
||||
when: "'install ok installed' not in omada_pkg_status.stdout"
|
||||
block:
|
||||
- name: Install dependencies for Omada Controller
|
||||
# Der Controller benötigt Java, jsvc (Java Service Wrapper) und curl.
|
||||
# MongoDB wird vom Controller-Paket selbst mitgebracht und muss nicht separat installiert werden.
|
||||
apt:
|
||||
ansible.builtin.apt:
|
||||
name:
|
||||
- "{{ omada_controller_java_package }}"
|
||||
- jsvc
|
||||
- gnupg # Benötigt für gpg --dearmor
|
||||
- curl
|
||||
- apt-transport-https
|
||||
state: present
|
||||
update_cache: yes
|
||||
register: apt_install
|
||||
retries: 3
|
||||
until: apt_install is success
|
||||
|
||||
- name: Ensure apt can use repositories over HTTPS
|
||||
ansible.builtin.apt:
|
||||
name: apt-transport-https
|
||||
state: present
|
||||
|
||||
- name: Download MongoDB GPG key
|
||||
ansible.builtin.get_url:
|
||||
url: "https://www.mongodb.org/static/pgp/server-{{ omada_controller_mongodb_version }}.asc"
|
||||
@@ -51,34 +37,35 @@
|
||||
filename: "mongodb-org-{{ omada_controller_mongodb_version }}"
|
||||
update_cache: yes
|
||||
# Der 'signed-by'-Parameter verweist auf den zuvor dearmored Schlüssel.
|
||||
# Dies ist die moderne und sichere Methode, GPG-Schlüssel für APT-Repositories zu handhaben.
|
||||
|
||||
- name: Install MongoDB server
|
||||
# Der Omada Controller benötigt MongoDB >= 3.0.0.
|
||||
# Wir installieren 'mongodb-org-server' aus dem offiziellen MongoDB-Repository.
|
||||
# Das Omada Controller-Paket wird diese Abhängigkeit dann finden.
|
||||
ansible.builtin.apt:
|
||||
name: mongodb-org-server
|
||||
state: present
|
||||
register: mongodb_install
|
||||
retries: 3
|
||||
until: mongodb_install is success
|
||||
# Hinweis: Der MongoDB-Dienst wird bei der Installation automatisch gestartet.
|
||||
# Der Omada Controller verwaltet seine Interaktion mit MongoDB.
|
||||
|
||||
- name: Check if Omada Controller package 'tpeap' is already installed (using command)
|
||||
ansible.builtin.command: dpkg-query -W -f='${Status}' tpeap
|
||||
register: omada_pkg_status
|
||||
# Fail silently if package is not found, and never report a change.
|
||||
failed_when: false
|
||||
changed_when: false
|
||||
|
||||
# Das .deb-Paket wird direkt von der URL installiert.
|
||||
- name: Install Omada Controller from URL
|
||||
apt:
|
||||
ansible.builtin.apt:
|
||||
deb: "{{ omada_controller_deb_url }}"
|
||||
state: present
|
||||
when: "'install ok installed' not in omada_pkg_status.stdout"
|
||||
register: omada_install
|
||||
retries: 3
|
||||
until: omada_install is success
|
||||
notify: Restart Omada Controller
|
||||
|
||||
- name: Ensure Omada Controller service (tpeap) is running and enabled on boot
|
||||
service:
|
||||
ansible.builtin.service:
|
||||
name: tpeap
|
||||
state: started
|
||||
enabled: yes
|
||||
|
||||
Reference in New Issue
Block a user