OCA reporting engine fork for dev and update.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

105 lines
3.9 KiB

  1. from base64 import b64decode
  2. from tempfile import NamedTemporaryFile
  3. from openerp import pooler
  4. from openerp.report.report_sxw import *
  5. from openerp.tools.translate import _
  6. from openerp.osv.osv import except_osv
  7. from py3o.template import Template
  8. import requests
  9. class py3o_report(report_sxw):
  10. # def __init__(self, name, table):
  11. # super(py3o_report, self).__init__(name, table)
  12. def get_values(self, cr, uid, ids, data, context):
  13. ''' Override this function to customize the dictionary given to the
  14. py3o.template renderer. '''
  15. return {
  16. 'lang': self.get_lang(cr, uid, context),
  17. 'objects': self.getObjects(cr, uid, ids, context),
  18. }
  19. def get_lang(self, cr, uid, context):
  20. pool = pooler.get_pool(cr.dbname)
  21. lang_obj = pool.get('res.lang')
  22. user_obj = pool.get('res.users')
  23. lang_code = user_obj.browse(cr, uid, uid, context=context).lang
  24. lang = lang_obj.search(cr, uid,
  25. [('code', '=', lang_code)],
  26. context=context)[0]
  27. return lang_obj.browse(cr, uid, lang, context=context)
  28. def format_date(self, date, values):
  29. ''' Return a date formatted according to the language extracted from
  30. the "values" argument (which should be the result of get_values). '''
  31. return date.strftime(values['lang'].date_format)
  32. def create(self, cr, uid, ids, data, context=None):
  33. # Find the report definition to get its settings.
  34. pool = pooler.get_pool(cr.dbname)
  35. report_xml_obj = pool.get('ir.actions.report.xml')
  36. report_xml_ids = report_xml_obj.search(cr, uid,
  37. [('report_name', '=', self.name[7:])], # Ignore "report."
  38. context=context)
  39. if not report_xml_ids:
  40. return super(py3o_report, self).create(cr, uid, ids, data,
  41. context=context)
  42. report_xml = report_xml_obj.browse(cr, uid,
  43. report_xml_ids[0],
  44. context=context)
  45. template = report_xml.py3o_template_id
  46. filetype = report_xml.py3o_fusion_filetype
  47. # py3o.template operates on filenames so create temporary files.
  48. with NamedTemporaryFile(suffix='.odt', prefix='py3o-template-') as \
  49. in_temp, \
  50. NamedTemporaryFile(suffix='.odt', prefix='py3o-report-') as \
  51. out_temp:
  52. in_temp.write(b64decode(template.py3o_template_data))
  53. in_temp.flush()
  54. template = Template(in_temp.name, out_temp.name)
  55. template.render(self.get_values(cr, uid, ids, data, context))
  56. out_temp.seek(0)
  57. if filetype.human_ext != 'odt':
  58. # Now we ask fusion server to convert our template
  59. fusion_server_obj = pool['py3o.server']
  60. fusion_server_id = fusion_server_obj.search(
  61. cr, uid, [], context=context
  62. )[0]
  63. fusion_server = fusion_server_obj.browse(
  64. cr, uid, fusion_server_id, context=context
  65. )
  66. files = {
  67. 'tmpl_file': out_temp,
  68. }
  69. fields = {
  70. "targetformat": filetype.fusion_ext,
  71. "datadict": "{}",
  72. "image_mapping": "{}",
  73. "skipfusion": True,
  74. }
  75. r = requests.post(fusion_server.url, data=fields, files=files)
  76. chunk_size = 1024
  77. with NamedTemporaryFile(
  78. suffix=filetype.human_ext,
  79. prefix='py3o-template-') as fd:
  80. for chunk in r.iter_content(chunk_size):
  81. fd.write(chunk)
  82. fd.seek(0)
  83. return fd.read(), filetype.human_ext
  84. return out_temp.read(), 'odt'
  85. return False, False