Compare commits

..

26 Commits

Author SHA1 Message Date
524aef91f9 set correct args option 2021-09-02 10:55:09 +02:00
84834a228f update question on set_var 2021-09-02 10:09:16 +02:00
f081522e1e correction set_var 2021-07-20 09:18:21 +02:00
441fbd22d2 correction timeout 2021-07-20 09:14:19 +02:00
0f3c332923 correction 2021-07-20 09:11:48 +02:00
4b11e407be ajout messages d'information, ajout option no-save pour batch 2021-07-19 09:32:41 +02:00
32bfaa523f correction batch 2021-07-16 15:43:16 +02:00
244cc1a716 correction bug 2021-07-16 15:07:25 +02:00
1a63a81555 correciton bug 2021-07-16 15:05:43 +02:00
ebcb30f0ba update authorize user group 2021-07-09 15:26:47 +02:00
db53a99881 update authorize_user_group 2021-07-09 15:04:17 +02:00
bc53733bf7 maj set_var 2021-07-09 10:18:19 +02:00
d6e8801684 maj set timeout 2021-07-09 10:13:00 +02:00
dc8d71a574 update exec_script_group 2021-07-09 10:03:39 +02:00
39c0895538 renommage desenregistrement.zephir 2021-07-09 09:13:48 +02:00
89b75f0147 update set_var module 2021-07-08 14:37:33 +02:00
a2f7313cc5 update del_servers_group 2021-07-08 10:34:37 +02:00
401a4f9ef4 update change_domain 2021-07-07 15:10:54 +02:00
27bdbf5e4f update set_var module 2021-07-05 10:13:40 +02:00
7b4414b137 correction set_userkey error message 2021-07-01 16:14:04 +02:00
e7903ded1b add set_var zephir 2021-07-01 11:17:32 +02:00
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
11 changed files with 707 additions and 158 deletions

View File

@ -10,35 +10,36 @@ from collections import OrderedDict
def display_help(): def display_help():
print("Modification de la valeur d'une variable d'un serveur") print("Modification de la valeur d'une variable d'un serveur")
print("{} [--var nom_variable --value valeur]".format(sys.argv[0])) print("{} [--d domain --integration --save --no-save]".format(sys.argv[0]))
def argparser(): def argparser():
# récupère l'ID du groupe # récupère l'ID du groupe
arglen = len(sys.argv) arglen = len(sys.argv)
save = None
integration = None
if "--save" in sys.argv:
save = True
if "--no-save" in sys.argv:
save = False
if "--integration" in sys.argv:
integration = True
if arglen == 1: if arglen == 1:
return None, None return None, save
if sys.argv[1] in ['-h', '--help']: if sys.argv[1] in ['-h', '--help']:
display_help() display_help()
sys.exit(0) sys.exit(0)
if sys.argv[1] in ['-r', '--realm']: if sys.argv[1] in ['-d', '--domain']:
realm = sys.argv[2] domain = sys.argv[2]
return realm, None return domain, save, integration
if sys.argv[3] in ['-d', '--domain']: return None, save, integration
domain = sys.argv[4]
return realm, domain
return None, None
def main(): def main():
# import des fonctions communes de Zéphir client # import des fonctions communes de Zéphir client
realm, domain = argparser() domain, save, integration = argparser()
if realm is None :
realm = raw_input("Realm AD : ")
if domain is None : if domain is None :
domain = raw_input("Domaine AD : ") domain = raw_input("Domaine AD : ")
@ -46,24 +47,45 @@ def main():
fh = open("/etc/eole/config.eol", 'r') fh = open("/etc/eole/config.eol", 'r')
store = cjson.decode(fh.read(), all_unicode=True) store = cjson.decode(fh.read(), all_unicode=True)
fh.close fh.close
if "ad_realm" in store: if "nom_domaine_local" in store:
store["ad_realm"]['val'] = realm store["nom_domaine_local"]['val'] = domain
if "ad_domain" in store:
store["ad_domain"]['val'] = domain
fh = open("/etc/eole/config.eol", 'w') fh = open("/etc/eole/config.eol", 'w')
fh.write(cjson.encode(store)) fh.write(cjson.encode(store))
fh.close() fh.close()
cmd="""CreoleCat samba4-vars.conf""" cmd="""CreoleCat -t samba4-vars.conf"""
output = os.popen(cmd) output = os.popen(cmd)
res = output.read().strip() res = output.read().strip()
output.close() output.close()
cmd="""/usr/share/eole/posttemplate/25-manage-samba instance""" if not integration :
to_integrate = raw_input("Souhaitez vous intégrer le serveur au domaine ad ? (O/N) ")
if to_integrate == "O":
integration = True
if integration:
cmd="""rm -f /var/lib/samba/.instance_ok; rm -f *.tdb"""
output = os.popen(cmd) output = os.popen(cmd)
res = output.read().strip() res = output.read().strip()
output.close() output.close()
cmd="""/usr/share/eole/postservice/25-manage-samba instance"""
output = os.popen(cmd)
res = output.read().strip()
output.close()
to_save = ""
if save if None:
to_save = raw_input("Souhaitez vous sauvegarder la configuration sur Zephir ? (O/N) ")
if to_save == "O":
save = True
print("Sauvegarde de la configuration sur zephir")
else:
print("La configuration ne sera pas sauvegardé sur le zephir")
if save:
cmd="""/usr/share/zephir/scripts/zephir_client save_files"""
output = os.popen(cmd)
output.close()
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View File

@ -1,3 +1,5 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from zephir.lib_zephir import * from zephir.lib_zephir import *
import os, shutil import os, shutil
from creole.config import eoledirs, distrib_dir, dicos_dir from creole.config import eoledirs, distrib_dir, dicos_dir
@ -20,7 +22,7 @@ if os.path.isfile('/var/run/z_stats.pid'):
stats_running = True stats_running = True
try: try:
from zephir.zephir_conf import zephir_conf from zephir.zephir_conf import zephir_conf
except: except:
zephir_conf = None zephir_conf = None
@ -39,7 +41,7 @@ if eole_module != 'zephir':
try: try:
os.unlink("%s/zephir_conf/zephir_conf.py" % zephir_path) os.unlink("%s/zephir_conf/zephir_conf.py" % zephir_path)
except: 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: try:
os.unlink("%s/zephir_conf/zephir_conf.pyc" % zephir_path) os.unlink("%s/zephir_conf/zephir_conf.pyc" % zephir_path)
try: try:

View File

@ -1,60 +0,0 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys, getpass, socket, cjson
from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient
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]))
def argparser():
# récupère l'ID du groupe
arglen = len(sys.argv)
if arglen == 1:
return None, None
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
return None, None
def main():
# import des fonctions communes de Zéphir client
varc, valvar = argparser()
if varc is None :
varc = raw_input("Variable à modifier : ")
if valvar is None :
valvar = raw_input("Valeur de la variable : ")
fh = open("/etc/eole/config.eol", 'r')
store = cjson.decode(fh.read(), all_unicode=True)
fh.close
if varc in store:
store[varc]['val'] = valvar
fh = open("/etc/eole/config.eol", 'w')
fh.write(cjson.encode(store))
fh.close()
if __name__ == '__main__':
main()

View File

@ -0,0 +1,85 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys, getpass, socket, cjson, os
from pyeole.ihm import print_line, question_ouinon
from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient
from collections import OrderedDict
def display_help():
print("Modification de la valeur d'une variable d'un serveur")
print("{} [--var nom_variable --value valeur --save --no-save]".format(sys.argv[0]))
def argparser():
# récupère l'ID du groupe
arglen = len(sys.argv)
save = None
if "--save" in sys.argv:
save = True
if "--no-save" in sys.argv:
save = False
if arglen == 1:
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]
if sys.argv[3] in ['-l', '--value']:
valvar = sys.argv[4]
return varc, valvar, save
else:
return varc, None, save
return None, None, save
def main():
# import des fonctions communes de Zéphir client
varc, valvar, save = argparser()
fh = open("/etc/eole/config.eol", 'r')
store = cjson.decode(fh.read(), all_unicode=True)
fh.close
if varc is None :
print
print('Liste des variables modifiables :')
for var in store:
print(' - ' + var)
varc = raw_input("Variable à modifier : ")
if valvar is None :
valvar = raw_input("Valeur de la variable : ")
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()
if save is None :
if question_ouinon("Souhaitez vous sauvegarder la configuration sur Zephir ?", default='non') == 'oui':
print("Sauvegarde de la configuration sur zephir")
save=True
else:
print("La configuration ne sera pas sauvegardé sur zephir")
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__':
main()

View File

@ -6,6 +6,7 @@ from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient from creole.client import CreoleClient
from collections import OrderedDict from collections import OrderedDict
from zephir.backend.lib_backend import CxPool
try: try:
@ -24,7 +25,6 @@ def display_help():
print("Autorise une connexion ssh d'un utilisateur sur un groupe de serveur") print("Autorise une connexion ssh d'un utilisateur sur un groupe de serveur")
print("{} [numero du groupe] [--user utilisateur]".format(sys.argv[0])) print("{} [numero du groupe] [--user utilisateur]".format(sys.argv[0]))
def argparser(): def argparser():
# récupère l'ID du groupe # récupère l'ID du groupe
arglen = len(sys.argv) arglen = len(sys.argv)
@ -40,9 +40,9 @@ def argparser():
display_help() display_help()
sys.exit(1) sys.exit(1)
if sys.argv[2] in ['-v', '--var']: if sys.argv[2] in ['-u', '--user']:
varc = sys.argv[3] user = sys.argv[3]
return server_id, user return group_id, user
return group_id, None return group_id, None
@ -68,8 +68,13 @@ def main():
print('Liste des groupes :') print('Liste des groupes :')
for grp_id, group_infos in groups.items(): for grp_id, group_infos in groups.items():
print(' - ' + str(grp_id) + ' : ' + group_infos[0]) print(' - ' + str(grp_id) + ' : ' + group_infos[0])
print( ' - N : Créer un nouveau groupe')
while group_id is None: while group_id is None:
tmp_group_id = flushed_input("Numéro du groupe : ") tmp_group_id = flushed_input("Numéro du groupe : ")
if tmp_group_id == 'N':
group_id = 'N'
liste_serveurs = make_group()
else:
try: try:
group_id = int(tmp_group_id) group_id = int(tmp_group_id)
except Exception as err: except Exception as err:
@ -78,23 +83,74 @@ def main():
if not group_id in groups: if not group_id in groups:
print_red('Groupe inconnu') print_red('Groupe inconnu')
group_id = None group_id = None
elif not group_id in groups:
print_red('Le groupe "{}" est inconnu'.format(group_id))
sys.exit(1) sys.exit(1)
liste_serveurs = groups[group_id][1]
else:
liste_serveurs = groups[group_id][1]
if user is None: if user is None:
user = flushed_input("Utilisateur : ") user = flushed_input("Utilisateur : ")
liste_serveurs = groups[group_id][1]
ret = proxy.serveurs.authorize_user(user,liste_serveurs) ret = proxy.serveurs.authorize_user(user,liste_serveurs)
# on affiche les erreurs si nécessaire
if ret[1]:
print_orange('Erreur : ' + str(ret[1]))
print('Utilisateur {} autorisé à accéder en ssh aux serveurs {}'.format(user, liste_serveurs)) print('Utilisateur {} autorisé à accéder en ssh aux serveurs {}'.format(user, liste_serveurs))
print("Excecuter le script exec_script_group [id_group] -s call pour pour envoyer la configuration aux serveurs")
def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
print("Liste des serveurs : ")
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append(server[0])
return server_infos
def get_pwd(addr, port): def get_pwd(addr, port):
"""lecture d'un login/passwd pour l'application zephir """lecture d'un login/passwd pour l'application zephir

View File

@ -2,11 +2,8 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
import sys, getpass, socket import sys, getpass, socket
from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient from creole.client import CreoleClient
from collections import OrderedDict from zephir.backend.lib_backend import CxPool
try: try:
from zephir.zephir_conf.zephir_conf import adresse_zephir from zephir.zephir_conf.zephir_conf import adresse_zephir
@ -64,8 +61,13 @@ def main():
print('Liste des groupes :') print('Liste des groupes :')
for grp_id, group_infos in groups.items(): for grp_id, group_infos in groups.items():
print(' - ' + str(grp_id) + ' : ' + group_infos[0]) print(' - ' + str(grp_id) + ' : ' + group_infos[0])
print( ' - N : Créer un nouveau groupe')
while group_id is None: while group_id is None:
tmp_group_id = flushed_input("Numéro du groupe : ") tmp_group_id = flushed_input("Numéro du groupe : ")
if tmp_group_id == 'N':
group_id = 'N'
liste_serveurs = make_group()
else:
try: try:
group_id = int(tmp_group_id) group_id = int(tmp_group_id)
except Exception as err: except Exception as err:
@ -74,19 +76,73 @@ def main():
if not group_id in groups: if not group_id in groups:
print_red('Groupe inconnu') print_red('Groupe inconnu')
group_id = None group_id = None
elif not group_id in groups:
print_red('Le groupe "{}" est inconnu'.format(group_id))
sys.exit(1) sys.exit(1)
liste_serveurs = groups[group_id][1] liste_serveurs = groups[group_id][1]
else:
liste_serveurs = groups[group_id][1]
for id_serv in liste_serveurs : for id_serv in liste_serveurs :
ret = proxy.serveurs.del_serveur(id_serv) ret = proxy.serveurs.del_serveur(id_serv)
if ret[1]: if ret[1]:
if ret[1] == "ok":
print('Les serveurs {} ont été supprimés'.format(liste_serveurs))
else:
print_orange('Erreur : ' + str(ret[1])) print_orange('Erreur : ' + str(ret[1]))
sys.exit(1) sys.exit(1)
print('Les serveurs {} ont été supprimés'.format(liste_serveurs)) def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
print("Liste des serveurs : ")
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append(server[0])
return server_infos
def get_pwd(addr, port): def get_pwd(addr, port):
"""lecture d'un login/passwd pour l'application zephir """lecture d'un login/passwd pour l'application zephir

View File

@ -6,6 +6,8 @@ from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient from creole.client import CreoleClient
from collections import OrderedDict from collections import OrderedDict
from zephir.backend.lib_backend import CxPool
try: try:
@ -44,7 +46,7 @@ def argparser():
script = sys.argv[3] script = sys.argv[3]
return group_id, script, None return group_id, script, None
if sys.argv[4] in ['-p', '--params']: if sys.argv[4] in ['-a', '--args']:
varc = sys.argv[5] varc = sys.argv[5]
return group_id, script, params return group_id, script, params
@ -72,8 +74,13 @@ def main():
print('Liste des groupes :') print('Liste des groupes :')
for grp_id, group_infos in groups.items(): for grp_id, group_infos in groups.items():
print(' - ' + str(grp_id) + ' : ' + group_infos[0]) print(' - ' + str(grp_id) + ' : ' + group_infos[0])
print( ' - N : Créer un nouveau groupe')
while group_id is None: while group_id is None:
tmp_group_id = flushed_input("Numéro du groupe : ") tmp_group_id = flushed_input("Numéro du groupe : ")
if tmp_group_id == 'N':
group_id = 'N'
liste_serveurs = make_group()
else:
try: try:
group_id = int(tmp_group_id) group_id = int(tmp_group_id)
except Exception as err: except Exception as err:
@ -82,18 +89,18 @@ def main():
if not group_id in groups: if not group_id in groups:
print_red('Groupe inconnu') print_red('Groupe inconnu')
group_id = None group_id = None
elif not group_id in groups:
print_red('Le groupe "{}" est inconnu'.format(group_id))
sys.exit(1) sys.exit(1)
liste_serveurs = groups[group_id][1]
else:
liste_serveurs = groups[group_id][1]
if script is None: if script is None:
script = flushed_input("Script à executer : ") script = flushed_input("Script à executer : ")
if params is None: if params is None:
params = flushed_input("Paramètres : ") params = flushed_input("Paramètres : ")
liste_serveurs = groups[group_id][1]
ret = proxy.uucp.exec_script(serveurs, script, params)) if params is None: params = ""
ret = proxy.uucp.exec_script(liste_serveurs, script, params)
# on affiche les erreurs si nécessaire # on affiche les erreurs si nécessaire
if ret[1]: if ret[1]:
@ -101,6 +108,60 @@ def main():
print('Script {} {} exécuté sur les serveurs {}'.format(script, params, liste_serveurs)) print('Script {} {} exécuté sur les serveurs {}'.format(script, params, liste_serveurs))
def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
print("Liste des serveurs : ")
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append(server[0])
return server_infos
def get_pwd(addr, port): def get_pwd(addr, port):

58
scripts/zephir/groups.py Normal file
View File

@ -0,0 +1,58 @@
#!/usr/bin/python
from zephir.backend.lib_backend import CxPool
def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
print("Liste des serveurs : ")
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append((server[0], server[1], server[2], server[3]))
return server_infos

View File

@ -6,6 +6,7 @@ from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient from creole.client import CreoleClient
from collections import OrderedDict from collections import OrderedDict
from zephir.backend.lib_backend import CxPool
try: try:
@ -69,8 +70,13 @@ def main():
print('Liste des groupes :') print('Liste des groupes :')
for grp_id, group_infos in groups.items(): for grp_id, group_infos in groups.items():
print(' - ' + str(grp_id) + ' : ' + group_infos[0]) print(' - ' + str(grp_id) + ' : ' + group_infos[0])
print( ' - N : Créer un nouveau groupe')
while group_id is None: while group_id is None:
tmp_group_id = flushed_input("Numéro du groupe : ") tmp_group_id = flushed_input("Numéro du groupe : ")
if tmp_group_id == 'N':
group_id = 'N'
liste_serveurs = make_group()
else:
try: try:
group_id = int(tmp_group_id) group_id = int(tmp_group_id)
except Exception as err: except Exception as err:
@ -79,10 +85,10 @@ def main():
if not group_id in groups: if not group_id in groups:
print_red('Groupe inconnu') print_red('Groupe inconnu')
group_id = None group_id = None
elif not group_id in groups:
print_red('Le groupe "{}" est inconnu'.format(group_id))
sys.exit(1) sys.exit(1)
liste_serveurs = groups[group_id][1] liste_serveurs = groups[group_id][1]
else:
liste_serveurs = groups[group_id][1]
if polling is None : if polling is None :
polling = flushed_input("Durée du polling (en min) : ") polling = flushed_input("Durée du polling (en min) : ")
@ -90,8 +96,65 @@ def main():
ret = proxy.serveurs.groupe_params(liste_serveurs,{'timeout': str(int(polling)*60)}) ret = proxy.serveurs.groupe_params(liste_serveurs,{'timeout': str(int(polling)*60)})
# on affiche les erreurs si nécessaire # on affiche les erreurs si nécessaire
if ret[1]: if ret[1]:
if ret[1] != "OK":
print_orange('Erreur : ' + str(ret[1])) print_orange('Erreur : ' + str(ret[1]))
sys.exit(1)
print('Polling mis à jour sur les serveurs {}'.format(liste_serveurs))
def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
print("Liste des serveurs : ")
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append(server[0])
return server_infos
def get_pwd(addr, port): def get_pwd(addr, port):
"""lecture d'un login/passwd pour l'application zephir """lecture d'un login/passwd pour l'application zephir

View File

@ -62,6 +62,7 @@ def main():
keyssh = f.read() keyssh = f.read()
clef_ssh = base64.encodestring(keyssh).decode() clef_ssh = base64.encodestring(keyssh).decode()
os.chdir("/etc/postgresql/")
cmd="""sudo -u postgres psql -c "update users set cle='{}' where login='{}';" zephir""".format(clef_ssh,user) cmd="""sudo -u postgres psql -c "update users set cle='{}' where login='{}';" zephir""".format(clef_ssh,user)
output = os.popen(cmd) output = os.popen(cmd)
res = output.read().strip() res = output.read().strip()
@ -71,6 +72,7 @@ def main():
if res == "UPDATE 1": if res == "UPDATE 1":
print("OK") print("OK")
print("Excecuter le script authorize_user_group pour authoriser l'accès de l'utilisateur aux serveurs")
else: else:
print("Erreur : ", str(res)) print("Erreur : ", str(res))

204
scripts/zephir/set_var.py Normal file
View File

@ -0,0 +1,204 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys, getpass, socket
from pyeole.ihm import print_line
from pyeole.ansiprint import print_orange, print_red
from creole.client import CreoleClient
from collections import OrderedDict
from zephir.backend.lib_backend import CxPool
try:
from zephir.zephir_conf.zephir_conf import adresse_zephir
except:
client = CreoleClient()
adresse_zephir = client.get_creole('nom_domaine_machine')
from zephir.lib_zephir import convert
from zephir.lib_zephir import xmlrpclib
from zephir.lib_zephir import EoleProxy
from zephir.lib_zephir import TransportEole
from zephir.lib_zephir import flushed_input
def display_help():
print("Modification de la valeur d'une variable d'un serveur")
print("{} [numero du groupe] [--var nom_variable --value valeur --save]".format(sys.argv[0]))
def argparser():
# récupère l'ID du groupe
arglen = len(sys.argv)
if arglen == 1:
return None, None, None
if sys.argv[1] in ['-h', '--help']:
display_help()
sys.exit(0)
try:
group_id = int(sys.argv[1])
except:
print_red("\"{}\" n'est pas un ID de groupe valide".format(sys.argv[1]))
display_help()
sys.exit(1)
if sys.argv[2] in ['-v', '--var']:
varc = sys.argv[3]
if sys.argv[4] in ['-l', '--value']:
valvar = sys.argv[5]
return group_id, varc, valvar
else:
return group_id, varc, None,
return None, None, None
def main():
# import des fonctions communes de Zéphir client
group_id, varc, valvar = argparser()
authentified, proxy = get_pwd(adresse_zephir, 7080)
if authentified == False:
sys.exit(1)
# on récupère la liste des groupes
try:
groups = {grp_id: (group_name, liste_serveurs) for grp_id, group_name, liste_serveurs in convert(proxy.serveurs.get_groups())[1]}
except xmlrpclib.ProtocolError:
print_red("""Erreur de permissions ou Zéphir non disponible""")
sys.exit(1)
except socket.error, e:
print_red("""Erreur de connexion au serveur Zéphir (%s)""" % str(e))
sys.exit(1)
# on récupère l'ID du groupe concerné
if group_id is None:
print('Liste des groupes :')
for grp_id, group_infos in groups.items():
print(' - ' + str(grp_id) + ' : ' + group_infos[0])
print( ' - N : Créer un nouveau groupe')
while group_id is None:
tmp_group_id = flushed_input("Numéro du groupe : ")
if tmp_group_id == 'N':
group_id = 'N'
liste_serveurs = make_group()
else:
try:
group_id = int(tmp_group_id)
except Exception as err:
print(err)
continue
if not group_id in groups:
print_red('Groupe inconnu')
group_id = None
sys.exit(1)
liste_serveurs = groups[group_id][1]
else:
liste_serveurs = groups[group_id][1]
# on récupère toutes les master/slaves du groupe de serveurs
params = convert(proxy.serveurs.get_groupe_vars(liste_serveurs, True))
if varc is None :
print
print('Liste des variables dans un groupe :')
list_vars = params[1][3]
for var in list_vars:
print(' - ' + var)
varc = flushed_input("Variable à modifier : ")
if valvar is None :
valvar = flushed_input("Valeur de la variable (séparateur |): ")
ret = proxy.serveurs.set_groupe_var(liste_serveurs, varc, valvar, False)
# on affiche les erreurs si nécessaire
if ret[1]:
if ret[1] != "OK":
print_orange('Erreur : ' + str(ret[1]))
sys.exit(1)
print('Variable {} mis à jour sur les serveurs {}'.format(varc, liste_serveurs))
def make_group():
cx_pool = CxPool()
cu = cx_pool.create()
cu.execute("""select libelle,id from modules""")
infos = {}
variante_infos = {}
filename = 'exportation'
server_infos = []
for module_name in cu.fetchall():
module, version = module_name[0].rsplit('-', 1)
infos.setdefault(version, {})[module] = module_name[1]
versions = infos.keys()
versions.sort()
print('Choix de la version :')
for idx, version in enumerate(versions):
print('{}: {}'.format(idx, version))
idx = input('> ')
version = versions[int(idx)]
filename += '-' + version
print
print('Choix du module :')
modules = infos[version].keys()
modules.sort()
for idx, module in enumerate(modules):
print('{}: {}'.format(idx, module))
idx = input('> ')
module = modules[int(idx)]
filename += '-' + module
print
cu.execute("select libelle,id from variantes where module = " + str(infos[version][module]))
for variante_obj in cu.fetchall():
variante_infos[variante_obj[0]] = variante_obj[1]
print('Choix de la variante :')
variantes = variante_infos.keys()
variantes.sort()
for idx, variante in enumerate(variantes):
print('{}: {}'.format(idx, variante))
idx_all = idx + 1
print('{}: toutes les variantes'.format(idx_all))
idx = input('> ')
if idx == idx_all:
variantes = variante_infos.values()
else:
filename += '-' + variantes[idx]
variantes = [variante_infos[variantes[idx]]]
print
for variante in variantes:
cu.execute('select id,ip_publique,rne,libelle from serveurs where variante=' + str(variante))
print("Liste des serveurs : ")
for server in cu.fetchall():
print('{} - {} - {} - {}'.format(server[0], server[1], server[2], server[3]))
server_infos.append(server[0])
return server_infos
def get_pwd(addr, port):
"""lecture d'un login/passwd pour l'application zephir
"""
login_ok = 0
user = "toto"
while login_ok == 0 and user != "":
try:
# flush de l'entrée standard au cas où l'utilisateur aurait
# tapé <entrée> pendant l'Upgrade
termios.tcflush(sys.stdin, termios.TCIOFLUSH)
except:
pass
user = flushed_input("Entrez votre login zephir (rien pour sortir) : ")
if user != "":
passwd = getpass.getpass("Mot de passe zephir pour %s : " % user)
# création du proxy avec zephir
proxy = EoleProxy("https://%s:%s@%s:%s" % (user, passwd, addr, port), transport=TransportEole())
login_ok = 1
try:
res = convert(proxy.get_permissions(user))
except xmlrpclib.ProtocolError:
login_ok = 0
print_line("\n Erreur d'authentification \n")
else:
return False, "! Abandon de la procédure !"
return True, proxy
if __name__ == '__main__':
main()