Actualiser synology_upgrade_ssh.yml
This commit is contained in:
parent
f5be115a07
commit
697e27fb59
|
|
@ -1,38 +1,204 @@
|
|||
---
|
||||
- name: Synology DSM - Vérifier et préparer mise à jour (mode supporté)
|
||||
- name: Synology DSM - Télécharger (et optionnellement installer) une mise à jour via SSH
|
||||
hosts: synology
|
||||
gather_facts: false
|
||||
|
||||
vars:
|
||||
# Si tu veux aussi lancer l'installation après le download
|
||||
do_install: false
|
||||
|
||||
# Si tu veux reboot après install (DSM redémarre parfois tout seul selon méthode)
|
||||
do_reboot: false
|
||||
|
||||
# Timeout long pour les téléchargements
|
||||
download_timeout: 7200
|
||||
|
||||
tasks:
|
||||
- name: Afficher version DSM actuelle
|
||||
# ------------------------------------------------------------
|
||||
# 0) Vérifs / infos système (DSM version)
|
||||
# ------------------------------------------------------------
|
||||
- name: Lire la version DSM (DSM6/DSM7)
|
||||
ansible.builtin.shell: |
|
||||
if test -f /etc.defaults/VERSION; then
|
||||
cat /etc.defaults/VERSION
|
||||
elif test -f /etc/VERSION; then
|
||||
cat /etc/VERSION
|
||||
else
|
||||
echo "VERSION_FILE_NOT_FOUND"
|
||||
fi
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: dsm_version
|
||||
changed_when: false
|
||||
|
||||
- name: Afficher version
|
||||
- name: Afficher version DSM
|
||||
ansible.builtin.debug:
|
||||
var: dsm_version.stdout_lines
|
||||
|
||||
- name: Vérifier état update via service DSM (heuristique)
|
||||
# ------------------------------------------------------------
|
||||
# 1) Trouver synoupgrade (chemins Synology)
|
||||
# ------------------------------------------------------------
|
||||
- name: Détecter synoupgrade (sans [ ])
|
||||
ansible.builtin.shell: |
|
||||
if [ -f /var/log/synoupdate.log ]; then
|
||||
tail -n 50 /var/log/synoupdate.log
|
||||
else
|
||||
echo "Aucun log synoupdate trouvé"
|
||||
if command -v synoupgrade >/dev/null 2>&1; then
|
||||
command -v synoupgrade
|
||||
exit 0
|
||||
fi
|
||||
register: update_log
|
||||
|
||||
for p in \
|
||||
/usr/syno/sbin/synoupgrade \
|
||||
/usr/sbin/synoupgrade \
|
||||
/sbin/synoupgrade \
|
||||
/bin/synoupgrade \
|
||||
/usr/bin/synoupgrade
|
||||
do
|
||||
if test -x "$p"; then
|
||||
echo "$p"
|
||||
exit 0
|
||||
fi
|
||||
done
|
||||
|
||||
echo "MISSING"
|
||||
exit 0
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: synoupgrade_path
|
||||
changed_when: false
|
||||
|
||||
- name: Résumé état mise à jour
|
||||
- name: Enregistrer le binaire synoupgrade
|
||||
ansible.builtin.set_fact:
|
||||
synoupgrade_bin: "{{ (synoupgrade_path.stdout | trim) }}"
|
||||
|
||||
- name: Fail si synoupgrade introuvable
|
||||
ansible.builtin.fail:
|
||||
msg: "synoupgrade introuvable sur ce NAS (DSM). stdout='{{ synoupgrade_path.stdout | trim }}'"
|
||||
when: synoupgrade_bin == "MISSING" or synoupgrade_bin == ""
|
||||
|
||||
- name: Debug synoupgrade
|
||||
ansible.builtin.debug:
|
||||
msg:
|
||||
- "=== ÉTAT DSM ==="
|
||||
- "Si une mise à jour est disponible :"
|
||||
- "👉 Aller dans DSM > Panneau de configuration > Mise à jour DSM"
|
||||
- "👉 Accepter l’EULA si demandé"
|
||||
- "👉 Cliquer Installer (ou planifier)"
|
||||
- ""
|
||||
- "Ce comportement est NORMAL sur DSM 7 (API/SSH limités)"
|
||||
- "Logs récents :"
|
||||
- "{{ update_log.stdout_lines | default([]) }}"
|
||||
msg: "synoupgrade détecté: {{ synoupgrade_bin }}"
|
||||
|
||||
# ------------------------------------------------------------
|
||||
# 2) Check si une MAJ DSM est dispo
|
||||
# ------------------------------------------------------------
|
||||
- name: Check mise à jour disponible (best effort)
|
||||
ansible.builtin.shell: |
|
||||
# Selon DSM, différentes options existent.
|
||||
# On essaye plusieurs modes sans échouer le playbook.
|
||||
set +e
|
||||
|
||||
"{{ synoupgrade_bin }}" --help 2>/dev/null | head -n 50
|
||||
|
||||
echo "---- TRY: check ----"
|
||||
"{{ synoupgrade_bin }}" check 2>&1
|
||||
rc1=$?
|
||||
|
||||
echo "---- TRY: --check ----"
|
||||
"{{ synoupgrade_bin }}" --check 2>&1
|
||||
rc2=$?
|
||||
|
||||
echo "---- TRY: --status ----"
|
||||
"{{ synoupgrade_bin }}" --status 2>&1
|
||||
rc3=$?
|
||||
|
||||
echo "RCs: check=$rc1 --check=$rc2 --status=$rc3"
|
||||
exit 0
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: check_out
|
||||
changed_when: false
|
||||
|
||||
- name: Afficher résultat du check
|
||||
ansible.builtin.debug:
|
||||
var: check_out.stdout_lines
|
||||
|
||||
# Heuristique : si on voit des mots indiquant une MAJ dispo
|
||||
- name: Déterminer si une mise à jour semble dispo (heuristique)
|
||||
ansible.builtin.set_fact:
|
||||
update_available: >-
|
||||
{{
|
||||
(
|
||||
(check_out.stdout | lower).find('update') != -1
|
||||
or (check_out.stdout | lower).find('upgrade') != -1
|
||||
or (check_out.stdout | lower).find('available') != -1
|
||||
or (check_out.stdout | lower).find('download') != -1
|
||||
or (check_out.stdout | lower).find('new') != -1
|
||||
or (check_out.stdout | lower).find('télécharg') != -1
|
||||
or (check_out.stdout | lower).find('dispon') != -1
|
||||
)
|
||||
}}
|
||||
|
||||
- name: Info dispo maj
|
||||
ansible.builtin.debug:
|
||||
msg: "MAJ dispo (heuristique) = {{ update_available }}"
|
||||
|
||||
# ------------------------------------------------------------
|
||||
# 3) Télécharger la MAJ (si dispo)
|
||||
# ------------------------------------------------------------
|
||||
- name: Télécharger la mise à jour DSM (best effort)
|
||||
ansible.builtin.shell: |
|
||||
set -e
|
||||
# On tente plusieurs syntaxes selon versions DSM.
|
||||
# La commande correcte dépend du modèle/DSM.
|
||||
# L'idée: déclencher le download depuis les dépôts Synology.
|
||||
#
|
||||
# Tentative 1:
|
||||
"{{ synoupgrade_bin }}" download || true
|
||||
# Tentative 2:
|
||||
"{{ synoupgrade_bin }}" --download || true
|
||||
# Tentative 3:
|
||||
"{{ synoupgrade_bin }}" download --start || true
|
||||
echo "Download commands sent."
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: dl_out
|
||||
changed_when: true
|
||||
when: update_available | bool
|
||||
|
||||
- name: Afficher sortie download
|
||||
ansible.builtin.debug:
|
||||
var: dl_out.stdout_lines
|
||||
when: update_available | bool
|
||||
|
||||
- name: Stop si aucune MAJ détectée
|
||||
ansible.builtin.debug:
|
||||
msg: "Aucune mise à jour détectée (heuristique). Rien à télécharger."
|
||||
when: not (update_available | bool)
|
||||
|
||||
# ------------------------------------------------------------
|
||||
# 4) Optionnel : installer après téléchargement
|
||||
# ------------------------------------------------------------
|
||||
- name: Lancer l'installation DSM (optionnel)
|
||||
ansible.builtin.shell: |
|
||||
set -e
|
||||
"{{ synoupgrade_bin }}" start || true
|
||||
"{{ synoupgrade_bin }}" --start || true
|
||||
"{{ synoupgrade_bin }}" upgrade || true
|
||||
echo "Install commands sent."
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: install_out
|
||||
changed_when: true
|
||||
when:
|
||||
- update_available | bool
|
||||
- do_install | bool
|
||||
|
||||
- name: Afficher sortie install
|
||||
ansible.builtin.debug:
|
||||
var: install_out.stdout_lines
|
||||
when:
|
||||
- update_available | bool
|
||||
- do_install | bool
|
||||
|
||||
# ------------------------------------------------------------
|
||||
# 5) Optionnel : reboot
|
||||
# ------------------------------------------------------------
|
||||
- name: Reboot NAS (optionnel)
|
||||
ansible.builtin.shell: |
|
||||
sudo reboot || reboot
|
||||
args:
|
||||
executable: /bin/bash
|
||||
when:
|
||||
- update_available | bool
|
||||
- do_install | bool
|
||||
- do_reboot | bool
|
||||
|
|
|
|||
Loading…
Reference in New Issue