merge
This commit is contained in:
@@ -22,6 +22,8 @@ from user_agents import parse
|
||||
import json
|
||||
import locale
|
||||
import hashlib
|
||||
import imaplib
|
||||
import email
|
||||
|
||||
from ..models.default import *
|
||||
from ..models.agenda import *
|
||||
@@ -85,6 +87,93 @@ def home(request):
|
||||
'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 le nombre de mails en attente
|
||||
societes = ['PE','ME','PL','PO']
|
||||
|
||||
# critères de recherche des demandes d'interventions de la MAIF
|
||||
search_criteria = ['FROM gestionsinistre@maif.fr SUBJECT "Intervention entreprise partenaire"',
|
||||
'FROM service.sinistres@domus-services.fr UNDELETED']
|
||||
|
||||
nb_mails = 0
|
||||
# lister les demandes par societe
|
||||
for societe in societes:
|
||||
conn = mailbox_connect(request, societe)
|
||||
# select INBOX
|
||||
rv, data = conn.select('INBOX', readonly =True)
|
||||
|
||||
# créer la liste des entêtes des messages à afficher
|
||||
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'))
|
||||
|
||||
# ng de mails dans la mailbax
|
||||
nb_mails += len(data[0])
|
||||
|
||||
# deconnexion du serveur
|
||||
conn.close()
|
||||
conn.logout()
|
||||
|
||||
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': nb_mails,
|
||||
}
|
||||
|
||||
@view_config(route_name='envoyer_mdp', renderer='../templates/default/envoyer_mdp.pt')
|
||||
def envoyer_mdp(request):
|
||||
url = request.route_url('envoyer_mdp')
|
||||
@@ -118,7 +207,7 @@ gestion.entreprise-dumas.com
|
||||
request.session.flash(error, 'warning')
|
||||
else:
|
||||
request.session.flash("Le lien permettant pour 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))
|
||||
return HTTPFound(location=request.route_url('affiche_message', login=login))
|
||||
else:
|
||||
message = "Le mot de passe fourni est incorrect."
|
||||
return {
|
||||
@@ -338,5 +427,3 @@ def ajax_article(request):
|
||||
liste.append(d)
|
||||
|
||||
return Response(json.dumps(liste))
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user