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.

81 lines
2.8 KiB

  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 os
  20. import re
  21. import io
  22. import sys
  23. import base64
  24. import shutil
  25. import urllib
  26. import logging
  27. import tempfile
  28. import mimetypes
  29. import unicodedata
  30. from odoo.tools.mimetypes import guess_mimetype
  31. _logger = logging.getLogger(__name__)
  32. #----------------------------------------------------------
  33. # File Helper
  34. #----------------------------------------------------------
  35. def slugify(value):
  36. value = str(unicodedata.normalize('NFKD', value))
  37. if sys.version_info < (3,):
  38. value = str(value.encode('ascii', 'ignore'))
  39. value = str(re.sub('[^\w\s-]', '', value).strip().lower())
  40. value = str(re.sub('[-\s]+', '-', value))
  41. return value
  42. def compute_name(name, suffix, escape_suffix):
  43. if escape_suffix:
  44. name, extension = os.path.splitext(name)
  45. return "%s(%s)%s" % (name, suffix, extension)
  46. else:
  47. return "%s(%s)" % (name, suffix)
  48. def unique_name(name, names, escape_suffix=False):
  49. if not name in names:
  50. return name
  51. else:
  52. suffix = 1
  53. name = compute_name(name, suffix, escape_suffix)
  54. while name in names:
  55. suffix += 1
  56. name = compute_name(name, suffix, escape_suffix)
  57. return name
  58. def unique_files(files):
  59. ufiles = []
  60. unames = []
  61. for file in files:
  62. uname = unique_name(file[0], unames, escape_suffix=True)
  63. ufiles.append((uname, file[1]))
  64. unames.append(uname)
  65. return ufiles
  66. def guess_extension(filename=None, mimetype=None, binary=None):
  67. extension = filename and os.path.splitext(filename)[1][1:].strip().lower()
  68. if not extension and mimetype:
  69. extension = mimetypes.guess_extension(mimetype)[1:].strip().lower()
  70. if not extension and binary:
  71. mimetype = guess_mimetype(binary, default="")
  72. extension = mimetypes.guess_extension(mimetype)[1:].strip().lower()
  73. return extension