diff --git a/development.ini b/development.ini
index 7bbc137..552442e 100644
--- a/development.ini
+++ b/development.ini
@@ -19,8 +19,8 @@ pyramid.includes =
pyramid_tm
-sqlalchemy.url = mysql://phuoc:phuoc!@localhost/bddevfac?charset=utf8
-#sqlalchemy.url = mysql://phuoc:phuoc!@192.168.1.17/bddevfac?charset=utf8
+#sqlalchemy.url = mysql://phuoc:phuoc!@localhost/bddevfac?charset=utf8
+sqlalchemy.url = mysql://phuoc:phuoc!@192.168.1.17/bddevfac?charset=utf8
# sqlalchemy.url = mysql://phuoc:phuoc!@192.168.0.31/bddevfac?charset=utf8
mondumas.admin_email = cao.thien-phuoc@orange.fr
diff --git a/mondumas/models/default.py b/mondumas/models/default.py
index bd59530..128f77a 100644
--- a/mondumas/models/default.py
+++ b/mondumas/models/default.py
@@ -1,131 +1,164 @@
-# -*- coding: utf8 -*-
-from sqlalchemy import text
-from sqlalchemy.ext.declarative import declarative_base
-from sqlalchemy.orm import (
- scoped_session,
- sessionmaker,
-)
-from zope.sqlalchemy import (
- ZopeTransactionExtension,
- mark_changed
-)
-
-from datetime import *
-import transaction
-
-def execute_query(request, query, params):
- """Execute query and mark session as changed"""
- request.dbsession.execute(query, params)
- mark_changed(request.dbsession)
- transaction.commit()
-
-def get_userAccess(request, logged_in):
- member = get_member_by_id(request, logged_in)
- if member:
- return member.access
- else:
- return 0
-
-def get_member_by_mdp_oublie(request, lien):
- query = "SELECT * FROM p_users WHERE mdp_oublie=:lien;"
- results = request.dbsession.execute(query, {'lien':lien}).first()
- return results
-
-def get_member_by_id(request, mbr_id):
- if mbr_id == '0':
- query = "SELECT * FROM p_users ORDER BY cd_uti"
- results = request.dbsession.execute(query).fetchall()
- else:
- # lire le membres par son identifianr
- query = """SELECT * FROM p_users WHERE CD_UTI=:mbr_id;"""
- results = request.dbsession.execute(query, {'mbr_id': mbr_id}).first()
- return results
-
-def get_member_info(request, logged_in):
- # lire le membres par son identifianr
- query = """SELECT nom, email, access, societe FROM p_users WHERE CD_UTI=:logged_in;"""
- results = request.dbsession.execute(query, {'logged_in': logged_in}).first()
- if results.access == 9:
- fonction = 'Administrateur'
- elif results.access == 8:
- fonction = 'Comptabilité'
- elif results.access == 5:
- fonction = 'Gestion'
- else:
- fonction = 'Production'
-
- return {
- 'nom': results.nom,
- 'email': results.email,
- 'fonction': fonction,
- 'societe': results.societe,
- }
-
-def update_membre_mdp_oublie(request, login):
- import uuid, base64
- # get a UUID - URL safe, Base64
-
- uid = uuid.uuid1()
- urlslug = base64.urlsafe_b64encode(uid.bytes).decode("utf-8").rstrip('=\n').replace('/', '_')
- query = "UPDATE p_users SET mdp_oublie=:urlslug, mdp_oublie_date=now() WHERE CD_UTI=:login;"
- execute_query(request, query, {'urlslug':urlslug, 'login':login})
-
- return urlslug
-
-def update_membre_mdp(request, login, password):
- """Update password for member login"""
- query = "UPDATE p_users SET mdp = SHA1(:password), mdp_oublie=NULL, mdp_oublie_date=NULL WHERE cd_uti=:login;"
- execute_query(request, query, {'login': login, 'password': password})
-
-def update_last_connection(request, login, ua_string):
- """Update last connection for login """
- query = "UPDATE p_users SET dern_cnx_le=NOW(), ua_string=:ua_string WHERE cd_uti=:login;"
- execute_query(request, query, {'login': login, 'ua_string': ua_string})
-
-def update_membre(request, cd_uti, new_values):
- # formater les champs
- s = ''
- for param in new_values.keys():
- if param == 'nom':
- new_values['nom'] = new_values['nom'].upper()
- if param == 'access':
- ' ne prend que le 1er caractère'
- new_values['access'] = new_values['access'][0]
-
- if s:
- s += ",%s=:%s" % (param, param)
- else:
- s = "%s=:%s" % (param, param)
-
- if cd_uti == '0':
- query = "INSERT INTO p_users SET %s" % s
- else:
- new_values['cd_uti'] = cd_uti
- query = "UPDATE p_users SET %s WHERE cd_uti = :cd_uti;" % s
- execute_query(request, query, new_values)
-
-def delete_membre(request, cd_uti):
- query = "DELETE FROM p_users WHERE cd_uti = :cd_uti ;"
- execute_query(request, query, {'cd_uti': cd_uti})
-
-def get_article(request, type, groupe, libelle):
- if type == 'LIB':
- if groupe == 'TEXTE':
- # lire tous les textes dont le libelle commençe par
- query = "SELECT * FROM tarifs WHERE groupe='TEXTE' and libelle like :libelle;"
- results = request.dbsession.execute(query, {'libelle': libelle + "%"}).fetchall()
- else:
- # lire tous les tarifs du grupe dont le ref commençe par libelle
- query = "SELECT * FROM tarifs WHERE groupe=:groupe and ref like :libelle;"
- results = request.dbsession.execute(query, {'groupe': groupe, 'libelle': libelle + "%"}).fetchall()
- else:
- # lire tous les tarif du grupe dont le ref est égale à
- query = "SELECT * FROM tarifs WHERE groupe=:groupe and ref = :libelle;"
- results = request.dbsession.execute(query, {'groupe': groupe, 'libelle': libelle}).first()
- return results
-
-def get_codespostaux(request, codep):
- query = "SELECT * FROM p_codespostaux WHERE code_postal LIKE :code;"
- results = request.dbsession.execute(query, {'code': codep+"%"}).fetchall()
- return results
-
+# -*- coding: utf8 -*-
+from sqlalchemy import text
+from sqlalchemy.ext.declarative import declarative_base
+from sqlalchemy.orm import (
+ scoped_session,
+ sessionmaker,
+)
+from zope.sqlalchemy import (
+ ZopeTransactionExtension,
+ mark_changed
+)
+
+from datetime import *
+import transaction
+
+def execute_query(request, query, params):
+ """Execute query and mark session as changed"""
+ request.dbsession.execute(query, params)
+ mark_changed(request.dbsession)
+ transaction.commit()
+
+def get_userAccess(request, logged_in):
+ member = get_member_by_id(request, logged_in)
+ if member:
+ return member.access
+ else:
+ return 0
+
+def get_member_by_mdp_oublie(request, lien):
+ query = "SELECT * FROM p_users WHERE mdp_oublie=:lien;"
+ results = request.dbsession.execute(query, {'lien':lien}).first()
+ return results
+
+def get_member_by_id(request, mbr_id):
+ if mbr_id == '0':
+ query = "SELECT * FROM p_users ORDER BY cd_uti"
+ results = request.dbsession.execute(query).fetchall()
+ else:
+ # lire le membres par son identifianr
+ query = """SELECT * FROM p_users WHERE CD_UTI=:mbr_id;"""
+ results = request.dbsession.execute(query, {'mbr_id': mbr_id}).first()
+ return results
+
+def get_member_info(request, logged_in):
+ # lire le membres par son identifianr
+ query = """SELECT nom, email, access, societe FROM p_users WHERE CD_UTI=:logged_in;"""
+ results = request.dbsession.execute(query, {'logged_in': logged_in}).first()
+ if results.access == 9:
+ fonction = 'Administrateur'
+ elif results.access == 8:
+ fonction = 'Comptabilité'
+ elif results.access == 5:
+ fonction = 'Gestion'
+ else:
+ fonction = 'Production'
+
+ return {
+ 'nom': results.nom,
+ 'email': results.email,
+ 'fonction': fonction,
+ 'societe': results.societe,
+ }
+
+def update_membre_mdp_oublie(request, login):
+ import uuid, base64
+ # get a UUID - URL safe, Base64
+
+ uid = uuid.uuid1()
+ urlslug = base64.urlsafe_b64encode(uid.bytes).decode("utf-8").rstrip('=\n').replace('/', '_')
+ query = "UPDATE p_users SET mdp_oublie=:urlslug, mdp_oublie_date=now() WHERE CD_UTI=:login;"
+ execute_query(request, query, {'urlslug':urlslug, 'login':login})
+
+ return urlslug
+
+def update_membre_mdp(request, login, password):
+ """Update password for member login"""
+ query = "UPDATE p_users SET mdp = SHA1(:password), mdp_oublie=NULL, mdp_oublie_date=NULL WHERE cd_uti=:login;"
+ execute_query(request, query, {'login': login, 'password': password})
+
+def update_last_connection(request, login, ua_string):
+ """Update last connection for login """
+ query = "UPDATE p_users SET dern_cnx_le=NOW(), ua_string=:ua_string WHERE cd_uti=:login;"
+ execute_query(request, query, {'login': login, 'ua_string': ua_string})
+
+def update_membre(request, cd_uti, new_values):
+ # formater les champs
+ s = ''
+ for param in new_values.keys():
+ if param == 'nom':
+ new_values['nom'] = new_values['nom'].upper()
+ if param == 'access':
+ ' ne prend que le 1er caractère'
+ new_values['access'] = new_values['access'][0]
+
+ if s:
+ s += ",%s=:%s" % (param, param)
+ else:
+ s = "%s=:%s" % (param, param)
+
+ if cd_uti == '0':
+ query = "INSERT INTO p_users SET %s" % s
+ else:
+ new_values['cd_uti'] = cd_uti
+ query = "UPDATE p_users SET %s WHERE cd_uti = :cd_uti;" % s
+ execute_query(request, query, new_values)
+
+def delete_membre(request, cd_uti):
+ query = "DELETE FROM p_users WHERE cd_uti = :cd_uti ;"
+ execute_query(request, query, {'cd_uti': cd_uti})
+
+def get_article(request, type, groupe, libelle):
+ if type == 'LIB':
+ if groupe == 'TEXTE':
+ # lire tous les textes dont le libelle commençe par
+ query = "SELECT * FROM tarifs WHERE groupe='TEXTE' and libelle like :libelle;"
+ results = request.dbsession.execute(query, {'libelle': libelle + "%"}).fetchall()
+ else:
+ # lire tous les tarifs du grupe dont le ref commençe par libelle
+ query = "SELECT * FROM tarifs WHERE groupe=:groupe and ref like :libelle;"
+ results = request.dbsession.execute(query, {'groupe': groupe, 'libelle': libelle + "%"}).fetchall()
+ else:
+ # lire tous les tarif du grupe dont le ref est égale à
+ query = "SELECT * FROM tarifs WHERE groupe=:groupe and ref = :libelle;"
+ results = request.dbsession.execute(query, {'groupe': groupe, 'libelle': libelle}).first()
+ return results
+
+def get_codespostaux(request, codep):
+ query = "SELECT * FROM p_codespostaux WHERE code_postal LIKE :code;"
+ results = request.dbsession.execute(query, {'code': codep+"%"}).fetchall()
+ return results
+
+def get_dd_restant(request):
+ query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
+ SUM(IF(societe='ME',1,0)) AS nb_ME,
+ SUM(IF(societe='PL',1,0)) AS nb_PL
+ FROM dem_devis WHERE STATUS=0;"""
+ results = request.dbsession.execute(query).first()
+ return results
+
+def get_de_restant(request):
+ query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
+ SUM(IF(societe='ME',1,0)) AS nb_ME,
+ SUM(IF(societe='PL',1,0)) AS nb_PL
+ FROM devis WHERE STATUS<4;"""
+ results = request.dbsession.execute(query).first()
+ return results
+
+def get_fa_restant(request):
+ query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
+ SUM(IF(societe='ME',1,0)) AS nb_ME,
+ SUM(IF(societe='PL',1,0)) AS nb_PL
+ FROM facture WHERE STATUS<8;"""
+ results = request.dbsession.execute(query).first()
+ return results
+
+def get_rdv_by_date(request, date, agenda):
+ query = """SELECT COUNT(*) AS nb_rdv FROM bddevfac.dem_lig WHERE DATEVI=:date AND LISTE=:agenda;"""
+ results = request.dbsession.execute(query, {'date': date, 'agenda': agenda}).first()
+ return results
+
+def get_rdf_null(request):
+ query = """SELECT COUNT(*) AS nb_rdf FROM bddevfac.dem_rdf WHERE date_relu IS NULL;"""
+ results = request.dbsession.execute(query).first()
+ return results
diff --git a/mondumas/models/dossier.py b/mondumas/models/dossier.py
index 876a021..fbba416 100644
--- a/mondumas/models/dossier.py
+++ b/mondumas/models/dossier.py
@@ -48,7 +48,7 @@ def get_dossier_by_sinistre(request,societe, nosin):
return results
def get_dossiers_traites(request):
- query = "SELECT d.*, s.libelle FROM dem_devis d JOIN p_statuts s ON d.STATUS = s.CODE WHERE d.usermaj='EMAIL' ORDER BY d.DATEMAJ";
+ query = "SELECT d.*, s.libelle FROM dem_devis d JOIN p_statuts s ON d.STATUS = s.CODE WHERE d.STATUS < 2 ORDER BY d.societe, d.STATUS, d.nomcli";
results = request.dbsession.execute(query).fetchall()
return results
@@ -336,4 +336,14 @@ def get_status_by_id(request, code):
else:
query = """SELECT * FROM p_statuts WHERE code = :code;"""
results = request.dbsession.execute(query, {'code': code}).first()
+ return results
+
+def get_devis_en_att(request):
+ query = "SELECT d.*, s.libelle FROM devis d JOIN p_statuts s ON d.STATUS = s.CODE WHERE d.STATUS < 4 ORDER BY d.societe, d.STATUS, d.nomcli;"
+ results = request.dbsession.execute(query).fetchall()
+ return results
+
+def get_factures_en_att(request):
+ query = "SELECT f.*, s.libelle FROM facture f JOIN p_statuts s ON f.STATUS = s.CODE WHERE f.STATUS < 8 ORDER BY f.societe, f.STATUS, f.nomcli;"
+ results = request.dbsession.execute(query).fetchall()
return results
\ No newline at end of file
diff --git a/mondumas/models/parametres.py b/mondumas/models/parametres.py
index 2cbc56e..0a8acef 100644
--- a/mondumas/models/parametres.py
+++ b/mondumas/models/parametres.py
@@ -226,38 +226,4 @@ def get_tarifs_byGroupe(request, groupe):
def get_tarif(request, groupe, ref):
query = "SELECT * FROM tarifs WHERE groupe = :groupe and ref = :ref;"
results = request.dbsession.execute(query, {'groupe': groupe, 'ref': ref}).first()
- return results
-
-def get_dd_restant(request):
- query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
- SUM(IF(societe='ME',1,0)) AS nb_ME,
- SUM(IF(societe='PL',1,0)) AS nb_PL
- FROM dem_devis WHERE STATUS=0;"""
- results = request.dbsession.execute(query).first()
- return results
-
-def get_de_restant(request):
- query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
- SUM(IF(societe='ME',1,0)) AS nb_ME,
- SUM(IF(societe='PL',1,0)) AS nb_PL
- FROM devis WHERE STATUS<4;"""
- results = request.dbsession.execute(query).first()
- return results
-
-def get_fa_restant(request):
- query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
- SUM(IF(societe='ME',1,0)) AS nb_ME,
- SUM(IF(societe='PL',1,0)) AS nb_PL
- FROM facture WHERE STATUS<8;"""
- results = request.dbsession.execute(query).first()
- return results
-
-def get_rdv_by_date(request, date, agenda):
- query = """SELECT COUNT(*) AS nb_rdv FROM bddevfac.dem_lig WHERE DATEVI=:date AND LISTE=:agenda;"""
- results = request.dbsession.execute(query, {'date': date, 'agenda': agenda}).first()
- return results
-
-def get_rdf_null(request):
- query = """SELECT COUNT(*) AS nb_rdf FROM bddevfac.dem_rdf WHERE date_relu IS NULL;"""
- results = request.dbsession.execute(query).first()
- return results
+ return results
\ No newline at end of file
diff --git a/mondumas/routes.py b/mondumas/routes.py
index 6964c8d..f627649 100644
--- a/mondumas/routes.py
+++ b/mondumas/routes.py
@@ -5,7 +5,7 @@ def includeme(config):
config.add_route('planning', '/planning/{date}')
config.add_route('rdv_edit','/rdv_edit/{nodossier}/{nolig}')
# default
- config.add_route('home', '/')
+ config.add_route('new_home', '/')
config.add_route('affiche_message','/affiche_message/{login}')
config.add_route('ajax_article', '/ajax_article')
config.add_route('ajax_client', '/ajax_client')
@@ -48,6 +48,8 @@ def includeme(config):
config.add_route('upload_img', '/upload_img/{norapport}/{origine}')
config.add_route('upload_om', '/upload_om')
config.add_route('dem_devis','/dem_devis')
+ config.add_route('devis_en_att','/devis_en_att')
+ config.add_route('factures_en_att','/factures_en_att')
# parametres
config.add_route('parametres', '/parametres')
config.add_route('article_edit', '/article_edit/{ref}')
@@ -73,7 +75,7 @@ def includeme(config):
config.add_route('user_edit', '/user_edit/{cd_uti}')
config.add_route('users', '/users')
config.add_route('users_ua', '/users_ua')
- config.add_route('new_home', '/new_home')
+ config.add_route('home', '/new_home')
# stats
config.add_route('stats', '/stats')
diff --git a/mondumas/templates/parametres/new_home.pt b/mondumas/templates/default/new_home.pt
similarity index 76%
rename from mondumas/templates/parametres/new_home.pt
rename to mondumas/templates/default/new_home.pt
index a93280c..0ea085f 100644
--- a/mondumas/templates/parametres/new_home.pt
+++ b/mondumas/templates/default/new_home.pt
@@ -104,28 +104,32 @@
-
diff --git a/mondumas/templates/dossier/devis_en_att.pt b/mondumas/templates/dossier/devis_en_att.pt
new file mode 100644
index 0000000..509af31
--- /dev/null
+++ b/mondumas/templates/dossier/devis_en_att.pt
@@ -0,0 +1,30 @@
+
+
+
+
+
diff --git a/mondumas/templates/dossier/factures_en_att.pt b/mondumas/templates/dossier/factures_en_att.pt
new file mode 100644
index 0000000..e9cfbac
--- /dev/null
+++ b/mondumas/templates/dossier/factures_en_att.pt
@@ -0,0 +1,30 @@
+
+
+
+
+
diff --git a/mondumas/views/default.py b/mondumas/views/default.py
index 5339b6b..4b5fcae 100644
--- a/mondumas/views/default.py
+++ b/mondumas/views/default.py
@@ -1,340 +1,465 @@
-# -*- coding: utf8 -*-
-from pyramid.response import Response
-from pyramid.renderers import render, get_renderer
-from pyramid.view import (
- view_config,
- forbidden_view_config,
-)
-from pyramid.security import (
- remember,
- forget,
-)
-from pyramid.httpexceptions import (
- HTTPFound,
- HTTPNotFound,
- HTTPForbidden,
-)
-from datetime import *
-from sqlalchemy.exc import DBAPIError
-from ..security import groupfinder
-from user_agents import parse
-
-import json
-import locale
-import hashlib
-
-from ..models.default import *
-from ..models.agenda import *
-from ..models.dossier import (
- get_chantiers_byName,
- get_clients_byName
-)
-
-from ..views.utils import *
-
-def to_decimal(x):
- import decimal
- return decimal.Decimal(str(x))
-
-def to_euro(x):
- """Takes a float and returns 12 345,67 €"""
- locale.setlocale(locale.LC_ALL,'')
- return locale.currency(x, True, True)
-
-def to_euroz(x):
- """Takes a float and returns 12 345,67 € if not zero"""
- if x == 0:
- return ''
- else:
- return to_euro(x)
-
-def to_decz(x):
- """Takes a float and returns a number with 2 dec"""
- locale.setlocale(locale.LC_ALL,'')
- if x == 0:
- return ""
- else:
- return locale.format_string('%.2f',x, False)
-
-def to_sha1(message):
- return hashlib.sha1(message.encode('utf-8')).hexdigest()
-
-def to_int(x):
- try:
- number = int(x.replace(',', '.'))
- return number
- except ValueError:
- return 0
-
-def to_percent(x):
- """Takes a float and returns a string"""
- return ("%.2f " % x).replace('.', ',') + "%"
-
-
-@view_config(route_name='home', renderer='../templates/default/home.pt', permission='view')
-def home(request):
- logged_in = request.authenticated_userid.upper()
- # lire la fiche de l'utilisateur
- member = get_member_by_id(request, logged_in)
- access = member.access
-
- return {
- 'page_title': 'Bienvenue sur %s' % request.host,
- 'project': 'mondumas',
- 'access': access,
- 'logged_in': logged_in,
- }
-
-@view_config(route_name='envoyer_mdp', renderer='../templates/default/envoyer_mdp.pt')
-def envoyer_mdp(request):
- url = request.route_url('envoyer_mdp')
- message = ''
-
- if 'form.submitted' in request.params:
- login = request.params['login']
- member = get_member_by_id(request, login)
- if member:
- # Fabrication du corps du email_passwordMessage
- lien = update_membre_mdp_oublie(request, login)
- body = """
-
Bonjour,
-
-
Le lien suivant vous dirigera vers une page où vous pourrez ré-initialiser votre mot de passe d'accès à gestion.entreprise-dumas.com:
-
-
%s
-
-
(Ce lien est valide pendant 168 heures.
-
-
-
-Cordialement,
-gestion.entreprise-dumas.com
-
-""" % (request.route_url('redefinir_mdp', lien=lien))
- # envoyer l'email
- expediteur = request.registry.settings['mondumas.admin_email']
- send_mail(request, expediteur, [member.email,], "[Ent. Dumas] Demande de ré-initialisation du mot de passe", body)
-
- request.session.flash("Le lien permettant de redéfinir votre mot de passe vous a été envoyé à l'adresse : %s." % member.email, 'success')
- return HTTPFound(location=request.route_url('affiche_message', login=login))
- else:
- message = "Le mot de passe fourni est incorrect."
- return {
- 'page_title': "Changer mon mot de passe",
- 'url': url,
- 'message': message,
- }
-
-@view_config(route_name='changer_mdp', renderer='../templates/default/changer_mdp.pt', permission='view')
-def changer_mdp(request):
- url = request.route_url('changer_mdp')
- logged_in = request.authenticated_userid
- message = ''
-
- member = get_member_by_id(request, logged_in)
- if member:
- if 'form.submitted' in request.params:
- old_password = request.params['old_password']
- new_password = request.params['new_password1']
- if member.mdp == to_sha1(old_password):
- update_membre_mdp(request, logged_in, new_password)
- request.session.flash("Votre mot de passe a été mis à jour avec succès.")
- return HTTPFound(location=request.route_url('home'))
- else:
- message = "Le mot de passe actuel n'est pas correct."
-
- return {
- 'page_title': "Changer mon mot de passe",
- 'url': url,
- 'member': member,
- 'message': message,
- }
-
-@view_config(route_name='redefinir_mdp', renderer='../templates/default/redefinir_mdp.pt')
-@view_config(route_name='init_mdp', renderer='../templates/default/redefinir_mdp.pt')
-def redefinir_mdp(request):
- if request.matched_route.name == 'redefinir_mdp':
- lien = request.matchdict["lien"]
- url = request.route_url('redefinir_mdp', lien=lien)
- # tester si le champ "motdepasse_oublie" est encore valide
- membre = get_member_by_mdp_oublie(request, lien)
- else:
- user = request.matchdict["user"]
- lien = request.matchdict["lien"]
- url = request.route_url('init_mdp', user=user, lien=lien)
- # tester valeur OK ?
- if lien == date.today().strftime('%d%m%Y'):
- # oui, lire le membre
- membre = get_member_by_id(request, user)
- else:
- membre = None
-
- if membre:
- if 'form.submitted' in request.params:
- login = request.params["login"]
- mdp = request.params["new_password1"]
- if login == membre.CD_UTI:
- update_membre_mdp(request, login, mdp)
- request.session.flash("Votre mot de passe a été modifié avec succès.", 'success')
- return HTTPFound(location=request.route_url('login'))
- else:
- request.session.flash("Identifiant incorrect.", 'danger')
- return HTTPFound(location=request.route_url('login'))
- else:
- request.session.flash("Le lien n'est plus valable.", 'warning')
- return HTTPFound(location=request.route_url('login'))
-
- return {
- 'page_title': "Définissez votre mot de passe",
- 'url': url,
- }
-
-
-@view_config(route_name='login', renderer='../templates/default/login.pt', permission='view')
-@view_config(route_name='login_as', renderer='../templates/default/login.pt', permission='view')
-@forbidden_view_config(renderer='../templates/default/login.pt')
-def login(request):
-
- current_route_path = request.current_route_path()
- login = ''
- login_url = request.route_url('login')
-
- referrer = request.url
- if referrer == login_url:
- referrer = '/' # never use the login form itself as came_from
-
- came_from = request.params.get('came_from', referrer)
- password = ''
- message = ''
- if 'form.submitted' in request.params:
- login = request.params['login']
- password = request.params['password']
- record = get_member_by_id(request, login)
- if record :
- # mot de passe hash valide ?
- if record.mdp == to_sha1(password) and record.actif == 1:
- # get user agent string from request
- ua_string = request.user_agent
- user_agent = parse(ua_string)
- update_last_connection(request, login, request.client_addr + ' - ' + str(user_agent))
-
- # force le commit car il ne se fait pas automatiquement après l'update
- transaction.commit()
-
- headers = remember(request, login)
- return HTTPFound(location=came_from, headers=headers)
-
- message = "Email et mot de passe invalides. La connexion a échoué."
-
- return {
- 'page_title': "",
- 'url': login_url,
- 'came_from': came_from,
- 'login': login,
- 'message': message,
- }
-
-
-@view_config(route_name='logout')
-def logout(request):
- request.session.invalidate()
- headers = forget(request)
- request.session.flash("Vous avez bien été déconnecté.")
- return HTTPFound(location=request.route_url('login', login=''),
- headers=headers)
-
-
-@view_config(route_name='affiche_message', renderer='../templates/default/affiche_message.pt')
-def affiche_message(request):
-
- login = request.matchdict['login']
- messages = request.session.pop_flash()
-
- return {
- 'page_title': "Demande effectuée",
- 'login': login,
- 'messages' : messages,
- 'url_identification': request.route_url('login_as', login=login)
- }
-
-@view_config(route_name='ajax_codepostal')
-def ajax_codepostal(request):
- recherche = request.GET['recherche']
-
- # lire les codes postaux commencant par
- items = get_codespostaux(request, recherche)
- liste=[]
- for row in items:
- d = row.code_postal + " - " + row.libelle
- liste.append(d)
-
- return Response(json.dumps(liste))
-
-@view_config(route_name='ajax_lookup')
-def ajax_lookup(request):
- recherche = request.GET['recherche']
- societe = recherche[:2] # 1er car.
- name = recherche[2:]
-
- # lire les chantiers
- chantiers = get_chantiers_byName(request, societe, name)
- liste=[]
- for row in chantiers:
- d = "%s | %s-%s"% (row.chantier, societe, row.numero)
- liste.append(d)
-
- return Response(json.dumps(liste))
-
-@view_config(route_name='ajax_client')
-def ajax_client(request):
- recherche = request.GET['recherche']
- societe = recherche[:2] # 1er car.
- name = recherche[2:]
-
- # lire les clients
- clients = get_clients_byName(request, societe, name)
- liste=[]
- for row in clients:
- d = "%s | %s-%s"% (row.NOM, societe, row.CD_CLI)
- liste.append(d)
-
- return Response(json.dumps(liste))
-
-@view_config(route_name='ajax_texte')
-def ajax_texte(request):
- groupe = request.GET['groupe']
- libelle = request.GET['libelle']
-
- # import pdb;pdb.set_trace()
-
- # lire les articles commencant par
- items = get_article(request, 'LIB', groupe, libelle)
-
- liste=[]
- for row in items:
- if groupe == 'TEXTE':
- d = row.libelle
- else:
- d = '%s | %s | %s' % (row.ref, row.libelle, to_euro(row.prixht))
- liste.append(d)
-
- return Response(json.dumps(liste))
-
-@view_config(route_name='ajax_article')
-def ajax_article(request):
- groupe = request.GET['groupe']
- ref = request.GET['ref']
-
- # lire l'article
- items = get_article(request, 'REF', groupe, ref)
- # puis retourne son libellé et son prixht
- liste=[]
- d = {}
- d['ref'] = items.ref
- d['libelle'] = items.libelle
- d['prixht'] = "%.2f" % items.prixht
- liste.append(d)
-
- return Response(json.dumps(liste))
-
-
+# -*- coding: utf8 -*-
+from pyramid.response import Response
+from pyramid.renderers import render, get_renderer
+from pyramid.view import (
+ view_config,
+ forbidden_view_config,
+)
+from pyramid.security import (
+ remember,
+ forget,
+)
+from pyramid.httpexceptions import (
+ HTTPFound,
+ HTTPNotFound,
+ HTTPForbidden,
+)
+from datetime import *
+from sqlalchemy.exc import DBAPIError
+from ..security import groupfinder
+from user_agents import parse
+
+import json
+import locale
+import hashlib
+import imaplib
+import email
+
+from ..models.default import *
+from ..models.agenda import *
+from ..models.dossier import (
+ get_chantiers_byName,
+ get_clients_byName
+)
+
+from ..views.utils import *
+
+def to_decimal(x):
+ import decimal
+ return decimal.Decimal(str(x))
+
+def to_euro(x):
+ """Takes a float and returns 12 345,67 €"""
+ locale.setlocale(locale.LC_ALL,'')
+ return locale.currency(x, True, True)
+
+def to_euroz(x):
+ """Takes a float and returns 12 345,67 € if not zero"""
+ if x == 0:
+ return ''
+ else:
+ return to_euro(x)
+
+def to_decz(x):
+ """Takes a float and returns a number with 2 dec"""
+ locale.setlocale(locale.LC_ALL,'')
+ if x == 0:
+ return ""
+ else:
+ return locale.format_string('%.2f',x, False)
+
+def to_sha1(message):
+ return hashlib.sha1(message.encode('utf-8')).hexdigest()
+
+def to_int(x):
+ try:
+ number = int(x.replace(',', '.'))
+ return number
+ except ValueError:
+ return 0
+
+def to_percent(x):
+ """Takes a float and returns a string"""
+ return ("%.2f " % x).replace('.', ',') + "%"
+
+
+@view_config(route_name='home', renderer='../templates/default/home.pt', permission='view')
+def home(request):
+ logged_in = request.authenticated_userid.upper()
+ # lire la fiche de l'utilisateur
+ member = get_member_by_id(request, logged_in)
+ access = member.access
+
+ return {
+ 'page_title': 'Bienvenue sur %s' % request.host,
+ 'project': 'mondumas',
+ 'access': access,
+ 'logged_in': logged_in,
+ }
+
+def mailbox_connect(request, societe):
+ # connecter au serveur IMAP de la societe
+ if societe == 'PE':
+ mbx_name = 'peinture-dumas@entreprise-dumas.com'
+ mbx_pwd = 'sasdumas'
+ elif societe == 'ME':
+ mbx_name = 'menuiserie-dumas@entreprise-dumas.com'
+ mbx_pwd = 'sasdumas'
+ elif societe == 'PL':
+ mbx_name = 'versanit-dumas@entreprise-dumas.com'
+ mbx_pwd = 'sasdumas'
+ elif societe == 'PO':
+ mbx_name = 'polynet-dumas@entreprise-dumas.com'
+ mbx_pwd = 'sasdumas'
+ else:
+ request.session.flash("Cette société est inconnue ou non traitée : %s" % societe, 'danger')
+ return None
+
+ conn = imaplib.IMAP4_SSL('imap.entreprise-dumas.com')
+ try:
+ # se connecter à la mailbox
+ conn.login(mbx_name, mbx_pwd)
+ except imaplib.IMAP4.error:
+ request.session.flash("ERREUR connexion au compte %s" % mbx_name, 'danger')
+ return None
+
+ return conn
+
+@view_config(route_name='new_home', renderer='../templates/default/new_home.pt', permission='view')
+def new_home(request):
+ logged_in = request.authenticated_userid.upper()
+ url = request.route_url('new_home')
+ # lire la fiche de l'utilisateur
+ member = get_member_by_id(request, logged_in)
+ access = member.access
+ agenda = member.agenda
+
+ datedeb = date.today().strftime("%Y-%m-%d")
+
+ nb_dd_restants = get_dd_restant(request)
+ nb_de_restants = get_de_restant(request)
+ nb_fa_restants = get_fa_restant(request)
+
+ nb_rdv = get_rdv_by_date(request, datedeb, agenda)
+ nb_rdf = get_rdf_null(request)
+
+ # Récupération de la listes des mails pour ensuite avoir leur nombre
+ def demandes_lister(societe, search_criteria):
+ # connecter au serveur de mail
+ conn = mailbox_connect(request, societe)
+ # select INBOX
+ rv, data = conn.select('INBOX', readonly =True)
+
+ # créer la liste des entêtes des messages à afficher
+ liste = []
+ for criteria in search_criteria:
+ rv, data = conn.search(None, criteria)
+ if rv != 'OK':
+ request.session.flash("ERREUR de lecture de la boîte de réception", 'danger')
+ return HTTPFound(location=request.route_url('home'))
+
+ mail_ids = data[0]
+ for email_UID in mail_ids.split():
+ rv, msg_data = conn.fetch(email_UID, '(RFC822)')
+ if rv != 'OK':
+ request.session.flash("ERREUR de lecture du message %s" % email_UID, 'danger')
+ return HTTPFound(location=request.route_url('home'))
+
+ msg = email.message_from_bytes(msg_data[0][1])
+ hdr = email.header.make_header(email.header.decode_header(msg['Subject']))
+ email_subject = str(hdr)
+ email_from = email.utils.parseaddr(msg['from'])[1]
+ # Now convert to local date-time
+ date_tuple = email.utils.parsedate_tz(msg['Date'])
+ if date_tuple:
+ email_date = datetime.fromtimestamp(email.utils.mktime_tz(date_tuple))
+ else:
+ email_date = datetime.now()
+
+ d = {
+ "email_societe": societe,
+ "email_date": email_date,
+ "email_from": email_from.split('@')[1],
+ 'email_subject':email_subject,
+ "email_uid": email_UID
+ }
+ liste.append(d)
+
+ # deconnexion du serveur
+ conn.close()
+ conn.logout()
+ return liste
+
+ societes = ['PE','ME','PL','PO']
+
+ # critères de recherche des demandes d'interventions de la MAIF
+ # search_criteria = ['FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED'] "
+ search_criteria = ['FROM gestionsinistre@maif.fr SUBJECT "Intervention entreprise partenaire"',
+ 'FROM service.sinistres@domus-services.fr UNDELETED']
+ # 'FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED']
+
+ emails=[]
+ # lister les demandes par societe
+ for societe in societes:
+ emails = emails + demandes_lister(societe, search_criteria)
+
+ # messages lus
+ msglus = bool(emails)
+
+ return {
+ 'page_title': 'Bienvenue sur %s' % request.host,
+ 'project': 'mondumas',
+ 'access': access,
+ 'logged_in': logged_in,
+ 'nb_dd_restants': nb_dd_restants,
+ 'nb_de_restants': nb_de_restants,
+ 'nb_fa_restants': nb_fa_restants,
+ 'nb_rdv': nb_rdv,
+ 'nb_rdf': nb_rdf,
+ 'nb_mails': len(emails),
+ #'mails': emails,
+ }
+
+@view_config(route_name='envoyer_mdp', renderer='../templates/default/envoyer_mdp.pt')
+def envoyer_mdp(request):
+ url = request.route_url('envoyer_mdp')
+ message = ''
+
+ if 'form.submitted' in request.params:
+ login = request.params['login']
+ member = get_member_by_id(request, login)
+ if member:
+ # Fabrication du corps du email_passwordMessage
+ lien = update_membre_mdp_oublie(request, login)
+ body = """
+
Bonjour,
+
+
Le lien suivant vous dirigera vers une page où vous pourrez ré-initialiser votre mot de passe d'accès à gestion.entreprise-dumas.com:
+
+
%s
+
+
(Ce lien est valide pendant 168 heures.
+
+
+
+Cordialement,
+gestion.entreprise-dumas.com
+
+""" % (request.route_url('redefinir_mdp', lien=lien))
+ # envoyer l'email
+ expediteur = request.registry.settings['mondumas.admin_email']
+ send_mail(request, expediteur, [member.email,], "[Ent. Dumas] Demande de ré-initialisation du mot de passe", body)
+
+ request.session.flash("Le lien permettant de redéfinir votre mot de passe vous a été envoyé à l'adresse : %s." % member.email, 'success')
+ return HTTPFound(location=request.route_url('affiche_message', login=login))
+ else:
+ message = "Le mot de passe fourni est incorrect."
+ return {
+ 'page_title': "Changer mon mot de passe",
+ 'url': url,
+ 'message': message,
+ }
+
+@view_config(route_name='changer_mdp', renderer='../templates/default/changer_mdp.pt', permission='view')
+def changer_mdp(request):
+ url = request.route_url('changer_mdp')
+ logged_in = request.authenticated_userid
+ message = ''
+
+ member = get_member_by_id(request, logged_in)
+ if member:
+ if 'form.submitted' in request.params:
+ old_password = request.params['old_password']
+ new_password = request.params['new_password1']
+ if member.mdp == to_sha1(old_password):
+ update_membre_mdp(request, logged_in, new_password)
+ request.session.flash("Votre mot de passe a été mis à jour avec succès.")
+ return HTTPFound(location=request.route_url('home'))
+ else:
+ message = "Le mot de passe actuel n'est pas correct."
+
+ return {
+ 'page_title': "Changer mon mot de passe",
+ 'url': url,
+ 'member': member,
+ 'message': message,
+ }
+
+@view_config(route_name='redefinir_mdp', renderer='../templates/default/redefinir_mdp.pt')
+@view_config(route_name='init_mdp', renderer='../templates/default/redefinir_mdp.pt')
+def redefinir_mdp(request):
+ if request.matched_route.name == 'redefinir_mdp':
+ lien = request.matchdict["lien"]
+ url = request.route_url('redefinir_mdp', lien=lien)
+ # tester si le champ "motdepasse_oublie" est encore valide
+ membre = get_member_by_mdp_oublie(request, lien)
+ else:
+ user = request.matchdict["user"]
+ lien = request.matchdict["lien"]
+ url = request.route_url('init_mdp', user=user, lien=lien)
+ # tester valeur OK ?
+ if lien == date.today().strftime('%d%m%Y'):
+ # oui, lire le membre
+ membre = get_member_by_id(request, user)
+ else:
+ membre = None
+
+ if membre:
+ if 'form.submitted' in request.params:
+ login = request.params["login"]
+ mdp = request.params["new_password1"]
+ if login == membre.CD_UTI:
+ update_membre_mdp(request, login, mdp)
+ request.session.flash("Votre mot de passe a été modifié avec succès.", 'success')
+ return HTTPFound(location=request.route_url('login'))
+ else:
+ request.session.flash("Identifiant incorrect.", 'danger')
+ return HTTPFound(location=request.route_url('login'))
+ else:
+ request.session.flash("Le lien n'est plus valable.", 'warning')
+ return HTTPFound(location=request.route_url('login'))
+
+ return {
+ 'page_title': "Définissez votre mot de passe",
+ 'url': url,
+ }
+
+
+@view_config(route_name='login', renderer='../templates/default/login.pt', permission='view')
+@view_config(route_name='login_as', renderer='../templates/default/login.pt', permission='view')
+@forbidden_view_config(renderer='../templates/default/login.pt')
+def login(request):
+
+ current_route_path = request.current_route_path()
+ login = ''
+ login_url = request.route_url('login')
+
+ referrer = request.url
+ if referrer == login_url:
+ referrer = '/' # never use the login form itself as came_from
+
+ came_from = request.params.get('came_from', referrer)
+ password = ''
+ message = ''
+ if 'form.submitted' in request.params:
+ login = request.params['login']
+ password = request.params['password']
+ record = get_member_by_id(request, login)
+ if record :
+ # mot de passe hash valide ?
+ if record.mdp == to_sha1(password) and record.actif == 1:
+ # get user agent string from request
+ ua_string = request.user_agent
+ user_agent = parse(ua_string)
+ update_last_connection(request, login, request.client_addr + ' - ' + str(user_agent))
+
+ # force le commit car il ne se fait pas automatiquement après l'update
+ transaction.commit()
+
+ headers = remember(request, login)
+ return HTTPFound(location=came_from, headers=headers)
+
+ message = "Email et mot de passe invalides. La connexion a échoué."
+
+ return {
+ 'page_title': "",
+ 'url': login_url,
+ 'came_from': came_from,
+ 'login': login,
+ 'message': message,
+ }
+
+
+@view_config(route_name='logout')
+def logout(request):
+ request.session.invalidate()
+ headers = forget(request)
+ request.session.flash("Vous avez bien été déconnecté.")
+ return HTTPFound(location=request.route_url('login', login=''),
+ headers=headers)
+
+
+@view_config(route_name='affiche_message', renderer='../templates/default/affiche_message.pt')
+def affiche_message(request):
+
+ login = request.matchdict['login']
+ messages = request.session.pop_flash()
+
+ return {
+ 'page_title': "Demande effectuée",
+ 'login': login,
+ 'messages' : messages,
+ 'url_identification': request.route_url('login_as', login=login)
+ }
+
+@view_config(route_name='ajax_codepostal')
+def ajax_codepostal(request):
+ recherche = request.GET['recherche']
+
+ # lire les codes postaux commencant par
+ items = get_codespostaux(request, recherche)
+ liste=[]
+ for row in items:
+ d = row.code_postal + " - " + row.libelle
+ liste.append(d)
+
+ return Response(json.dumps(liste))
+
+@view_config(route_name='ajax_lookup')
+def ajax_lookup(request):
+ recherche = request.GET['recherche']
+ societe = recherche[:2] # 1er car.
+ name = recherche[2:]
+
+ # lire les chantiers
+ chantiers = get_chantiers_byName(request, societe, name)
+ liste=[]
+ for row in chantiers:
+ d = "%s | %s-%s"% (row.chantier, societe, row.numero)
+ liste.append(d)
+
+ return Response(json.dumps(liste))
+
+@view_config(route_name='ajax_client')
+def ajax_client(request):
+ recherche = request.GET['recherche']
+ societe = recherche[:2] # 1er car.
+ name = recherche[2:]
+
+ # lire les clients
+ clients = get_clients_byName(request, societe, name)
+ liste=[]
+ for row in clients:
+ d = "%s | %s-%s"% (row.NOM, societe, row.CD_CLI)
+ liste.append(d)
+
+ return Response(json.dumps(liste))
+
+@view_config(route_name='ajax_texte')
+def ajax_texte(request):
+ groupe = request.GET['groupe']
+ libelle = request.GET['libelle']
+
+ # import pdb;pdb.set_trace()
+
+ # lire les articles commencant par
+ items = get_article(request, 'LIB', groupe, libelle)
+
+ liste=[]
+ for row in items:
+ if groupe == 'TEXTE':
+ d = row.libelle
+ else:
+ d = '%s | %s | %s' % (row.ref, row.libelle, to_euro(row.prixht))
+ liste.append(d)
+
+ return Response(json.dumps(liste))
+
+@view_config(route_name='ajax_article')
+def ajax_article(request):
+ groupe = request.GET['groupe']
+ ref = request.GET['ref']
+
+ # lire l'article
+ items = get_article(request, 'REF', groupe, ref)
+ # puis retourne son libellé et son prixht
+ liste=[]
+ d = {}
+ d['ref'] = items.ref
+ d['libelle'] = items.libelle
+ d['prixht'] = "%.2f" % items.prixht
+ liste.append(d)
+
+ return Response(json.dumps(liste))
+
+
diff --git a/mondumas/views/dossier.py b/mondumas/views/dossier.py
index 9990145..2cb2097 100644
--- a/mondumas/views/dossier.py
+++ b/mondumas/views/dossier.py
@@ -844,34 +844,6 @@ def rdf_bill(request):
'articles': articles,
'article' : article,
}
-
-def mailbox_connect(request, societe):
- # connecter au serveur IMAP de la societe
- if societe == 'PE':
- mbx_name = 'peinture-dumas@entreprise-dumas.com'
- mbx_pwd = 'sasdumas'
- elif societe == 'ME':
- mbx_name = 'menuiserie-dumas@entreprise-dumas.com'
- mbx_pwd = 'sasdumas'
- elif societe == 'PL':
- mbx_name = 'versanit-dumas@entreprise-dumas.com'
- mbx_pwd = 'sasdumas'
- elif societe == 'PO':
- mbx_name = 'polynet-dumas@entreprise-dumas.com'
- mbx_pwd = 'sasdumas'
- else:
- request.session.flash("Cette société est inconnue ou non traitée : %s" % societe, 'danger')
- return None
-
- conn = imaplib.IMAP4_SSL('imap.entreprise-dumas.com')
- try:
- # se connecter à la mailbox
- conn.login(mbx_name, mbx_pwd)
- except imaplib.IMAP4.error:
- request.session.flash("ERREUR connexion au compte %s" % mbx_name, 'danger')
- return None
-
- return conn
@view_config(route_name='demandes', renderer='../templates/dossier/demandes.pt', permission='view')
def demandes(request):
@@ -1582,4 +1554,30 @@ def dem_devis(request):
'page_title': 'Dossiers générés à traiter',
'url': url,
'dossiers_traites':dossiers_traites,
+ }
+
+@view_config(route_name='devis_en_att', renderer='../templates/dossier/devis_en_att.pt', permission='view')
+def dem_devis(request):
+ logged_in = request.authenticated_userid.upper()
+ url = request.route_url('devis_en_att')
+
+ list_devis_en_att = get_devis_en_att(request)
+
+ return {
+ 'page_title': "Devis en attente d'acceptation",
+ 'url': url,
+ 'list_devis_en_att':list_devis_en_att,
+ }
+
+@view_config(route_name='factures_en_att', renderer='../templates/dossier/factures_en_att.pt', permission='view')
+def dem_devis(request):
+ logged_in = request.authenticated_userid.upper()
+ url = request.route_url('factures_en_att')
+
+ list_factures_en_att = get_factures_en_att(request)
+
+ return {
+ 'page_title': "Factures en attente de réglement",
+ 'url': url,
+ 'list_factures_en_att':list_factures_en_att,
}
\ No newline at end of file
diff --git a/mondumas/views/parametres.py b/mondumas/views/parametres.py
index 336dea1..4495458 100644
--- a/mondumas/views/parametres.py
+++ b/mondumas/views/parametres.py
@@ -837,99 +837,4 @@ def tarifs_import(request):
'message': message,
'groupes': groupes,
'groupe': groupe,
- }
-
-@view_config(route_name='new_home', renderer='../templates/parametres/new_home.pt', permission='view')
-def new_home(request):
- logged_in = request.authenticated_userid.upper()
- url = request.route_url('new_home')
- # lire la fiche de l'utilisateur
- member = get_member_by_id(request, logged_in)
- access = member.access
- agenda = member.agenda
-
- datedeb = date.today().strftime("%Y-%m-%d")
-
- nb_dd_restants = get_dd_restant(request)
- nb_de_restants = get_de_restant(request)
- nb_fa_restants = get_fa_restant(request)
-
- nb_rdv = get_rdv_by_date(request, datedeb, agenda)
- nb_rdf = get_rdf_null(request)
-
- # Récupération de la listes des mails pour ensuite avoir leur nombre
- def demandes_lister(societe, search_criteria):
- # connecter au serveur de mail
- conn = mailbox_connect(request, societe)
- # select INBOX
- rv, data = conn.select('INBOX', readonly =True)
-
- # créer la liste des entêtes des messages à afficher
- liste = []
- for criteria in search_criteria:
- rv, data = conn.search(None, criteria)
- if rv != 'OK':
- request.session.flash("ERREUR de lecture de la boîte de réception", 'danger')
- return HTTPFound(location=request.route_url('home'))
-
- mail_ids = data[0]
- for email_UID in mail_ids.split():
- rv, msg_data = conn.fetch(email_UID, '(RFC822)')
- if rv != 'OK':
- request.session.flash("ERREUR de lecture du message %s" % email_UID, 'danger')
- return HTTPFound(location=request.route_url('home'))
-
- msg = email.message_from_bytes(msg_data[0][1])
- hdr = email.header.make_header(email.header.decode_header(msg['Subject']))
- email_subject = str(hdr)
- email_from = email.utils.parseaddr(msg['from'])[1]
- # Now convert to local date-time
- date_tuple = email.utils.parsedate_tz(msg['Date'])
- if date_tuple:
- email_date = datetime.fromtimestamp(email.utils.mktime_tz(date_tuple))
- else:
- email_date = datetime.now()
-
- d = {
- "email_societe": societe,
- "email_date": email_date,
- "email_from": email_from.split('@')[1],
- 'email_subject':email_subject,
- "email_uid": email_UID
- }
- liste.append(d)
-
- # deconnexion du serveur
- conn.close()
- conn.logout()
- return liste
-
- societes = ['PE','ME','PL','PO']
-
- # critères de recherche des demandes d'interventions de la MAIF
- # search_criteria = ['FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED'] "
- search_criteria = ['FROM gestionsinistre@maif.fr SUBJECT "Intervention entreprise partenaire"',
- 'FROM service.sinistres@domus-services.fr UNDELETED']
- # 'FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED']
-
- emails=[]
- # lister les demandes par societe
- for societe in societes:
- emails = emails + demandes_lister(societe, search_criteria)
-
- # messages lus
- msglus = bool(emails)
-
- return {
- 'page_title': 'Bienvenue sur %s' % request.host,
- 'project': 'mondumas',
- 'access': access,
- 'logged_in': logged_in,
- 'nb_dd_restants': nb_dd_restants,
- 'nb_de_restants': nb_de_restants,
- 'nb_fa_restants': nb_fa_restants,
- 'nb_rdv': nb_rdv,
- 'nb_rdf': nb_rdf,
- 'nb_mails': len(emails),
- #'mails': emails,
}
\ No newline at end of file
diff --git a/mondumas/views/stats.py b/mondumas/views/stats.py
index 23a8ac8..bfd487b 100644
--- a/mondumas/views/stats.py
+++ b/mondumas/views/stats.py
@@ -176,8 +176,8 @@ def ca_groupes(request):
print(datedeb)
chart_ca_12m = []
# titre des colonnes
- chart_ca_12m.append(('Mois', 'AXA', { 'type':'string','role': 'tooltip'}, 'MAIF', { 'type':'string','role': 'tooltip'},'DOMUS', { 'type':'string','role': 'tooltip'},
- 'GMF', { 'type':'string','role': 'tooltip'},'MACIF', { 'type':'string','role': 'tooltip'}))
+ chart_ca_12m.append(('Mois', 'AXA', { 'type':'string','role': 'tooltip'},'DOMUS', { 'type':'string','role': 'tooltip'},
+ 'GMF', { 'type':'string','role': 'tooltip'},'MACIF', { 'type':'string','role': 'tooltip'}, 'MAIF', { 'type':'string','role': 'tooltip'}))
title = 'CA sur 12 mois'
for item in items:
date_aff = item.date[:3] + ' ' + item.date[-4:]