Bug Agent WAPT / CentOS ?

Share here your tips or issues concerning WAPT Console or WAPT Agent / Venez ici partager vos problèmes et astuces concernants la console et l'agent WAPT
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
AGUTI
Messages : 3
Inscription : 10 avr. 2020 - 17:00

10 avr. 2020 - 17:14

J'ai voulu installer un agent WAPT sur un serveur CentOS7 pour m'en servir comme dépôt.
J'utilise WAPT Community 1.8.1 sur le serveur.
J'ai récupéré le paquet "tis-waptagent" via YUM sur la machine CentOS et j'ai suivi la procédure d'installation indiquée dans le site wapt.fr.
Mais impossible de faire démarrer le service : la commande
systemctl start waptservice.service
retournait une erreur concernant "locale.getdefaultlocale()[0].split('_')[0]".
=> après avoir refait plusieurs fois la manip, j'ai constaté que :
o Dans la ligne 785 de "/opt/wapt/setuphelpers.py" il y a l'instruction suivante :
return locale.getdefaultlocale()[0].split('_')[0]
o Instruction qui appelle la commande "getlocale" pour obtenir une liste de valeurs correspondant aux paramètres régionaux de langue et de clavier, et qui récupère le premier élément de cette liste (l'item "0"). Cet élément est ensuite divisé ("split") selon le caractère de séparation "_".
o Mais la commande getlocale ne renvoie rien et il est donc impossible de faire un "split" sur une variable qui n'a pas le type requis.

=> J'ai alors tenté l'action corrective suivante : on commente cette instruction dans le fichier "setuphelpers" et on ajoute juste en dessous une instruction qui force le paramètre de régionalisation à la valeur "en_US" :
#return locale.getdefaultlocale()[0].split('_')[0]
return 'en_US.UFT8'
=> résultat : le service veut bien démarrer
Par contre maintenant "systemctl status waptservice.service" retourne une erreur de certificat (alors que j'ai bien déposé le certificat du serveur localement) :
"WARNING Websocket connect params: [('x509 certificate routines', 'X509_check_private_key', 'key values mismatch')]"

=> est-ce que c'est un problème de configuration de mon côté ou bien est-ce que le paquet "waptagent" est bugué ? est-ce que le problème de prise en compte du langage est un bug ?
Merci
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1373
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

15 avr. 2020 - 12:49

Est ce que vous avez une variable d'environnement qui définie la locale? Probablement qu'il n'y en a pas, on va voir pour mettre en_US.utf8 par défaut si getlocale() ne renvoie rien.

Pour le problème de certificat, est ce que c'est un certificat autosigné ou bien issue d'une CA?

Est ce que vous pourriez essayer de relancer l'agent en mode debug pour voir si vous avez un peu plus d'information (pour l'arrêter il faut killer le process python, le ctrl-c n'est pas correctement catché):

Code : Tout sélectionner

/opt/wapt/runwaptagent.sh  -l debug
Cordialement,
Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
AGUTI
Messages : 3
Inscription : 10 avr. 2020 - 17:00

28 avr. 2020 - 17:59

Bonjour et merci pour votre réponse.

Concernant le problème de paramétrage régional :
- effectivement, le système n'avait aucune localisation définie
- j'ai paramétré "localectl set-locale LANG=en_US.utf8"
- j'ai remis la version originale du fichier "setuphelpers.py" à la place de celui que j'ai modifié
- lorsque je tente un redémarrage du service "waptservice", celui-ci accepte de démarrer (il n'affiche que les erreurs liées aux certificats, mais ça c'est un autre problème)
- PAR CONTRE, si je demande l'aide de la commande "wapt-get" j'obtiens une erreur concernant la ligne "locale.getdefaultlocale()[0].split('_')[0]" du fichier "setuphelpers.py"
- je remplace le fichier "setuphelpers" original par celui que j'ai modifié (celui où je force "return locale=en_US.utf8") et alors tout a l'air de fonctionner
- Je ne comprends pas ce comportement...

Concernant le problème de certificats, tout fonctionne pour le moment avec les certificats autosignés de WAPT.
- J'ai placé le certificat du serveur dans la machine CentOS dans "/opt/wapt/ssl" et dans "opt/wapt/ssl/server" mais j'ai toujours le même message "mismatch"
- J'ai démarré en mode debug et on dirait que l'agent sous CentOS veut initier une communication avec le serveur en utilisant son propre certificat (et non celui du serveur) :
Loading ssl context with cert /opt/wapt/private/c9662cf4-b2be-4943-8a2a-a529e3d97175.crt and key /opt/wapt/private/c9662cf4-b2be-4943-8a2a-a529e3d97175.pem
- est-ce qu'il faut que le serveur connaisse le certificat de l'agent Linux ? et dans ce cas, où faut-il le placer sous Windows ?

Encore merci
AGUTI
Messages : 3
Inscription : 10 avr. 2020 - 17:00

28 avr. 2020 - 18:44

Un détail supplémentaire : lorsque je tente un "wapt-get register" auprès du serveur, j'obtiens le message suivant :
Using config file: /opt/wapt/wapt-get.ini
Registering host against server: https://mon-serveur.mon-domaine
FATAL ERROR : NameError: global name 'logger' is not defined

Est-ce que ça peut avoir un rapport avec le problème de certificats ?

Merci
Avatar de l’utilisateur
sfonteneau
Expert WAPT
Messages : 1783
Inscription : 10 juil. 2014 - 23:52
Contact :

28 avr. 2020 - 19:26

Le hasard fait que je devine l'erreur (je l'ai eu hier)

J'ai essayer d'installer wapt dans la couche wsl hier et je suis tomber sur le problème

En gros c'est dmidecode qui ne fonctionne pas.

et on passe dans un except mais il est pas bon

essayez de taper la commande : dmidecode pour voir si elle passe (attention elle passe que en root)

vous pouvez aussi remplacer la ligne par "pass":
https://github.com/tranquilit/WAPT/blob ... ix.py#L245
Verrouillé