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.

67 lines
2.4 KiB

  1. ###################################################################################
  2. #
  3. # Copyright (c) 2017-2019 MuK IT GmbH.
  4. #
  5. # This file is part of MuK Security
  6. # (see https://mukit.at).
  7. #
  8. # This program is free software: you can redistribute it and/or modify
  9. # it under the terms of the GNU Lesser General Public License as published by
  10. # the Free Software Foundation, either version 3 of the License, or
  11. # (at your option) any later version.
  12. #
  13. # This program is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU Lesser General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU Lesser General Public License
  19. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. #
  21. ###################################################################################
  22. import logging
  23. from odoo import api, models, fields
  24. from odoo.addons.muk_security.tools.security import NoSecurityUid
  25. _logger = logging.getLogger(__name__)
  26. class Base(models.AbstractModel):
  27. _inherit = 'base'
  28. #----------------------------------------------------------
  29. # Helper
  30. #----------------------------------------------------------
  31. def _filter_access_rules(self, operation):
  32. if isinstance(self.env.uid, NoSecurityUid):
  33. return self
  34. return super(Base, self)._filter_access_rules(operation)
  35. @api.model
  36. def _apply_ir_rules(self, query, mode='read'):
  37. if isinstance(self.env.uid, NoSecurityUid):
  38. return None
  39. return super(Base, self)._apply_ir_rules(query, mode=mode)
  40. #----------------------------------------------------------
  41. # Function
  42. #----------------------------------------------------------
  43. @api.model
  44. def suspend_security(self, user=None):
  45. return self.sudo(user=NoSecurityUid(user or self.env.uid))
  46. @api.multi
  47. def check_access_rule(self, operation):
  48. if isinstance(self.env.uid, NoSecurityUid):
  49. return None
  50. return super(Base, self).check_access_rule(operation)
  51. @api.model
  52. def check_field_access_rights(self, operation, fields):
  53. if isinstance(self.env.uid, NoSecurityUid):
  54. return fields or list(self._fields)
  55. return super(Base, self).check_field_access_rights(operation, fields)