Add missing files
parent
54d831ec47
commit
487ed70777
|
@ -0,0 +1,6 @@
|
||||||
|
id,fusion_ext,human_ext
|
||||||
|
py3o_fusion_filetype_odt,ODT,odt
|
||||||
|
py3o_fusion_filetype_ods,ODS,ods
|
||||||
|
py3o_fusion_filetype_doc,DOC,doc
|
||||||
|
py3o_fusion_filetype_docx,DOCX,docx
|
||||||
|
py3o_fusion_filetype_pdf,PDF,pdf
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<openerp>
|
||||||
|
<data>
|
||||||
|
<menuitem id="py3o_config_menu"
|
||||||
|
name="Py3o Configuration"
|
||||||
|
parent="base.menu_custom" />
|
||||||
|
</data>
|
||||||
|
</openerp>
|
|
@ -0,0 +1,18 @@
|
||||||
|
from openerp.osv import fields, osv
|
||||||
|
|
||||||
|
|
||||||
|
class py3o_fusion_filetype(osv.Model):
|
||||||
|
_name = 'py3o.fusion.filetype'
|
||||||
|
|
||||||
|
_rec_name = 'human_ext'
|
||||||
|
|
||||||
|
_columns = {
|
||||||
|
'fusion_ext': fields.char(
|
||||||
|
u"Fusion Extension",
|
||||||
|
size=8,
|
||||||
|
),
|
||||||
|
'human_ext': fields.char(
|
||||||
|
u"Human readble extension",
|
||||||
|
size=8,
|
||||||
|
),
|
||||||
|
}
|
|
@ -0,0 +1,144 @@
|
||||||
|
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_user_variable()]
|
||||||
|
print user_variable
|
||||||
|
|
||||||
|
values = self.get_values(cr, uid, ids, data, context)
|
||||||
|
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
|
|
@ -0,0 +1,12 @@
|
||||||
|
from openerp.osv import fields, osv
|
||||||
|
|
||||||
|
|
||||||
|
class py3o_server(osv.Model):
|
||||||
|
_name = 'py3o.server'
|
||||||
|
|
||||||
|
_columns = {
|
||||||
|
'url': fields.char(
|
||||||
|
u"URL",
|
||||||
|
size=256,
|
||||||
|
),
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<openerp>
|
||||||
|
<data>
|
||||||
|
<record id="py3o_server_configuration_form_view" model="ir.ui.view">
|
||||||
|
<field name="name">py3o.server.configuration.form.view</field>
|
||||||
|
<field name="model">py3o.server</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<form string="Py3o Server Configuration" version="7.0">
|
||||||
|
<sheet>
|
||||||
|
<group>
|
||||||
|
<field name="url" />
|
||||||
|
</group>
|
||||||
|
</sheet>
|
||||||
|
</form>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="py3o_server_configuration_tree_view" model="ir.ui.view">
|
||||||
|
<field name="name">py3o.server.configuration.tree.view</field>
|
||||||
|
<field name="model">py3o.server</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree string="Py3o Server Configuration" version="7.0">
|
||||||
|
<field name="url" />
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="py3o_server_configuration_action" model="ir.actions.act_window">
|
||||||
|
<field name="name">py3o.server.configuration.action</field>
|
||||||
|
<field name="res_model">py3o.server</field>
|
||||||
|
<field name="view_type">form</field>
|
||||||
|
<field name="view_mode">tree,form</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<menuitem id="py3o_server_configuration_menu"
|
||||||
|
name="Py3o Server Configuration"
|
||||||
|
parent="py3o_config_menu"
|
||||||
|
action="py3o_server_configuration_action" />
|
||||||
|
</data>
|
||||||
|
</openerp>
|
|
@ -0,0 +1,14 @@
|
||||||
|
from openerp.osv import fields, osv
|
||||||
|
|
||||||
|
|
||||||
|
class py3o_template(osv.Model):
|
||||||
|
_name = 'py3o.template'
|
||||||
|
|
||||||
|
_columns = {
|
||||||
|
'name': fields.char(
|
||||||
|
u"Name",
|
||||||
|
),
|
||||||
|
'py3o_template_data': fields.binary(
|
||||||
|
u"LibreOffice template",
|
||||||
|
),
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<openerp>
|
||||||
|
<data>
|
||||||
|
<record id="py3o_template_configuration_form_view" model="ir.ui.view">
|
||||||
|
<field name="name">py3o.template.configuration.form.view</field>
|
||||||
|
<field name="model">py3o.template</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<form string="Py3o Templates Configuration" version="7.0">
|
||||||
|
<sheet>
|
||||||
|
<group>
|
||||||
|
<field name="name" />
|
||||||
|
<field name="py3o_template_data" />
|
||||||
|
</group>
|
||||||
|
</sheet>
|
||||||
|
</form>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="py3o_template_configuration_tree_view" model="ir.ui.view">
|
||||||
|
<field name="name">py3o.template.configuration.tree.view</field>
|
||||||
|
<field name="model">py3o.template</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree string="Py3o Templates Configuration" version="7.0">
|
||||||
|
<field name="name" />
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="py3o_template_configuration_action" model="ir.actions.act_window">
|
||||||
|
<field name="name">Py3o Templates Configuration</field>
|
||||||
|
<field name="res_model">py3o.template</field>
|
||||||
|
<field name="view_type">form</field>
|
||||||
|
<field name="view_mode">tree,form</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<menuitem id="py3o_template_configuration_menu"
|
||||||
|
name="Py3o Templates"
|
||||||
|
parent="py3o_config_menu"
|
||||||
|
action="py3o_template_configuration_action" />
|
||||||
|
</data>
|
||||||
|
</openerp>
|
Loading…
Reference in New Issue