Browse Source
Merge pull request #22 from hbrunn/8.0-report_custom_filename
Merge pull request #22 from hbrunn/8.0-report_custom_filename
[ADD] support qweb reportspull/25/head
Pedro M. Baeza
9 years ago
4 changed files with 76 additions and 8 deletions
-
11report_custom_filename/README.rst
-
1report_custom_filename/controllers/__init__.py
-
68report_custom_filename/controllers/report_controller.py
-
4report_custom_filename/model/ir_actions_report_xml.py
@ -0,0 +1,68 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2015 Therp BV (<http://therp.nl>). |
|||
# |
|||
# 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/>. |
|||
# |
|||
############################################################################## |
|||
from openerp import http |
|||
from openerp.addons.email_template import email_template |
|||
from openerp.addons.report.controllers.main import ReportController |
|||
from openerp.addons.web.controllers.main import content_disposition |
|||
|
|||
|
|||
class ReportController(ReportController): |
|||
@http.route([ |
|||
'/report/<path:converter>/<reportname>', |
|||
'/report/<path:converter>/<reportname>/<docids>', |
|||
]) |
|||
def report_routes(self, reportname, docids=None, converter=None, **data): |
|||
response = super(ReportController, self).report_routes( |
|||
reportname, docids=docids, converter=converter, **data) |
|||
if docids: |
|||
docids = [int(i) for i in docids.split(',')] |
|||
report_xml = http.request.session.model('ir.actions.report.xml') |
|||
report_ids = report_xml.search( |
|||
[('report_name', '=', reportname)]) |
|||
for report in report_xml.browse(report_ids): |
|||
if not report.download_filename: |
|||
continue |
|||
objects = http.request.session.model(report.model)\ |
|||
.browse(docids or []) |
|||
generated_filename = email_template.mako_template_env\ |
|||
.from_string(report.download_filename)\ |
|||
.render({ |
|||
'objects': objects, |
|||
'o': objects[:1], |
|||
'object': objects[:1], |
|||
'ext': report.report_type.replace('qweb-', ''), |
|||
}) |
|||
response.headers['Content-Disposition'] = content_disposition( |
|||
generated_filename) |
|||
return response |
|||
|
|||
@http.route(['/report/download']) |
|||
def report_download(self, data, token): |
|||
response = super(ReportController, self).report_download(data, token) |
|||
# if we got another content disposition before, ditch the one added |
|||
# by super() |
|||
last_index = None |
|||
for i in range(len(response.headers) - 1, -1, -1): |
|||
if response.headers[i][0] == 'Content-Disposition': |
|||
if last_index: |
|||
response.headers.pop(last_index) |
|||
last_index = i |
|||
return response |
Write
Preview
Loading…
Cancel
Save
Reference in new issue