Compare commits

..

5 Commits

Author SHA1 Message Date
c13d90045e correciton on exec_script_group 2021-07-01 09:53:59 +02:00
50cc20307d correction on del_zephir 2021-07-01 09:51:42 +02:00
d79fd7be7a ajout remonté zephir et multivalues 2021-06-30 16:43:06 +02:00
4c409112d8 correction error message 2021-06-30 15:16:27 +02:00
93fd0536f1 corrections 2021-06-30 15:13:29 +02:00
7 changed files with 56 additions and 36 deletions

View File

@ -10,32 +10,35 @@ from collections import OrderedDict
def display_help():
print("Modification de la valeur d'une variable d'un serveur")
print("{} [--var nom_variable --value valeur]".format(sys.argv[0]))
print("{} [--r realm --d domain --save]".format(sys.argv[0]))
def argparser():
# récupère l'ID du groupe
arglen = len(sys.argv)
save = False
if "--save" in sys.argv:
save = True
if arglen == 1:
return None, None
return None, None, save
if sys.argv[1] in ['-h', '--help']:
display_help()
sys.exit(0)
if sys.argv[1] in ['-r', '--realm']:
realm = sys.argv[2]
return realm, None
return realm, None, save
if sys.argv[3] in ['-d', '--domain']:
domain = sys.argv[4]
return realm, domain
return realm, domain, save
return None, None
return None, None, save
def main():
# import des fonctions communes de Zéphir client
realm, domain = argparser()
realm, domain, save = argparser()
if realm is None :
realm = raw_input("Realm AD : ")
@ -55,15 +58,19 @@ def main():
fh.write(cjson.encode(store))
fh.close()
cmd="""CreoleCat samba4-vars.conf"""
cmd="""CreoleCat -t samba4-vars.conf"""
output = os.popen(cmd)
res = output.read().strip()
output.close()
cmd="""/usr/share/eole/posttemplate/25-manage-samba instance"""
cmd="""/usr/share/eole/postservice/25-manage-samba instance"""
output = os.popen(cmd)
res = output.read().strip()
output.close()
if save:
cmd="""/usr/share/zephir/scripts/zephir_client save_files"""
output = os.popen(cmd)
output.close()
if __name__ == '__main__':
main()

View File

@ -1,3 +1,5 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from zephir.lib_zephir import *
import os, shutil
from creole.config import eoledirs, distrib_dir, dicos_dir
@ -19,9 +21,9 @@ stats_service = u'z_stats'
if os.path.isfile('/var/run/z_stats.pid'):
stats_running = True
try:
from zephir.zephir_conf import zephir_conf
except:
zephir_conf = None
from zephir.zephir_conf import zephir_conf
except:
zephir_conf = None
if stats_running:
@ -39,7 +41,7 @@ if eole_module != 'zephir':
try:
os.unlink("%s/zephir_conf/zephir_conf.py" % zephir_path)
except:
print("\n !! le fichier %s/zephir_conf/zephir_conf.py n'a pas pu être supprimé !!\n" % zephir_d_path)
print("\n !! le fichier %s/zephir_conf/zephir_conf.py n'a pas pu être supprimé !!\n" % zephir_path)
try:
os.unlink("%s/zephir_conf/zephir_conf.pyc" % zephir_path)
try:

View File

@ -1,7 +1,7 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys, getpass, socket, cjson
import sys, getpass, socket, cjson, os
from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient
@ -10,33 +10,36 @@ from collections import OrderedDict
def display_help():
print("Modification de la valeur d'une variable d'un serveur")
print("{} [--var nom_variable --value valeur]".format(sys.argv[0]))
print("{} [--var nom_variable --value valeur --save]".format(sys.argv[0]))
def argparser():
# récupère l'ID du groupe
arglen = len(sys.argv)
save = False
if "--save" in sys.argv:
save = True
if arglen == 1:
return None, None
return None, None, save
if sys.argv[1] in ['-h', '--help']:
display_help()
sys.exit(0)
if sys.argv[1] in ['-v', '--var']:
varc = sys.argv[2]
return varc, None
if sys.argv[3] in ['-l', '--value']:
valvar = sys.argv[4]
return varc, valvar, save
else:
return varc, None, save
if sys.argv[3] in ['-l', '--value']:
valvar = sys.argv[4]
return varc, valvar
return None, None
return None, None, save
def main():
# import des fonctions communes de Zéphir client
varc, valvar = argparser()
varc, valvar, save = argparser()
if varc is None :
@ -49,11 +52,19 @@ def main():
store = cjson.decode(fh.read(), all_unicode=True)
fh.close
if varc in store:
if "|" in valvar:
valvar = valvar.split("|")
store[varc]['val'] = valvar
fh = open("/etc/eole/config.eol", 'w')
fh.write(cjson.encode(store))
fh.close()
fh = open("/etc/eole/config.eol", 'w')
fh.write(cjson.encode(store))
fh.close()
if save:
cmd="""/usr/share/zephir/scripts/zephir_client save_files"""
output = os.popen(cmd)
output.close()
else:
print_orange('Erreur : variable {} inconnue'.format(varc))
if __name__ == '__main__':

View File

@ -40,7 +40,7 @@ def argparser():
display_help()
sys.exit(1)
if sys.argv[2] in ['-v', '--var']:
if sys.argv[2] in ['-v', '--var']:
varc = sys.argv[3]
return server_id, user

View File

@ -81,12 +81,11 @@ def main():
for id_serv in liste_serveurs :
ret = proxy.serveurs.del_serveur(id_serv)
if ret[1]:
print_orange('Erreur : ' + str(ret[1]))
sys.exit(1)
print('Les serveurs {} ont été supprimés'.format(liste_serveurs))
if ret[1] == "ok":
print('Les serveurs {} ont été supprimés'.format(liste_serveurs))
else:
print_orange('Erreur : ' + str(ret[1]))
sys.exit(1)
def get_pwd(addr, port):
"""lecture d'un login/passwd pour l'application zephir

View File

@ -40,7 +40,7 @@ def argparser():
display_help()
sys.exit(1)
if sys.argv[2] in ['-s', '--script']:
if sys.argv[2] in ['-s', '--script']:
script = sys.argv[3]
return group_id, script, None
@ -93,7 +93,7 @@ def main():
liste_serveurs = groups[group_id][1]
ret = proxy.uucp.exec_script(serveurs, script, params))
ret = proxy.uucp.exec_script(liste_serveurs, script, params)
# on affiche les erreurs si nécessaire
if ret[1]:

View File

@ -90,7 +90,8 @@ def main():
ret = proxy.serveurs.groupe_params(liste_serveurs,{'timeout': str(int(polling)*60)})
# on affiche les erreurs si nécessaire
if ret[1]:
print_orange('Erreur : ' + str(ret[1]))
if ret[1] != "ok":
print_orange('Erreur : ' + str(ret[1]))
def get_pwd(addr, port):