Resolution du problme : les lignes d'historique n'avaient pas toutes la
mme tte... darcs-hash:20061216134726-f46e9-7f9ef3d06b998d6048e87ee475789a1b856d32df.gz
This commit is contained in:
parent
345e65bae7
commit
aa7dc31615
1 changed files with 62 additions and 41 deletions
|
@ -16,6 +16,14 @@ from ldap_crans import crans_ldap
|
||||||
from time import *
|
from time import *
|
||||||
from config import upload
|
from config import upload
|
||||||
import commands
|
import commands
|
||||||
|
# logging tools
|
||||||
|
import syslog
|
||||||
|
def log(x):
|
||||||
|
syslog.openlog('GENERATE_DECONNEXION_NOTICE')
|
||||||
|
syslog.syslog(x)
|
||||||
|
syslog.closelog()
|
||||||
|
|
||||||
|
import crans.utils.exceptions
|
||||||
|
|
||||||
import locale
|
import locale
|
||||||
locale.setlocale(locale.LC_TIME, 'fr_FR')
|
locale.setlocale(locale.LC_TIME, 'fr_FR')
|
||||||
|
@ -29,54 +37,67 @@ Les sanctions disponibles sont :
|
||||||
usage: generate.py --sanction recherche_ldap
|
usage: generate.py --sanction recherche_ldap
|
||||||
Le motif de recherche dans la base ldap doit donné un résultat unique""" % "\n\t--".join(map(lambda x: x,sanctions))
|
Le motif de recherche dans la base ldap doit donné un résultat unique""" % "\n\t--".join(map(lambda x: x,sanctions))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def generate_ps(sanction, proprio, db):
|
def generate_ps(sanction, proprio, db):
|
||||||
"""En fonction de la sanction à appliquer au propriétaire,
|
"""En fonction de la sanction à appliquer au propriétaire,
|
||||||
on génère la feuille de déconnexion et on retourne son nom et
|
on génère la feuille de déconnexion et on retourne son nom et
|
||||||
emplacement."""
|
emplacement."""
|
||||||
# Dossier de génération du ps
|
try:
|
||||||
dossier = '/usr/scripts/surveillance/fiche_deconnexion'
|
log('Generate deconnexion notice for %s' % proprio.Nom())
|
||||||
|
# Dossier de génération du ps
|
||||||
|
dossier = '/usr/scripts/surveillance/fiche_deconnexion'
|
||||||
|
|
||||||
# Base pour le nom du fichier
|
# Base pour le nom du fichier
|
||||||
fichier = strftime('%Y-%m-%d-%H-%M') + '-%s-%s' % (sanction, proprio.Nom().\
|
fichier = strftime('%Y-%m-%d-%H-%M') + '-%s-%s' % (sanction, proprio.Nom().\
|
||||||
lower().replace(' ', '-'))
|
lower().replace(' ', '-'))
|
||||||
|
|
||||||
# Création du fichier tex
|
# Création du fichier tex
|
||||||
format_date = '%A %d %B %Y'
|
format_date = '%A %d %B %Y'
|
||||||
template = file('%s/deconnexion_%s.tex' % (dossier, sanction)).read()
|
template = file('%s/deconnexion_%s.tex' % (dossier, sanction)).read()
|
||||||
template = template.replace('~prenom~', proprio.prenom().encode('iso8859-15'))
|
template = template.replace('~prenom~', proprio.prenom().encode('iso8859-15'))
|
||||||
template = template.replace('~nom~', proprio.nom().encode('iso8859-15'))
|
template = template.replace('~nom~', proprio.nom().encode('iso8859-15'))
|
||||||
template = template.replace('~chambre~', proprio.chbre().encode('iso8859-15'))
|
template = template.replace('~chambre~', proprio.chbre().encode('iso8859-15'))
|
||||||
template = template.replace('~mail~', proprio.email().encode('iso8859-15'))
|
template = template.replace('~mail~', proprio.email().encode('iso8859-15'))
|
||||||
template = template.replace('~debut~', strftime(format_date, localtime()))
|
template = template.replace('~debut~', strftime(format_date, localtime()))
|
||||||
template = template.replace('~fin~', strftime(format_date, localtime(time()+14*86400)))
|
template = template.replace('~fin~', strftime(format_date, localtime(time()+14*86400)))
|
||||||
# filtrage des autodisc
|
# filtrage des autodisc
|
||||||
historique = [ bl.encode('iso-8859-15').split('$') for bl in proprio.blacklist() if bl.split('$')[2] == 'autodisc_%s' % sanction ]
|
historique = [ bl.encode('iso-8859-15').split('$') for bl in proprio.blacklist() if bl.split('$')[2] == 'autodisc_%s' % sanction ]
|
||||||
# transfomation en tuple (date, sanction)
|
# transfomation en tuple (date, sanction)
|
||||||
historique = [ (strftime('%A %d %B %Y', localtime(int(bl[0]))), bl[-1].split(' ')[-2]) for bl in historique ]
|
historique = [ (strftime('%A %d %B %Y', localtime(int(bl[0]))), bl[-1]) for bl in historique ]
|
||||||
# tranformation en ligne
|
# tranformation en ligne
|
||||||
if sanction == 'upload' :
|
if sanction == 'upload' :
|
||||||
# On donne la valeur de l'upload
|
# On donne la valeur de l'upload
|
||||||
historique = [ '%s & %s & Mo'%(bl[0], bl[1]) for bl in historique ]
|
historique = [ '%s & %s & Mo'%(bl[0], bl[1].split(' ')[-2]) for bl in historique ]
|
||||||
else :
|
else :
|
||||||
# On donne juste la date
|
# On donne juste la date
|
||||||
historique = [ '%s' % bl[0] for bl in historique ]
|
historique = [ '%s' % bl[0] for bl in historique ]
|
||||||
# assemblage des lignes
|
# assemblage des lignes
|
||||||
historique = r"""\\
|
historique = r"""\\
|
||||||
""".join(historique)
|
""".join(historique)
|
||||||
template = template.replace('~historique~', historique)
|
template = template.replace('~historique~', historique)
|
||||||
if sanction == 'upload' :
|
if sanction == 'upload' :
|
||||||
template = template.replace('~limitehard~', str(upload.hard))
|
template = template.replace('~limitehard~', str(upload.hard))
|
||||||
template = template.replace('~nbadher~', str(len(db.search('paiement=ok')['adherent'])))
|
template = template.replace('~nbadher~', str(len(db.search('paiement=ok')['adherent'])))
|
||||||
|
|
||||||
file('%s/%s.tex' % (dossier, fichier), 'w').write(template)
|
file('%s/%s.tex' % (dossier, fichier), 'w').write(template)
|
||||||
|
|
||||||
# Compilation du fichier latex
|
# Compilation du fichier latex
|
||||||
commands.getstatusoutput('PATH="/bin:/usr/bin" cd %(dossier)s && latex %(base)s.tex && dvips %(base)s.dvi && rm -f %(base)s.dvi %(base)s.aux %(base)s.log %(base)s.tex'%{'dossier': dossier, 'base': fichier})
|
commands.getstatusoutput('PATH="/bin:/usr/bin" cd %(dossier)s && latex %(base)s.tex && dvips %(base)s.dvi && rm -f %(base)s.dvi %(base)s.aux %(base)s.log %(base)s.tex'%{'dossier': dossier, 'base': fichier})
|
||||||
|
|
||||||
return '%s/%s.ps' % (dossier, fichier)
|
|
||||||
|
|
||||||
|
return '%s/%s.ps' % (dossier, fichier)
|
||||||
|
except Exception, e:
|
||||||
|
log('Erreur lors de la génération du ps : ')
|
||||||
|
log(str(e))
|
||||||
|
log("Values : sanction:%s adherent:%s" % (sanction, proprio.Nom()))
|
||||||
|
log(crans.utils.exceptions.formatExc())
|
||||||
|
raise e
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
def log(x):
|
||||||
|
print x
|
||||||
|
|
||||||
def aide():
|
def aide():
|
||||||
print help
|
print help
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
@ -99,7 +120,7 @@ if __name__ == "__main__":
|
||||||
print "Erreur : aucun motif de recherche défini.\n"
|
print "Erreur : aucun motif de recherche défini.\n"
|
||||||
aide()
|
aide()
|
||||||
else :
|
else :
|
||||||
motif = sys.argv[2]
|
motif = sys.argv[-1]
|
||||||
|
|
||||||
recherche = db.search(motif)['adherent']
|
recherche = db.search(motif)['adherent']
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue