diff --git a/base_export_email/__init__.py b/base_export_email/__init__.py new file mode 100755 index 000000000..47054a027 --- /dev/null +++ b/base_export_email/__init__.py @@ -0,0 +1,30 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Authors: Laetitia Gangloff +# Copyright (c) 2015 Acsone SA/NV (http://www.acsone.eu) +# All Rights Reserved +# +# WARNING: This program as such is intended to be used by professional +# programmers who take the whole responsibility of assessing all potential +# consequences resulting from its eventual inadequacies and bugs. +# End users who are looking for a ready-to-use solution with commercial +# guarantees and support are strongly advised to contact a Free Software +# Service Company. +# +# 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 . +# +############################################################################## + +from . import ir_actions diff --git a/base_export_email/__openerp__.py b/base_export_email/__openerp__.py new file mode 100755 index 000000000..29916c7e4 --- /dev/null +++ b/base_export_email/__openerp__.py @@ -0,0 +1,54 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Authors: Laetitia Gangloff +# Copyright (c) 2015 Acsone SA/NV (http://www.acsone.eu) +# All Rights Reserved +# +# WARNING: This program as such is intended to be used by professional +# programmers who take the whole responsibility of assessing all potential +# consequences resulting from its eventual inadequacies and bugs. +# End users who are looking for a ready-to-use solution with commercial +# guarantees and support are strongly advised to contact a Free Software +# Service Company. +# +# 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 . +# +############################################################################## + +{ + "name": "Base export email addon", + "version": "0.1", + "author": "ACSONE SA/NV", + "category": "Other", + "website": "http://www.acsone.eu", + "depends": ['email_template', + ], + "description": """ + +Base export email addon +========================= + +- Add server action type to send by email a data export + +""", + "data": ["ir_actions.xml"], + "demo": [], + "test": [], + "active": False, + "license": "AGPL-3", + "installable": True, + "auto_install": False, + "application": False, +} diff --git a/base_export_email/ir_actions.py b/base_export_email/ir_actions.py new file mode 100644 index 000000000..cd76267bc --- /dev/null +++ b/base_export_email/ir_actions.py @@ -0,0 +1,157 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Authors: Laetitia Gangloff +# Copyright (c) 2015 Acsone SA/NV (http://www.acsone.eu) +# All Rights Reserved +# +# WARNING: This program as such is intended to be used by professional +# programmers who take the whole responsibility of assessing all potential +# consequences resulting from its eventual inadequacies and bugs. +# End users who are looking for a ready-to-use solution with commercial +# guarantees and support are strongly advised to contact a Free Software +# Service Company. +# +# 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 . +# +############################################################################## + +from openerp.osv import orm, fields +from openerp.tools.translate import _ +from openerp.addons.web.controllers import main +from openerp.tools.safe_eval import safe_eval +import time +import base64 + + +class actions_server(orm.Model): + _inherit = "ir.actions.server" + + def __init__(self, pool, cr): + super(actions_server, self).__init__(pool, cr) + # add state 'export_email' + self._columns['state'].selection.append(('export_email', + _('Export data by email'))) + return + + _columns = {'model': fields.related('model_id', 'model', + type="char", size=256, string='Model'), + 'filter_id': fields.many2one( + 'ir.filters', string='Filter', ondelete='restrict'), + 'email_template_id': fields.many2one( + 'email.template', string='Template', ondelete='restrict'), + 'saved_export_id': fields.many2one( + 'ir.exports', string='Saved export', ondelete='restrict'), + 'fields_to_export': fields.text( + 'Fields to export', + help="The list of fields to export. \ + The format is ['name', 'seller_ids/product_name']") + } + + _defaults = {'fields_to_export': '[]'} + + def onchange_model_id(self, cr, uid, ids, model_id, context=None): + """ + Used to set correct domain on filter_id and saved_export_id + """ + data = {'model': False, + 'filter_id': False, + 'email_template_id': False, + 'saved_export_id': False} + if model_id: + model = self.pool['ir.model'].browse(cr, uid, model_id, + context=context) + data.update({'model': model.model}) + return {'value': data} + + def _search_data(self, cr, uid, action, context=None): + """ + search data to export + """ + obj_pool = self.pool[action.model] + domain = action.filter_id and safe_eval( + action.filter_id.domain, {'time': time}) or [] + ctx = action.filter_id and safe_eval( + action.filter_id.context) or context + return obj_pool.search(cr, uid, domain, + offset=0, limit=False, order=False, + context=ctx) + + def _export_data(self, cr, uid, obj_ids, action, context=None): + """ + export data + """ + obj_pool = self.pool[action.model] + export_fields = [] + if action.fields_to_export: + export_fields = safe_eval(action.fields_to_export) + if action.saved_export_id: + # retrieve fields of the selected list + export_fields.extend( + [efl.name for efl in + action.saved_export_id.export_fields]) + return export_fields, obj_pool.export_data( + cr, uid, obj_ids, export_fields, + context=context).get('datas', []) + + def _send_email(self, cr, uid, action, export_fields, export_data, + context=None): + """ + Prepare a message with the exported data to send with the + template of the configuration + """ + mail_compose = self.pool['mail.compose.message'] + values = mail_compose.onchange_template_id( + cr, uid, 0, action.email_template_id, 'comment', + action.model, 0, context=context)['value'] + values['partner_ids'] = [ + (4, partner_id) for partner_id in values.pop('partner_ids', + []) + ] + export = main.CSVExport() + filename = export.filename(action.model) + content = export.from_data(export_fields, export_data) + if isinstance(content, unicode): + content = content.encode('utf-8') + data_attach = { + 'name': filename, + 'datas': base64.b64encode(str(content)), + 'datas_fname': filename, + 'description': filename, + } + + values['attachment_ids'] = [(0, 0, data_attach)] + compose_id = mail_compose.create( + cr, uid, values, context=context) + return mail_compose.send_mail(cr, uid, [compose_id], context=context) + + def run(self, cr, uid, ids, context=None): + """ + If the state of an action is export_email, + export data related to the configuration and send the result by email + """ + for action in self.browse(cr, uid, ids, context): + if action.state == 'export_email': + ids.remove(action.id) + # search data to export + obj_ids = self._search_data(cr, uid, action, context=context) + # export data + export_fields, export_data = self._export_data( + cr, uid, obj_ids, action, context=context) + # Prepare a message with the exported data to send with the + # template of the configuration + self._send_email( + cr, uid, action, export_fields, export_data, + context=context) + return super(actions_server, self).run(cr, uid, ids, context=context) diff --git a/base_export_email/ir_actions.xml b/base_export_email/ir_actions.xml new file mode 100644 index 000000000..274808982 --- /dev/null +++ b/base_export_email/ir_actions.xml @@ -0,0 +1,43 @@ + + + + + Server Action (base_export_email) + ir.actions.server + + + + onchange_model_id(model_id, context) + + + + + + {'required': [('state', '!=', 'export_email'), + ('state','!=','dummy'), + ('state','!=','sms'), + ('state','!=','code'), + ('state','!=','loop'), + ('state','!=','trigger'), + ('state','!=','object_copy'), + ('state','!=','client_action'), + ('state','!=','email'), + ('state','!=','sms'), + ('state','!=','other')]} + + + + + + + + + + + + + + +