Browse Source

Py3o update for odoo 8

--HG--
branch : odoo8
pull/80/head
Anael Lorimier 10 years ago
parent
commit
59ab08e179
  1. 2
      __init__.py
  2. 7
      __openerp__.py
  3. 4
      models/__init__.py
  4. 2
      models/ir_report.py
  5. 0
      models/py3o_fusion_filetype.py
  6. 0
      models/py3o_server.py
  7. 0
      models/py3o_template.py
  8. 58
      py3o_parser.py
  9. 0
      views/ir_report.xml
  10. 4
      views/menu.xml
  11. 0
      views/py3o_server.xml
  12. 0
      views/py3o_template.xml

2
__init__.py

@ -1 +1 @@
import ir_report
import models

7
__openerp__.py

@ -41,9 +41,12 @@ The py3o.template package is required; install it with:
'python': ['py3o.template'] 'python': ['py3o.template']
}, },
'data': [ 'data': [
'menu.xml',
'ir_report.xml',
'security/ir.model.access.csv', 'security/ir.model.access.csv',
'views/py3o_template.xml',
'views/py3o_server.xml',
'views/ir_report.xml',
'views/menu.xml',
], ],
'installable': True, 'installable': True,
} }

4
models/__init__.py

@ -0,0 +1,4 @@
import ir_report
import py3o_fusion_filetype
import py3o_template
import py3o_server

2
ir_report.py → models/ir_report.py

@ -1,7 +1,7 @@
import os import os
from openerp.osv import fields, osv from openerp.osv import fields, osv
from openerp.report.interface import report_int from openerp.report.interface import report_int
from .py3o_parser import Py3oParser
from ..py3o_parser import Py3oParser
from openerp import addons from openerp import addons

0
py3o_fusion_filetype.py → models/py3o_fusion_filetype.py

0
py3o_server.py → models/py3o_server.py

0
py3o_template.py → models/py3o_template.py

58
py3o_parser.py

@ -1,5 +1,9 @@
from base64 import b64decode
import requests
from tempfile import NamedTemporaryFile
from openerp.report.report_sxw import report_sxw, rml_parse from openerp.report.report_sxw import report_sxw, rml_parse
from openerp import registry from openerp import registry
from py3o.template import Template
_extender_functions = {} _extender_functions = {}
@ -64,7 +68,7 @@ class Py3oParser(report_sxw):
model_data = pool['ir.model.data'].browse( model_data = pool['ir.model.data'].browse(
cr, uid, model_data_ids[0], context=context cr, uid, model_data_ids[0], context=context
) )
xml_id = '%s,%s' % (model_data.module, model_data.name)
xml_id = '%s.%s' % (model_data.module, model_data.name)
parser_instance = self.parser(cr, uid, self.name2, context=context) parser_instance = self.parser(cr, uid, self.name2, context=context)
parser_instance.set_context( parser_instance.set_context(
@ -74,7 +78,57 @@ class Py3oParser(report_sxw):
if xml_id in _extender_functions: if xml_id in _extender_functions:
for fct in _extender_functions[xml_id]: for fct in _extender_functions[xml_id]:
pass
fct(pool, cr, uid, parser_instance.localcontext, context)
template = report_xml.py3o_template_id
filetype = report_xml.py3o_fusion_filetype
# py3o.template operates on filenames so create temporary files.
with NamedTemporaryFile(suffix='.odt', prefix='py3o-template-') as \
in_temp, \
NamedTemporaryFile(suffix='.odt', prefix='py3o-report-') as \
out_temp:
in_temp.write(b64decode(template.py3o_template_data))
in_temp.flush()
template = Template(in_temp.name, out_temp.name)
print parser_instance.localcontext
template.render(parser_instance.localcontext)
out_temp.seek(0)
if filetype.human_ext != 'odt':
# Now we ask fusion server to convert our template
fusion_server_obj = pool['py3o.server']
fusion_server_id = fusion_server_obj.search(
cr, uid, [], context=context
)[0]
fusion_server = fusion_server_obj.browse(
cr, uid, fusion_server_id, context=context
)
files = {
'tmpl_file': out_temp,
}
fields = {
"targetformat": filetype.fusion_ext,
"datadict": "{}",
"image_mapping": "{}",
"skipfusion": True,
}
r = requests.post(fusion_server.url, data=fields, files=files)
chunk_size = 1024
with NamedTemporaryFile(
suffix=filetype.human_ext,
prefix='py3o-template-'
) as fd:
for chunk in r.iter_content(chunk_size):
fd.write(chunk)
fd.seek(0)
return fd.read(), filetype.human_ext
return out_temp.read(), 'odt'
def create(self, cr, uid, ids, data, context=None): def create(self, cr, uid, ids, data, context=None):
""" Override this function to handle our py3o report """ Override this function to handle our py3o report

0
ir_report.xml → views/ir_report.xml

4
menu.xml → views/menu.xml

@ -2,7 +2,7 @@
<openerp> <openerp>
<data> <data>
<menuitem id="py3o_config_menu" <menuitem id="py3o_config_menu"
name="Py3o Configuration"
parent="base.menu_custom" />
name="Py3o"
parent="report.reporting_menuitem" />
</data> </data>
</openerp> </openerp>

0
py3o_server.xml → views/py3o_server.xml

0
py3o_template.xml → views/py3o_template.xml

Loading…
Cancel
Save