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.

49 lines
2.1 KiB

  1. ###################################################################################
  2. #
  3. # Copyright (C) 2017 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 json
  20. import base64
  21. import logging
  22. from odoo import http
  23. from odoo.http import request
  24. _logger = logging.getLogger(__name__)
  25. class BackendController(http.Controller):
  26. @http.route('/utils/attachment/add', type='http', auth="user", methods=['POST'])
  27. def add_attachment(self, ufile=None, **kw):
  28. content = ufile.read()
  29. attachment = request.env['ir.attachment'].create({
  30. 'name': "Access Attachment: %s" % ufile.filename,
  31. 'datas': base64.b64encode(content),
  32. 'datas_fname': ufile.filename,
  33. 'type': 'binary',
  34. 'public': False,
  35. })
  36. attachment.generate_access_token()
  37. base_url = request.env['ir.config_parameter'].sudo().get_param('web.base.url')
  38. result = attachment.read(['name', 'datas_fname', 'mimetype', 'checksum', 'access_token'])[0]
  39. result['url'] = '%s/web/content/%s?access_token=%s' % (base_url, attachment.id, attachment.access_token)
  40. return json.dumps(result)
  41. @http.route('/utils/attachment/remove', type='http', auth="user", methods=['POST'])
  42. def remove_attachment(self, id, **kw):
  43. return json.dumps(request.env['ir.attachment'].browse(id).unlink())