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.

85 lines
3.1 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 logging
  20. from odoo import api, models, fields
  21. from odoo.addons.muk_security.tools.security import NoSecurityUid
  22. _logger = logging.getLogger(__name__)
  23. class Base(models.AbstractModel):
  24. _inherit = 'base'
  25. #----------------------------------------------------------
  26. # Helper
  27. #----------------------------------------------------------
  28. def _filter_access_rules(self, operation):
  29. if isinstance(self.env.uid, NoSecurityUid):
  30. return self
  31. return super(Base, self)._filter_access_rules(operation)
  32. @api.multi
  33. def _filter_access(self, operation):
  34. if self.check_access_rights('read', False):
  35. return self._filter_access_rules(operation)
  36. return self.env[self._name]
  37. @api.multi
  38. def _filter_access_ids(self, operation):
  39. return self._filter_access(operation).ids
  40. @api.model
  41. def _apply_ir_rules(self, query, mode='read'):
  42. if isinstance(self.env.uid, NoSecurityUid):
  43. return None
  44. return super(Base, self)._apply_ir_rules(query, mode=mode)
  45. #----------------------------------------------------------
  46. # Function
  47. #----------------------------------------------------------
  48. @api.model
  49. def suspend_security(self, user=None):
  50. return self.sudo(user=NoSecurityUid(user or self.env.uid))
  51. @api.multi
  52. def check_access_rule(self, operation):
  53. if isinstance(self.env.uid, NoSecurityUid):
  54. return None
  55. return super(Base, self).check_access_rule(operation)
  56. @api.model
  57. def check_field_access_rights(self, operation, fields):
  58. if isinstance(self.env.uid, NoSecurityUid):
  59. return fields or list(self._fields)
  60. return super(Base, self).check_field_access_rights(operation, fields)
  61. @api.multi
  62. def check_access(self, operation, raise_exception=False):
  63. try:
  64. access_right = self.check_access_rights(operation, raise_exception)
  65. access_rule = self.check_access_rule(operation) is None
  66. return access_right and access_rule
  67. except AccessError:
  68. if raise_exception:
  69. raise
  70. return False