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.

56 lines
2.3 KiB

6 years ago
  1. ###################################################################################
  2. #
  3. # Copyright (C) 2018 MuK IT GmbH
  4. #
  5. # This program is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU Affero General Public License as
  7. # published by the Free Software Foundation, either version 3 of the
  8. # License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU Affero General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU Affero General Public License
  16. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. #
  18. ###################################################################################
  19. import hashlib
  20. import logging
  21. from odoo import api, models, fields
  22. from odoo.addons.muk_converter.tools import converter
  23. _logger = logging.getLogger(__name__)
  24. class Converter(models.AbstractModel):
  25. _name = 'muk_converter.converter'
  26. _description = 'Converter'
  27. @api.model
  28. def convert(self, filename, content, format="pdf", recompute=False):
  29. def parse(filename, content, format):
  30. return converter.convert(filename, content, format)
  31. def store(checksum, filename, content, format, stored):
  32. if not stored.exists():
  33. self.env['muk_converter.store'].sudo().create({
  34. 'checksum': checksum,
  35. 'format': format,
  36. 'content_fname': filename,
  37. 'content': content})
  38. else:
  39. stored.write({'used_date': fields.Datetime.now})
  40. checksum = hashlib.sha1(content).hexdigest()
  41. stored = self.env['muk_converter.store'].sudo().search(
  42. [["checksum", "=", checksum], ["format", "=", format]], limit=1)
  43. if not recompute and stored.exists():
  44. return stored.content
  45. else:
  46. output = parse(filename, content, format)
  47. name = "%s.%s" % (filename, format)
  48. store(checksum, name, output, format, stored)
  49. return output