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.

64 lines
2.4 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.model
  33. def _apply_ir_rules(self, query, mode='read'):
  34. if isinstance(self.env.uid, NoSecurityUid):
  35. return None
  36. return super(Base, self)._apply_ir_rules(query, mode=mode)
  37. #----------------------------------------------------------
  38. # Function
  39. #----------------------------------------------------------
  40. @api.model
  41. def suspend_security(self, user=None):
  42. return self.sudo(user=NoSecurityUid(user or self.env.uid))
  43. @api.multi
  44. def check_access_rule(self, operation):
  45. if isinstance(self.env.uid, NoSecurityUid):
  46. return None
  47. return super(Base, self).check_access_rule(operation)
  48. @api.model
  49. def check_field_access_rights(self, operation, fields):
  50. if isinstance(self.env.uid, NoSecurityUid):
  51. return fields or list(self._fields)
  52. return super(Base, self).check_field_access_rights(operation, fields)