[mail] On utilise l'extension pour choisir un moteur de rendu
NB: il n'y a que plaintext ou markdown pour le moment
This commit is contained in:
parent
785a29ef90
commit
6b0f94a59d
3 changed files with 38 additions and 32 deletions
|
@ -24,62 +24,68 @@ templateLoader = jinja2.FileSystemLoader( searchpath=["/", template_path] )
|
||||||
templateEnv = jinja2.Environment( loader=templateLoader )
|
templateEnv = jinja2.Environment( loader=templateLoader )
|
||||||
|
|
||||||
|
|
||||||
|
# file extension to rendering function map
|
||||||
|
markup = {
|
||||||
|
'md' : markdown
|
||||||
|
}
|
||||||
|
|
||||||
### For an example:
|
### For an example:
|
||||||
### print generate('bienvenue', {'From':'respbats@crans.org', 'To':'admin@genua.fr', 'lang_info':'English version below'}).as_string()
|
### print generate('bienvenue', {'From':'respbats@crans.org', 'To':'admin@genua.fr', 'lang_info':'English version below'}).as_string()
|
||||||
|
|
||||||
|
|
||||||
def submessage(playload, type, charset='utf-8'):
|
def submessage(playload, type, charset='utf-8'):
|
||||||
"""Renvois un sous message à mettre dans un message multipart"""
|
"""Renvois un sous message à mettre dans un message multipart"""
|
||||||
submsg=MIMEText('', type, charset)
|
submsg=MIMEText('', type, charset)
|
||||||
del(submsg['Content-Transfer-Encoding'])
|
del(submsg['Content-Transfer-Encoding'])
|
||||||
submsg['Content-Transfer-Encoding']='8bit'
|
submsg['Content-Transfer-Encoding']='8bit'
|
||||||
submsg.set_payload(playload)
|
submsg.set_payload(playload)
|
||||||
return submsg
|
return submsg
|
||||||
|
|
||||||
def htmlmultilang(mail, lang1, lang2, params, lang_info='', charset='utf-8'):
|
def get_lang(mail, part, lang, lang_fallback):
|
||||||
"""Génère un html bilingue"""
|
for l in [lang, lang_fallback]:
|
||||||
file1 = template_path + mail + '/body/' + lang1
|
for ext in markup.keys():
|
||||||
file2 = template_path + mail + '/body/' + lang2
|
if os.path.isfile(template_path + mail + '/' + part + '/' + l + '.' + ext):
|
||||||
if lang1 == lang2 or not os.path.isfile(file2):
|
return l, ext, template_path + mail + '/' + part + '/' + l + '.' + ext
|
||||||
txt = templateEnv.get_template(file1).render(params)
|
if os.path.isfile(template_path + mail + '/' + part + '/' + l):
|
||||||
html = templateEnv.get_template(html_template).render({'body': markdown(txt)})
|
return l, None, template_path + mail + '/' + part + '/' + l
|
||||||
return submessage(html.encode(charset), 'html', charset)
|
raise ValueError("Language %s nor %s found" % (lang, lang_fallback))
|
||||||
else:
|
|
||||||
txt1 = templateEnv.get_template(file1).render(params)
|
|
||||||
txt2 = templateEnv.get_template(file2).render(params)
|
|
||||||
params.update({'lang1':lang1, 'lang2':lang2, 'body1': markdown(txt1), 'body2':markdown(txt2)})
|
|
||||||
html = templateEnv.get_template(html_mutilang_template).render(params)
|
|
||||||
return submessage(html.encode(charset), 'html', charset)
|
|
||||||
|
|
||||||
def textmultilang(mail, lang1, lang2, params, charset='utf-8'):
|
def body(mail, lang1, lang2, mk, params, charset):
|
||||||
"""Génère un plain text bilingue"""
|
|
||||||
file1 = template_path + mail + '/body/' + lang1
|
file1 = template_path + mail + '/body/' + lang1
|
||||||
file2 = template_path + mail + '/body/' + lang2
|
file2 = template_path + mail + '/body/' + lang2
|
||||||
if lang1 == lang2 or not os.path.isfile(file2):
|
if mk:
|
||||||
|
file1 = file1 + '.' + mk
|
||||||
|
file2 = file2 + '.' + mk
|
||||||
|
if lang1 == lang2 or not os.path.isfile(file2): # No alt language
|
||||||
txt = templateEnv.get_template(file1).render(params)
|
txt = templateEnv.get_template(file1).render(params)
|
||||||
return submessage(txt.encode(charset), 'plain', charset)
|
ret = [ submessage(txt.encode(charset), 'plain', charset) ]
|
||||||
|
if mk: # compute the html version
|
||||||
|
html = templateEnv.get_template(html_template).render({'body': markup[mk](txt)})
|
||||||
|
ret.append(submessage(html.encode(charset), 'html', charset))
|
||||||
else:
|
else:
|
||||||
txt1 = templateEnv.get_template(file1).render(params)
|
txt1 = templateEnv.get_template(file1).render(params)
|
||||||
txt2 = templateEnv.get_template(file2).render(params)
|
txt2 = templateEnv.get_template(file2).render(params)
|
||||||
params.update({'body1': txt1, 'body2':txt2})
|
params_txt=dict(params)
|
||||||
txt = templateEnv.get_template(text_mutilang_template).render(params)
|
params_txt.update({'body1': txt1, 'body2':txt2})
|
||||||
return submessage(txt.encode(charset), 'plain', charset)
|
txt = templateEnv.get_template(text_mutilang_template).render(params_txt)
|
||||||
|
ret=[ submessage(txt.encode(charset), 'plain', charset) ]
|
||||||
|
if mk: # compute the html version
|
||||||
|
params_html=dict(params)
|
||||||
|
params_html.update({'lang1':lang1, 'lang2':lang2, 'body1': markup[mk](txt1), 'body2': markup[mk](txt2)})
|
||||||
|
html = templateEnv.get_template(html_mutilang_template).render(params_html)
|
||||||
|
ret.append(submessage(html.encode(charset), 'html', charset))
|
||||||
|
return ret
|
||||||
|
|
||||||
def generate(mail, params, lang=default_language, lang_fallback=default_language, lang_alt='en', charset='utf-8'):
|
def generate(mail, params, lang=default_language, lang_fallback=default_language, lang_alt='en', charset='utf-8'):
|
||||||
"""Génère un message multipart"""
|
"""Génère un message multipart"""
|
||||||
msg = MIMEMultipart('alternative')
|
msg = MIMEMultipart('alternative')
|
||||||
if os.path.isdir(template_path + mail):
|
if os.path.isdir(template_path + mail):
|
||||||
for filename in [dir for dir in os.listdir(template_path + mail) if os.path.isdir(template_path + mail + '/' + dir)]:
|
for filename in [dir for dir in os.listdir(template_path + mail) if os.path.isdir(template_path + mail + '/' + dir)]:
|
||||||
if os.path.isfile(template_path + mail + '/' + filename + '/' + lang):
|
lang_tmp, mk, file = get_lang(mail, filename, lang, lang_fallback)
|
||||||
lang_tmp = lang
|
|
||||||
file = template_path + mail + '/' + filename + '/' + lang
|
|
||||||
else:
|
|
||||||
lang_tmp = lang_fallback
|
|
||||||
file = template_path + mail + '/' + filename + '/' + lang_tmp
|
|
||||||
|
|
||||||
if filename == 'body':
|
if filename == 'body':
|
||||||
msg.attach(textmultilang(mail, lang_tmp, lang_alt, params, charset))
|
for part in body(mail, lang_tmp, lang_alt, mk, params, charset):
|
||||||
msg.attach(htmlmultilang(mail, lang_tmp, lang_alt, params, charset))
|
msg.attach(part)
|
||||||
else:
|
else:
|
||||||
txt = templateEnv.get_template(file).render(params)
|
txt = templateEnv.get_template(file).render(params)
|
||||||
if filename in ['From', 'To', 'Cc', 'Bcc']:
|
if filename in ['From', 'To', 'Cc', 'Bcc']:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue