Laurent Mignon
8 years ago
committed by
Laurent Mignon (ACSONE)
9 changed files with 73 additions and 272 deletions
-
2report_py3o/__init__.py
-
24report_py3o/__openerp__.py
-
8report_py3o/models/__init__.py
-
69report_py3o/models/ir_report.py
-
19report_py3o/models/py3o_fusion_filetype.py
-
22report_py3o/models/py3o_server.py
-
31report_py3o/models/py3o_template.py
-
8report_py3o/py3o_parser.py
-
146report_py3o/py3o_report_modif.py
@ -1 +1 @@ |
|||||
import models |
|
||||
|
from . import models |
@ -1,4 +1,4 @@ |
|||||
import ir_report |
|
||||
import py3o_fusion_filetype |
|
||||
import py3o_template |
|
||||
import py3o_server |
|
||||
|
from . import ir_report |
||||
|
from . import py3o_fusion_filetype |
||||
|
from . import py3o_template |
||||
|
from . import py3o_server |
@ -1,18 +1,13 @@ |
|||||
from openerp.osv import fields, osv |
|
||||
|
# -*- coding: utf-8 -*- |
||||
|
# Copyright 2013 XCG Consulting (http://odoo.consulting) |
||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
||||
|
from openerp import fields, models |
||||
|
|
||||
|
|
||||
class py3o_fusion_filetype(osv.Model): |
|
||||
|
class Py3oFusionFiletype(models.Model): |
||||
_name = 'py3o.fusion.filetype' |
_name = 'py3o.fusion.filetype' |
||||
|
|
||||
_rec_name = 'human_ext' |
_rec_name = 'human_ext' |
||||
|
|
||||
_columns = { |
|
||||
'fusion_ext': fields.char( |
|
||||
u"Fusion Extension", |
|
||||
size=8, |
|
||||
), |
|
||||
'human_ext': fields.char( |
|
||||
u"Human readble extension", |
|
||||
size=8, |
|
||||
), |
|
||||
} |
|
||||
|
fusion_ext = fields.Char("Fusion Extension", siez=8) |
||||
|
human_ext = fields.Char("Human readble extension", size=8) |
@ -1,19 +1,11 @@ |
|||||
from openerp.osv import fields, osv |
|
||||
|
# -*- coding: utf-8 -*- |
||||
|
# Copyright 2013 XCG Consulting (http://odoo.consulting) |
||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
||||
|
from openerp import fields, models |
||||
|
|
||||
|
|
||||
class py3o_server(osv.Model): |
|
||||
|
class Py3oServer(models.Model): |
||||
_name = 'py3o.server' |
_name = 'py3o.server' |
||||
|
|
||||
_columns = { |
|
||||
'url': fields.char( |
|
||||
u"URL", |
|
||||
size=256, |
|
||||
), |
|
||||
'is_active': fields.boolean( |
|
||||
u"Active", |
|
||||
) |
|
||||
} |
|
||||
|
|
||||
_defaults = { |
|
||||
'is_active': True, |
|
||||
} |
|
||||
|
url = fields.Char("URL", required=True) |
||||
|
is_active = fields.Boolean("Active", default=True) |
@ -1,28 +1,19 @@ |
|||||
from openerp.osv import fields, osv |
|
||||
|
# -*- coding: utf-8 -*- |
||||
|
# Copyright 2013 XCG Consulting (http://odoo.consulting) |
||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
||||
|
from openerp import fields, models |
||||
|
|
||||
|
|
||||
class py3o_template(osv.Model): |
|
||||
|
class Py3oTemplate(models.Model): |
||||
_name = 'py3o.template' |
_name = 'py3o.template' |
||||
|
|
||||
_columns = { |
|
||||
'name': fields.char( |
|
||||
u"Name", |
|
||||
), |
|
||||
|
|
||||
'py3o_template_data': fields.binary( |
|
||||
u"LibreOffice template", |
|
||||
), |
|
||||
|
|
||||
'filetype': fields.selection( |
|
||||
[ |
|
||||
|
name = fields.Char(required=True) |
||||
|
py3o_template_data = fields.Binary("LibreOffice template") |
||||
|
filetype = fields.Selection( |
||||
|
selection=[ |
||||
('odt', u"ODF Text Document"), |
('odt', u"ODF Text Document"), |
||||
('ods', u"ODF Spreadsheet"), |
('ods', u"ODF Spreadsheet"), |
||||
], |
], |
||||
u"LibreOffice Template File Type", |
|
||||
|
string="LibreOffice Template File Type", |
||||
required=True, |
required=True, |
||||
), |
|
||||
} |
|
||||
|
|
||||
_defaults = { |
|
||||
'filetype': 'odt' |
|
||||
} |
|
||||
|
default='odt') |
@ -1,146 +0,0 @@ |
|||||
from base64 import b64decode |
|
||||
from tempfile import NamedTemporaryFile as tempfile |
|
||||
|
|
||||
from openerp import pooler |
|
||||
from openerp.report.report_sxw import * |
|
||||
from openerp.tools.translate import _ |
|
||||
from openerp.osv.osv import except_osv |
|
||||
|
|
||||
from py3o.template import Template |
|
||||
|
|
||||
from oe_json_serializer import OESerializer |
|
||||
|
|
||||
import json |
|
||||
import requests |
|
||||
import os |
|
||||
|
|
||||
|
|
||||
class py3o_report(report_sxw): |
|
||||
# def __init__(self, name, table): |
|
||||
# super(py3o_report, self).__init__(name, table) |
|
||||
|
|
||||
def get_values(self, cr, uid, ids, data, context): |
|
||||
''' Override this function to customize the dictionary given to the |
|
||||
py3o.template renderer. ''' |
|
||||
|
|
||||
return { |
|
||||
'lang': self.get_lang(cr, uid, context), |
|
||||
'objects': self.getObjects(cr, uid, ids, context), |
|
||||
} |
|
||||
|
|
||||
def get_lang(self, cr, uid, context): |
|
||||
pool = pooler.get_pool(cr.dbname) |
|
||||
lang_obj = pool.get('res.lang') |
|
||||
user_obj = pool.get('res.users') |
|
||||
|
|
||||
lang_code = user_obj.browse(cr, uid, uid, context=context).lang |
|
||||
lang = lang_obj.search(cr, uid, |
|
||||
[('code', '=', lang_code)], |
|
||||
context=context)[0] |
|
||||
return lang_obj.browse(cr, uid, lang, context=context) |
|
||||
|
|
||||
def format_date(self, date, values): |
|
||||
''' Return a date formatted according to the language extracted from |
|
||||
the "values" argument (which should be the result of get_values). ''' |
|
||||
return date.strftime(values['lang'].date_format) |
|
||||
|
|
||||
def create(self, cr, uid, ids, data, context=None): |
|
||||
# Find the report definition to get its settings. |
|
||||
pool = pooler.get_pool(cr.dbname) |
|
||||
report_xml_obj = pool.get('ir.actions.report.xml') |
|
||||
report_xml_ids = report_xml_obj.search(cr, uid, |
|
||||
[('report_name', '=', self.name[7:])], # Ignore "report." |
|
||||
context=context) |
|
||||
|
|
||||
if not report_xml_ids: |
|
||||
return super(py3o_report, self).create(cr, uid, ids, data, |
|
||||
context=context) |
|
||||
report_xml = report_xml_obj.browse(cr, uid, |
|
||||
report_xml_ids[0], |
|
||||
context=context) |
|
||||
|
|
||||
template = report_xml.py3o_template_id |
|
||||
filetype = report_xml.py3o_fusion_filetype |
|
||||
|
|
||||
|
|
||||
#Try to request fusion server: |
|
||||
|
|
||||
fusion_server_obj = pool['py3o.server'] |
|
||||
#TODO: Raise a message if no config found |
|
||||
fusion_server_id = fusion_server_obj.search( |
|
||||
cr, uid, [], context=context |
|
||||
)[0] |
|
||||
fusion_server = fusion_server_obj.browse(cr, uid, fusion_server_id) |
|
||||
|
|
||||
# py3o.template operates on filenames so create temporary files. |
|
||||
in_temp = tempfile(suffix='.odt', prefix='py3o-template-') |
|
||||
|
|
||||
in_temp.write(b64decode(template.py3o_template_data)) |
|
||||
in_temp.seek(0) |
|
||||
out_temp = tempfile(suffix='.odt', prefix='py3o-report-') |
|
||||
|
|
||||
# We need to get the variables used in the template |
|
||||
#TODO: Find a way to avoid calling Template |
|
||||
t = Template(in_temp.name, out_temp.name) |
|
||||
# Remove 'py3o.' |
|
||||
user_variable = [x[5:] for x in t.get_all_user_python_expression()] |
|
||||
print user_variable |
|
||||
|
|
||||
values = self.get_values(cr, uid, ids, data, context) |
|
||||
t.render(values) |
|
||||
print values |
|
||||
|
|
||||
#WARNING: We rely on the fact that there is a for loop on the report |
|
||||
# on objects (for object in objects) due to lack of time |
|
||||
val_dict = {} |
|
||||
for val in values: |
|
||||
if val == 'objects': |
|
||||
o = [] |
|
||||
for obj in values[val]: |
|
||||
x = OESerializer.serialize( |
|
||||
obj, |
|
||||
[ |
|
||||
v[len('object') + 1:] |
|
||||
for v in user_variable |
|
||||
if v.startswith('object') |
|
||||
] |
|
||||
) |
|
||||
o.append(x) |
|
||||
val_dict.update({val: o}) |
|
||||
continue |
|
||||
|
|
||||
x = OESerializer.serialize( |
|
||||
values[val], |
|
||||
[ |
|
||||
v[len(val) + 1:] |
|
||||
for v in user_variable |
|
||||
if v.startswith(val) |
|
||||
] |
|
||||
) |
|
||||
val_dict.update({val: x}) |
|
||||
|
|
||||
import pprint |
|
||||
pprint.pprint(val_dict) |
|
||||
val_json = json.dumps(val_dict) |
|
||||
|
|
||||
fields = { |
|
||||
'targetformat': filetype.fusion_ext, |
|
||||
'datadict': val_json, |
|
||||
'image_mapping': '{}', |
|
||||
} |
|
||||
print fields |
|
||||
|
|
||||
r = requests.post( |
|
||||
fusion_server.url, data=fields, files={'tmpl_file': in_temp} |
|
||||
) |
|
||||
in_temp.close() |
|
||||
if r.status_code == 400: |
|
||||
raise Exception("Problem with fusion server: %s" % r.json()) |
|
||||
|
|
||||
chunk_size = 1024 |
|
||||
|
|
||||
ext = filetype.human_ext |
|
||||
for chunk in r.iter_content(chunk_size): |
|
||||
out_temp.write(chunk) |
|
||||
out_temp.seek(0) |
|
||||
return out_temp.read(), ext |
|
Write
Preview
Loading…
Cancel
Save
Reference in new issue