2010-07-01 13:16:22 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# OpenERP, Open Source Management Solution
|
|
|
|
# Copyright (C) 2009 Sharoon Thomas
|
|
|
|
# Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as
|
|
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
|
|
# License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU Affero General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
import base64
|
|
|
|
import random
|
|
|
|
import time
|
|
|
|
import types
|
|
|
|
import netsvc
|
|
|
|
|
|
|
|
LOGGER = netsvc.Logger()
|
|
|
|
|
|
|
|
TEMPLATE_ENGINES = []
|
|
|
|
|
|
|
|
from osv import osv, fields
|
|
|
|
from tools.translate import _
|
|
|
|
from mako.template import Template #For backward combatibility
|
|
|
|
try:
|
|
|
|
from mako.template import Template as MakoTemplate
|
|
|
|
from mako import exceptions
|
|
|
|
TEMPLATE_ENGINES.append(('mako', 'Mako Templates'))
|
|
|
|
except:
|
|
|
|
LOGGER.notifyChannel(
|
2010-06-11 07:44:19 +00:00
|
|
|
_("Email Template"),
|
|
|
|
netsvc.LOG_WARNING,
|
|
|
|
_("Mako templates not installed")
|
|
|
|
)
|
2010-06-02 14:36:27 +00:00
|
|
|
try:
|
|
|
|
from django.template import Context, Template as DjangoTemplate
|
|
|
|
#Workaround for bug:
|
|
|
|
#http://code.google.com/p/django-tagging/issues/detail?id=110
|
|
|
|
from django.conf import settings
|
|
|
|
settings.configure()
|
|
|
|
#Workaround ends
|
|
|
|
TEMPLATE_ENGINES.append(('django', 'Django Template'))
|
|
|
|
except:
|
|
|
|
LOGGER.notifyChannel(
|
2010-06-11 07:44:19 +00:00
|
|
|
_("Email Template"),
|
|
|
|
netsvc.LOG_WARNING,
|
|
|
|
_("Django templates not installed")
|
|
|
|
)
|
2010-06-02 14:36:27 +00:00
|
|
|
|
|
|
|
import email_template_engines
|
|
|
|
import tools
|
|
|
|
import report
|
|
|
|
import pooler
|
2010-07-13 16:24:26 +00:00
|
|
|
import logging
|
2010-06-02 14:36:27 +00:00
|
|
|
|
|
|
|
def get_value(cursor, user, recid, message=None, template=None, context=None):
|
|
|
|
"""
|
|
|
|
Evaluates an expression and returns its value
|
|
|
|
@param cursor: Database Cursor
|
|
|
|
@param user: ID of current user
|
|
|
|
@param recid: ID of the target record under evaluation
|
|
|
|
@param message: The expression to be evaluated
|
|
|
|
@param template: BrowseRecord object of the current template
|
2010-08-10 11:35:06 +00:00
|
|
|
@param context: OpenERP Context
|
2010-06-02 14:36:27 +00:00
|
|
|
@return: Computed message (unicode) or u""
|
|
|
|
"""
|
|
|
|
pool = pooler.get_pool(cursor.dbname)
|
|
|
|
if message is None:
|
|
|
|
message = {}
|
|
|
|
#Returns the computed expression
|
|
|
|
if message:
|
|
|
|
try:
|
|
|
|
message = tools.ustr(message)
|
|
|
|
object = pool.get(template.model_int_name).browse(cursor, user, recid, context)
|
|
|
|
env = {
|
|
|
|
'user':pool.get('res.users').browse(cursor, user, user, context),
|
|
|
|
'db':cursor.dbname
|
|
|
|
}
|
|
|
|
if template.template_language == 'mako':
|
|
|
|
templ = MakoTemplate(message, input_encoding='utf-8')
|
|
|
|
reply = MakoTemplate(message).render_unicode(object=object,
|
|
|
|
peobject=object,
|
|
|
|
env=env,
|
|
|
|
format_exceptions=True)
|
|
|
|
elif template.template_language == 'django':
|
|
|
|
templ = DjangoTemplate(message)
|
|
|
|
env['object'] = object
|
|
|
|
env['peobject'] = object
|
|
|
|
reply = templ.render(Context(env))
|
|
|
|
return reply or False
|
|
|
|
except Exception:
|
2010-07-13 16:24:26 +00:00
|
|
|
logging.exception("can't render %r", message)
|
2010-06-02 14:36:27 +00:00
|
|
|
return u""
|
|
|
|
else:
|
|
|
|
return message
|
|
|
|
|
|
|
|
class email_template(osv.osv):
|
|
|
|
"Templates for sending Email"
|
|
|
|
|
|
|
|
_name = "email.template"
|
|
|
|
_description = 'Email Templates for Models'
|
|
|
|
|
|
|
|
def change_model(self, cursor, user, ids, object_name, context=None):
|
|
|
|
if object_name:
|
|
|
|
mod_name = self.pool.get('ir.model').read(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
object_name,
|
|
|
|
['model'], context)['model']
|
|
|
|
else:
|
|
|
|
mod_name = False
|
|
|
|
return {
|
|
|
|
'value':{'model_int_name':mod_name}
|
|
|
|
}
|
|
|
|
|
|
|
|
_columns = {
|
2010-06-10 12:44:50 +00:00
|
|
|
'name' : fields.char('Name', size=100, required=True),
|
2010-06-02 14:36:27 +00:00
|
|
|
'object_name':fields.many2one('ir.model', 'Model'),
|
|
|
|
'model_int_name':fields.char('Model Internal Name', size=200,),
|
2010-06-10 12:44:50 +00:00
|
|
|
'enforce_from_account':fields.many2one(
|
|
|
|
'email_template.account',
|
|
|
|
string="Enforce From Account",
|
2010-06-24 18:32:34 +00:00
|
|
|
help="Emails will be sent only from this account(which are approved)."),
|
2010-06-10 12:44:50 +00:00
|
|
|
'from_email' : fields.related('enforce_from_account', 'email_id',
|
2010-07-16 09:05:13 +00:00
|
|
|
type='char', string='From',
|
|
|
|
help='From Email (select mail account)',
|
|
|
|
readonly=True),
|
2010-06-02 14:36:27 +00:00
|
|
|
'def_to':fields.char(
|
2010-07-16 09:05:13 +00:00
|
|
|
'Recipient (To)',
|
2010-06-02 14:36:27 +00:00
|
|
|
size=250,
|
2010-07-16 09:05:13 +00:00
|
|
|
help="The default recipient of email."
|
2010-06-02 14:36:27 +00:00
|
|
|
"Placeholders can be used here."),
|
|
|
|
'def_cc':fields.char(
|
|
|
|
'Default CC',
|
|
|
|
size=250,
|
|
|
|
help="The default CC for the email."
|
|
|
|
" Placeholders can be used here."),
|
|
|
|
'def_bcc':fields.char(
|
|
|
|
'Default BCC',
|
|
|
|
size=250,
|
|
|
|
help="The default BCC for the email."
|
|
|
|
" Placeholders can be used here."),
|
|
|
|
'lang':fields.char(
|
|
|
|
'Language',
|
|
|
|
size=250,
|
|
|
|
help="The default language for the email."
|
|
|
|
" Placeholders can be used here. "
|
|
|
|
"eg. ${object.partner_id.lang}"),
|
|
|
|
'def_subject':fields.char(
|
|
|
|
'Default Subject',
|
|
|
|
size=200,
|
|
|
|
help="The default subject of email."
|
|
|
|
" Placeholders can be used here.",
|
|
|
|
translate=True),
|
|
|
|
'def_body_text':fields.text(
|
|
|
|
'Standard Body (Text)',
|
|
|
|
help="The text version of the mail",
|
|
|
|
translate=True),
|
|
|
|
'def_body_html':fields.text(
|
|
|
|
'Body (Text-Web Client Only)',
|
|
|
|
help="The text version of the mail",
|
|
|
|
translate=True),
|
|
|
|
'use_sign':fields.boolean(
|
2010-06-10 12:44:50 +00:00
|
|
|
'Signature',
|
2010-06-02 14:36:27 +00:00
|
|
|
help="the signature from the User details"
|
2010-07-16 09:05:13 +00:00
|
|
|
" will be appended to the mail"),
|
2010-06-02 14:36:27 +00:00
|
|
|
'file_name':fields.char(
|
|
|
|
'File Name Pattern',
|
|
|
|
size=200,
|
|
|
|
help="File name pattern can be specified with placeholders."
|
|
|
|
"eg. 2009_SO003.pdf",
|
|
|
|
translate=True),
|
|
|
|
'report_template':fields.many2one(
|
|
|
|
'ir.actions.report.xml',
|
|
|
|
'Report to send'),
|
|
|
|
'ref_ir_act_window':fields.many2one(
|
|
|
|
'ir.actions.act_window',
|
|
|
|
'Window Action',
|
|
|
|
readonly=True),
|
|
|
|
'ref_ir_value':fields.many2one(
|
|
|
|
'ir.values',
|
|
|
|
'Wizard Button',
|
|
|
|
readonly=True),
|
|
|
|
'allowed_groups':fields.many2many(
|
|
|
|
'res.groups',
|
|
|
|
'template_group_rel',
|
|
|
|
'templ_id', 'group_id',
|
|
|
|
string="Allowed User Groups",
|
|
|
|
help="Only users from these groups will be"
|
|
|
|
" allowed to send mails from this Template"),
|
|
|
|
'model_object_field':fields.many2one(
|
|
|
|
'ir.model.fields',
|
|
|
|
string="Field",
|
|
|
|
help="Select the field from the model you want to use."
|
|
|
|
"\nIf it is a relationship field you will be able to "
|
|
|
|
"choose the nested values in the box below\n(Note:If "
|
|
|
|
"there are no values make sure you have selected the"
|
|
|
|
" correct model)",
|
|
|
|
store=False),
|
|
|
|
'sub_object':fields.many2one(
|
|
|
|
'ir.model',
|
|
|
|
'Sub-model',
|
|
|
|
help='When a relation field is used this field'
|
|
|
|
' will show you the type of field you have selected',
|
|
|
|
store=False),
|
|
|
|
'sub_model_object_field':fields.many2one(
|
|
|
|
'ir.model.fields',
|
|
|
|
'Sub Field',
|
|
|
|
help="When you choose relationship fields "
|
|
|
|
"this field will specify the sub value you can use.",
|
|
|
|
store=False),
|
|
|
|
'null_value':fields.char(
|
|
|
|
'Null Value',
|
|
|
|
help="This Value is used if the field is empty",
|
|
|
|
size=50, store=False),
|
|
|
|
'copyvalue':fields.char(
|
|
|
|
'Expression',
|
|
|
|
size=100,
|
|
|
|
help="Copy and paste the value in the "
|
|
|
|
"location you want to use a system value.",
|
|
|
|
store=False),
|
|
|
|
'table_html':fields.text(
|
|
|
|
'HTML code',
|
|
|
|
help="Copy this html code to your HTML message"
|
|
|
|
" body for displaying the info in your mail.",
|
|
|
|
store=False),
|
|
|
|
#Template language(engine eg.Mako) specifics
|
|
|
|
'template_language':fields.selection(
|
|
|
|
TEMPLATE_ENGINES,
|
|
|
|
'Templating Language',
|
|
|
|
required=True
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
_defaults = {
|
2010-06-10 12:44:50 +00:00
|
|
|
'template_language' : lambda *a:'mako',
|
2010-06-02 14:36:27 +00:00
|
|
|
|
|
|
|
}
|
2010-06-25 09:52:31 +00:00
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
_sql_constraints = [
|
|
|
|
('name', 'unique (name)', _('The template name must be unique !'))
|
|
|
|
]
|
|
|
|
|
2010-06-25 09:52:31 +00:00
|
|
|
def create_action(self, cr, uid, ids, context):
|
|
|
|
vals = {}
|
|
|
|
template_obj = self.browse(cr, uid, ids)[0]
|
|
|
|
src_obj = template_obj.object_name.model
|
2010-06-02 14:36:27 +00:00
|
|
|
vals['ref_ir_act_window'] = self.pool.get('ir.actions.act_window').create(cr, uid, {
|
2010-06-25 12:04:22 +00:00
|
|
|
'name': template_obj.name,
|
2010-06-02 14:36:27 +00:00
|
|
|
'type': 'ir.actions.act_window',
|
|
|
|
'res_model': 'email_template.send.wizard',
|
|
|
|
'src_model': src_obj,
|
|
|
|
'view_type': 'form',
|
2010-06-25 09:52:31 +00:00
|
|
|
'context': "{'src_model':'%s','template_id':'%d','src_rec_id':active_id,'src_rec_ids':active_ids}" % (src_obj, template_obj.id),
|
2010-06-02 14:36:27 +00:00
|
|
|
'view_mode':'form,tree',
|
|
|
|
'view_id': self.pool.get('ir.ui.view').search(cr, uid, [('name', '=', 'email_template.send.wizard.form')], context=context)[0],
|
|
|
|
'target': 'new',
|
|
|
|
'auto_refresh':1
|
|
|
|
}, context)
|
|
|
|
vals['ref_ir_value'] = self.pool.get('ir.values').create(cr, uid, {
|
2010-06-25 09:52:31 +00:00
|
|
|
'name': _('Send Mail (%s)') % template_obj.name,
|
2010-06-02 14:36:27 +00:00
|
|
|
'model': src_obj,
|
|
|
|
'key2': 'client_action_multi',
|
|
|
|
'value': "ir.actions.act_window," + str(vals['ref_ir_act_window']),
|
|
|
|
'object': True,
|
|
|
|
}, context)
|
2010-06-25 09:52:31 +00:00
|
|
|
self.write(cr, uid, ids, {
|
2010-06-02 14:36:27 +00:00
|
|
|
'ref_ir_act_window': vals['ref_ir_act_window'],
|
|
|
|
'ref_ir_value': vals['ref_ir_value'],
|
|
|
|
}, context)
|
2010-06-25 09:52:31 +00:00
|
|
|
return True
|
2010-06-02 14:36:27 +00:00
|
|
|
|
2010-06-25 09:52:31 +00:00
|
|
|
def unlink_action(self, cr, uid, ids, context):
|
2010-06-02 14:36:27 +00:00
|
|
|
for template in self.browse(cr, uid, ids, context):
|
|
|
|
obj = self.pool.get(template.object_name.model)
|
|
|
|
try:
|
|
|
|
if template.ref_ir_act_window:
|
|
|
|
self.pool.get('ir.actions.act_window').unlink(cr, uid, template.ref_ir_act_window.id, context)
|
|
|
|
if template.ref_ir_value:
|
|
|
|
self.pool.get('ir.values').unlink(cr, uid, template.ref_ir_value.id, context)
|
|
|
|
except:
|
|
|
|
raise osv.except_osv(_("Warning"), _("Deletion of Record failed"))
|
2010-06-25 09:52:31 +00:00
|
|
|
|
|
|
|
def delete_action(self, cr, uid, ids, context):
|
|
|
|
self.unlink_action(cr, uid, ids, context)
|
|
|
|
return True
|
|
|
|
|
|
|
|
def unlink(self, cr, uid, ids, context=None):
|
|
|
|
self.unlink_action(cr, uid, ids, context)
|
2010-06-02 14:36:27 +00:00
|
|
|
return super(email_template, self).unlink(cr, uid, ids, context)
|
|
|
|
|
|
|
|
def copy(self, cr, uid, id, default=None, context=None):
|
|
|
|
if default is None:
|
|
|
|
default = {}
|
|
|
|
default = default.copy()
|
|
|
|
old = self.read(cr, uid, id, ['name'], context=context)
|
|
|
|
new_name = _("Copy of template ") + old.get('name', 'No Name')
|
|
|
|
check = self.search(cr, uid, [('name', '=', new_name)], context=context)
|
|
|
|
if check:
|
|
|
|
new_name = new_name + '_' + random.choice('abcdefghij') + random.choice('lmnopqrs') + random.choice('tuvwzyz')
|
|
|
|
default.update({'name':new_name})
|
|
|
|
return super(email_template, self).copy(cr, uid, id, default, context)
|
|
|
|
|
|
|
|
def compute_pl(self,
|
|
|
|
model_object_field,
|
|
|
|
sub_model_object_field,
|
|
|
|
null_value, template_language='mako'):
|
|
|
|
"""
|
|
|
|
Returns the expression based on data provided
|
|
|
|
@param model_object_field: First level field
|
|
|
|
@param sub_model_object_field: Second level drilled down field (M2O)
|
|
|
|
@param null_value: What has to be returned if the value is empty
|
|
|
|
@param template_language: The language used for templating
|
|
|
|
@return: computed expression
|
|
|
|
"""
|
|
|
|
#Configure for MAKO
|
|
|
|
copy_val = ''
|
|
|
|
if template_language == 'mako':
|
|
|
|
if model_object_field:
|
|
|
|
copy_val = "${object." + model_object_field
|
|
|
|
if sub_model_object_field:
|
|
|
|
copy_val += "." + sub_model_object_field
|
|
|
|
if null_value:
|
|
|
|
copy_val += " or '" + null_value + "'"
|
|
|
|
if model_object_field:
|
|
|
|
copy_val += "}"
|
|
|
|
elif template_language == 'django':
|
|
|
|
if model_object_field:
|
|
|
|
copy_val = "{{object." + model_object_field
|
|
|
|
if sub_model_object_field:
|
|
|
|
copy_val += "." + sub_model_object_field
|
|
|
|
if null_value:
|
|
|
|
copy_val = copy_val + '|default:"' + null_value + '"'
|
|
|
|
copy_val = copy_val + "}}"
|
|
|
|
return copy_val
|
|
|
|
|
|
|
|
def onchange_model_object_field(self, cr, uid, ids, model_object_field, template_language, context=None):
|
|
|
|
if not model_object_field:
|
|
|
|
return {}
|
|
|
|
result = {}
|
|
|
|
field_obj = self.pool.get('ir.model.fields').browse(cr, uid, model_object_field, context)
|
|
|
|
#Check if field is relational
|
|
|
|
if field_obj.ttype in ['many2one', 'one2many', 'many2many']:
|
|
|
|
res_ids = self.pool.get('ir.model').search(cr, uid, [('model', '=', field_obj.relation)], context=context)
|
|
|
|
if res_ids:
|
|
|
|
result['sub_object'] = res_ids[0]
|
|
|
|
result['copyvalue'] = self.compute_pl(False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
template_language)
|
|
|
|
result['sub_model_object_field'] = False
|
|
|
|
result['null_value'] = False
|
|
|
|
else:
|
|
|
|
#Its a simple field... just compute placeholder
|
|
|
|
result['sub_object'] = False
|
|
|
|
result['copyvalue'] = self.compute_pl(field_obj.name,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
template_language
|
|
|
|
)
|
|
|
|
result['sub_model_object_field'] = False
|
|
|
|
result['null_value'] = False
|
|
|
|
return {'value':result}
|
|
|
|
|
|
|
|
def onchange_sub_model_object_field(self, cr, uid, ids, model_object_field, sub_model_object_field, template_language, context=None):
|
|
|
|
if not model_object_field or not sub_model_object_field:
|
|
|
|
return {}
|
|
|
|
result = {}
|
|
|
|
field_obj = self.pool.get('ir.model.fields').browse(cr, uid, model_object_field, context)
|
|
|
|
if field_obj.ttype in ['many2one', 'one2many', 'many2many']:
|
|
|
|
res_ids = self.pool.get('ir.model').search(cr, uid, [('model', '=', field_obj.relation)], context=context)
|
|
|
|
sub_field_obj = self.pool.get('ir.model.fields').browse(cr, uid, sub_model_object_field, context)
|
|
|
|
if res_ids:
|
|
|
|
result['sub_object'] = res_ids[0]
|
|
|
|
result['copyvalue'] = self.compute_pl(field_obj.name,
|
|
|
|
sub_field_obj.name,
|
|
|
|
False,
|
|
|
|
template_language
|
|
|
|
)
|
|
|
|
result['sub_model_object_field'] = sub_model_object_field
|
|
|
|
result['null_value'] = False
|
|
|
|
else:
|
|
|
|
#Its a simple field... just compute placeholder
|
|
|
|
result['sub_object'] = False
|
|
|
|
result['copyvalue'] = self.compute_pl(field_obj.name,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
template_language
|
|
|
|
)
|
|
|
|
result['sub_model_object_field'] = False
|
|
|
|
result['null_value'] = False
|
|
|
|
return {'value':result}
|
|
|
|
|
|
|
|
def onchange_null_value(self, cr, uid, ids, model_object_field, sub_model_object_field, null_value, template_language, context=None):
|
|
|
|
if not model_object_field and not null_value:
|
|
|
|
return {}
|
|
|
|
result = {}
|
|
|
|
field_obj = self.pool.get('ir.model.fields').browse(cr, uid, model_object_field, context)
|
|
|
|
if field_obj.ttype in ['many2one', 'one2many', 'many2many']:
|
|
|
|
res_ids = self.pool.get('ir.model').search(cr, uid, [('model', '=', field_obj.relation)], context=context)
|
|
|
|
sub_field_obj = self.pool.get('ir.model.fields').browse(cr, uid, sub_model_object_field, context)
|
|
|
|
if res_ids:
|
|
|
|
result['sub_object'] = res_ids[0]
|
|
|
|
result['copyvalue'] = self.compute_pl(field_obj.name,
|
|
|
|
sub_field_obj.name,
|
|
|
|
null_value,
|
|
|
|
template_language
|
|
|
|
)
|
|
|
|
result['sub_model_object_field'] = sub_model_object_field
|
|
|
|
result['null_value'] = null_value
|
|
|
|
else:
|
|
|
|
#Its a simple field... just compute placeholder
|
|
|
|
result['sub_object'] = False
|
|
|
|
result['copyvalue'] = self.compute_pl(field_obj.name,
|
|
|
|
False,
|
|
|
|
null_value,
|
|
|
|
template_language
|
|
|
|
)
|
|
|
|
result['sub_model_object_field'] = False
|
|
|
|
result['null_value'] = null_value
|
|
|
|
return {'value':result}
|
|
|
|
|
|
|
|
def generate_attach_reports(self,
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template,
|
|
|
|
record_id,
|
|
|
|
mail,
|
|
|
|
context=None):
|
|
|
|
"""
|
|
|
|
Generate report to be attached and attach it
|
|
|
|
to the email
|
|
|
|
|
|
|
|
@param cursor: Database Cursor
|
|
|
|
@param user: ID of User
|
|
|
|
@param template: Browse record of
|
|
|
|
template
|
|
|
|
@param record_id: ID of the target model
|
|
|
|
for which this mail has
|
|
|
|
to be generated
|
|
|
|
@param mail: Browse record of email object
|
|
|
|
@return: True
|
|
|
|
"""
|
|
|
|
reportname = 'report.' + \
|
|
|
|
self.pool.get('ir.actions.report.xml').read(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template.report_template.id,
|
|
|
|
['report_name'],
|
|
|
|
context)['report_name']
|
|
|
|
service = netsvc.LocalService(reportname)
|
|
|
|
data = {}
|
|
|
|
data['model'] = template.model_int_name
|
|
|
|
(result, format) = service.create(cursor,
|
|
|
|
user,
|
|
|
|
[record_id],
|
|
|
|
data,
|
|
|
|
context)
|
|
|
|
attachment_obj = self.pool.get('ir.attachment')
|
2010-08-06 09:44:11 +00:00
|
|
|
|
|
|
|
fname = tools.ustr(get_value(cursor, user, record_id,
|
|
|
|
template.file_name, template, context)
|
|
|
|
or 'Report')
|
|
|
|
ext = '.' + format
|
|
|
|
if not fname.endswith(ext):
|
|
|
|
fname += ext
|
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
new_att_vals = {
|
|
|
|
'name':mail.subject + ' (Email Attachment)',
|
|
|
|
'datas':base64.b64encode(result),
|
2010-08-06 09:44:11 +00:00
|
|
|
'datas_fname': fname,
|
2010-06-02 14:36:27 +00:00
|
|
|
'description':mail.subject or "No Description",
|
|
|
|
'res_model':'email_template.mailbox',
|
|
|
|
'res_id':mail.id
|
|
|
|
}
|
|
|
|
attachment_id = attachment_obj.create(cursor,
|
|
|
|
user,
|
|
|
|
new_att_vals,
|
|
|
|
context)
|
|
|
|
if attachment_id:
|
|
|
|
self.pool.get('email_template.mailbox').write(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
mail.id,
|
|
|
|
{
|
|
|
|
'attachments_ids':[
|
|
|
|
[6, 0, [attachment_id]]
|
|
|
|
],
|
|
|
|
'mail_type':'multipart/mixed'
|
|
|
|
},
|
|
|
|
context)
|
|
|
|
return True
|
|
|
|
|
2010-06-11 07:44:19 +00:00
|
|
|
def _generate_mailbox_item_from_template(self,
|
2010-06-02 14:36:27 +00:00
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template,
|
|
|
|
record_id,
|
|
|
|
context=None):
|
|
|
|
"""
|
|
|
|
Generates an email from the template for
|
|
|
|
record record_id of target object
|
|
|
|
|
|
|
|
@param cursor: Database Cursor
|
|
|
|
@param user: ID of User
|
|
|
|
@param template: Browse record of
|
|
|
|
template
|
|
|
|
@param record_id: ID of the target model
|
|
|
|
for which this mail has
|
|
|
|
to be generated
|
|
|
|
@return: ID of created object
|
|
|
|
"""
|
|
|
|
if context is None:
|
|
|
|
context = {}
|
|
|
|
#If account to send from is in context select it, else use enforced account
|
|
|
|
if 'account_id' in context.keys():
|
|
|
|
from_account = self.pool.get('email_template.account').read(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
context.get('account_id'),
|
|
|
|
['name', 'email_id'],
|
|
|
|
context
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
from_account = {
|
|
|
|
'id':template.enforce_from_account.id,
|
|
|
|
'name':template.enforce_from_account.name,
|
|
|
|
'email_id':template.enforce_from_account.email_id
|
|
|
|
}
|
|
|
|
lang = get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.lang,
|
|
|
|
template,
|
|
|
|
context)
|
|
|
|
if lang:
|
|
|
|
ctx = context.copy()
|
|
|
|
ctx.update({'lang':lang})
|
2010-07-13 16:24:26 +00:00
|
|
|
template = self.browse(cursor, user, template.id, context=ctx)
|
2010-06-02 14:36:27 +00:00
|
|
|
mailbox_values = {
|
|
|
|
'email_from': tools.ustr(from_account['name']) + \
|
|
|
|
"<" + tools.ustr(from_account['email_id']) + ">",
|
|
|
|
'email_to':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_to,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'email_cc':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_cc,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'email_bcc':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_bcc,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'subject':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_subject,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'body_text':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_body_text,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'body_html':get_value(cursor,
|
|
|
|
user,
|
|
|
|
record_id,
|
|
|
|
template.def_body_html,
|
|
|
|
template,
|
|
|
|
context),
|
|
|
|
'account_id' :from_account['id'],
|
|
|
|
#This is a mandatory field when automatic emails are sent
|
|
|
|
'state':'na',
|
|
|
|
'folder':'drafts',
|
|
|
|
'mail_type':'multipart/alternative'
|
|
|
|
}
|
2010-06-11 07:44:19 +00:00
|
|
|
if not mailbox_values['account_id']:
|
|
|
|
raise Exception("Unable to send the mail. No account linked to the template.")
|
2010-06-02 14:36:27 +00:00
|
|
|
#Use signatures if allowed
|
|
|
|
if template.use_sign:
|
|
|
|
sign = self.pool.get('res.users').read(cursor,
|
|
|
|
user,
|
|
|
|
user,
|
|
|
|
['signature'],
|
|
|
|
context)['signature']
|
|
|
|
if mailbox_values['body_text']:
|
|
|
|
mailbox_values['body_text'] += sign
|
|
|
|
if mailbox_values['body_html']:
|
|
|
|
mailbox_values['body_html'] += sign
|
|
|
|
mailbox_id = self.pool.get('email_template.mailbox').create(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
mailbox_values,
|
|
|
|
context)
|
2010-06-11 07:44:19 +00:00
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
return mailbox_id
|
2010-06-24 10:52:26 +00:00
|
|
|
|
2010-06-11 07:44:19 +00:00
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
def generate_mail(self,
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template_id,
|
|
|
|
record_ids,
|
|
|
|
context=None):
|
|
|
|
if context is None:
|
|
|
|
context = {}
|
|
|
|
template = self.browse(cursor, user, template_id, context=context)
|
|
|
|
if not template:
|
|
|
|
raise Exception("The requested template could not be loaded")
|
2010-06-24 10:52:26 +00:00
|
|
|
result = True
|
2010-06-02 14:36:27 +00:00
|
|
|
for record_id in record_ids:
|
|
|
|
mailbox_id = self._generate_mailbox_item_from_template(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template,
|
|
|
|
record_id,
|
|
|
|
context)
|
|
|
|
mail = self.pool.get('email_template.mailbox').browse(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
mailbox_id,
|
|
|
|
context=context
|
|
|
|
)
|
|
|
|
if template.report_template:
|
2010-07-13 16:24:26 +00:00
|
|
|
self.generate_attach_reports(
|
2010-06-02 14:36:27 +00:00
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
template,
|
|
|
|
record_id,
|
|
|
|
mail,
|
|
|
|
context
|
|
|
|
)
|
|
|
|
self.pool.get('email_template.mailbox').write(
|
|
|
|
cursor,
|
|
|
|
user,
|
|
|
|
mailbox_id,
|
|
|
|
{'folder':'outbox'},
|
|
|
|
context=context
|
2010-06-11 07:44:19 +00:00
|
|
|
)
|
2010-06-24 10:52:26 +00:00
|
|
|
# TODO : manage return value of all the records
|
|
|
|
result = self.pool.get('email_template.mailbox').send_this_mail(cursor, user, [mailbox_id], context)
|
|
|
|
return result
|
2010-06-02 14:36:27 +00:00
|
|
|
|
|
|
|
email_template()
|
|
|
|
|
|
|
|
class email_template_preview(osv.osv_memory):
|
|
|
|
_name = "email_template.preview"
|
|
|
|
_description = "Email Template Preview"
|
|
|
|
|
2010-06-14 11:13:01 +00:00
|
|
|
def _get_model_recs(self, cr, uid, context=None):
|
|
|
|
if context is None:
|
|
|
|
context = {}
|
|
|
|
#Fills up the selection box which allows records from the selected object to be displayed
|
|
|
|
self.context = context
|
|
|
|
if 'template_id' in context.keys():
|
|
|
|
ref_obj_id = self.pool.get('email.template').read(cr, uid, context['template_id'], ['object_name'], context)
|
|
|
|
ref_obj_name = self.pool.get('ir.model').read(cr, uid, ref_obj_id['object_name'][0], ['model'], context)['model']
|
2010-06-24 10:52:26 +00:00
|
|
|
ref_obj_ids = self.pool.get(ref_obj_name).search(cr, uid, [], 0, 20, 'id desc', context=context)
|
2010-06-14 11:13:01 +00:00
|
|
|
ref_obj_recs = self.pool.get(ref_obj_name).name_get(cr, uid, ref_obj_ids, context)
|
|
|
|
return ref_obj_recs
|
|
|
|
|
2010-06-02 14:36:27 +00:00
|
|
|
def _default_model(self, cursor, user, context=None):
|
|
|
|
"""
|
|
|
|
Returns the default value for model field
|
|
|
|
@param cursor: Database Cursor
|
|
|
|
@param user: ID of current user
|
2010-08-10 11:35:06 +00:00
|
|
|
@param context: OpenERP Context
|
2010-06-02 14:36:27 +00:00
|
|
|
"""
|
|
|
|
return self.pool.get('email.template').read(
|
|
|
|
cursor,
|
|
|
|
user,
|
2010-06-14 11:13:01 +00:00
|
|
|
context['template_id'],
|
2010-06-02 14:36:27 +00:00
|
|
|
['object_name'],
|
|
|
|
context)['object_name']
|
|
|
|
|
|
|
|
_columns = {
|
|
|
|
'ref_template':fields.many2one(
|
|
|
|
'email.template',
|
|
|
|
'Template', readonly=True),
|
|
|
|
'rel_model':fields.many2one('ir.model', 'Model', readonly=True),
|
2010-06-14 11:13:01 +00:00
|
|
|
'rel_model_ref':fields.selection(_get_model_recs, 'Referred Document'),
|
2010-06-02 14:36:27 +00:00
|
|
|
'to':fields.char('To', size=250, readonly=True),
|
|
|
|
'cc':fields.char('CC', size=250, readonly=True),
|
|
|
|
'bcc':fields.char('BCC', size=250, readonly=True),
|
|
|
|
'subject':fields.char('Subject', size=200, readonly=True),
|
|
|
|
'body_text':fields.text('Body', readonly=True),
|
|
|
|
'body_html':fields.text('Body', readonly=True),
|
|
|
|
'report':fields.char('Report Name', size=100, readonly=True),
|
|
|
|
}
|
|
|
|
_defaults = {
|
2010-06-14 11:13:01 +00:00
|
|
|
'ref_template': lambda self, cr, uid, ctx:ctx['template_id'],
|
2010-06-02 14:36:27 +00:00
|
|
|
'rel_model': _default_model
|
|
|
|
}
|
|
|
|
def on_change_ref(self, cr, uid, ids, rel_model_ref, context=None):
|
|
|
|
if context is None:
|
|
|
|
context = {}
|
|
|
|
if not rel_model_ref:
|
|
|
|
return {}
|
|
|
|
vals = {}
|
|
|
|
if context == {}:
|
|
|
|
context = self.context
|
2010-06-14 11:13:01 +00:00
|
|
|
template = self.pool.get('email.template').browse(cr, uid, context['template_id'], context)
|
2010-06-02 14:36:27 +00:00
|
|
|
#Search translated template
|
|
|
|
lang = get_value(cr, uid, rel_model_ref, template.lang, template, context)
|
|
|
|
if lang:
|
|
|
|
ctx = context.copy()
|
|
|
|
ctx.update({'lang':lang})
|
2010-06-14 11:13:01 +00:00
|
|
|
template = self.pool.get('email.template').browse(cr, uid, context['template_id'], ctx)
|
2010-06-02 14:36:27 +00:00
|
|
|
vals['to'] = get_value(cr, uid, rel_model_ref, template.def_to, template, context)
|
|
|
|
vals['cc'] = get_value(cr, uid, rel_model_ref, template.def_cc, template, context)
|
|
|
|
vals['bcc'] = get_value(cr, uid, rel_model_ref, template.def_bcc, template, context)
|
|
|
|
vals['subject'] = get_value(cr, uid, rel_model_ref, template.def_subject, template, context)
|
|
|
|
vals['body_text'] = get_value(cr, uid, rel_model_ref, template.def_body_text, template, context)
|
|
|
|
vals['body_html'] = get_value(cr, uid, rel_model_ref, template.def_body_html, template, context)
|
|
|
|
vals['report'] = get_value(cr, uid, rel_model_ref, template.file_name, template, context)
|
|
|
|
return {'value':vals}
|
|
|
|
|
|
|
|
email_template_preview()
|
|
|
|
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|