Nessuna descrizione

manage_access_control_routes.py 2.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # IRIS Source Code
  2. # Copyright (C) 2024 - DFIR-IRIS
  3. # contact@dfir-iris.org
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU Lesser General Public
  7. # License as published by the Free Software Foundation; either
  8. # version 3 of the 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 GNU
  13. # Lesser General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU Lesser General Public License
  16. # along with this program; if not, write to the Free Software Foundation,
  17. # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. from flask import Blueprint
  19. from app.business.users import users_reset_mfa
  20. from app.iris_engine.access_control.utils import ac_recompute_all_users_effective_ac
  21. from app.iris_engine.access_control.utils import ac_recompute_effective_ac
  22. from app.iris_engine.access_control.utils import ac_trace_effective_user_permissions
  23. from app.iris_engine.access_control.utils import ac_trace_user_effective_cases_access_2
  24. from app.models.authorization import Permissions
  25. from app.blueprints.access_controls import ac_api_requires
  26. from app.blueprints.responses import response_success
  27. manage_ac_rest_blueprint = Blueprint('access_control_rest', __name__)
  28. @manage_ac_rest_blueprint.route('/manage/access-control/recompute-effective-users-ac', methods=['GET'])
  29. @ac_api_requires(Permissions.server_administrator)
  30. def manage_ac_compute_effective_all_ac():
  31. ac_recompute_all_users_effective_ac()
  32. return response_success('Updated')
  33. @manage_ac_rest_blueprint.route('/manage/access-control/recompute-effective-user-ac/<int:cur_id>', methods=['GET'])
  34. @ac_api_requires(Permissions.server_administrator)
  35. def manage_ac_compute_effective_ac(cur_id):
  36. ac_recompute_effective_ac(cur_id)
  37. return response_success('Updated')
  38. @manage_ac_rest_blueprint.route('/manage/access-control/reset-mfa/<int:cur_id>', methods=['GET'])
  39. @ac_api_requires(Permissions.server_administrator)
  40. def manage_ac_reset_mfa(cur_id):
  41. users_reset_mfa(cur_id)
  42. return response_success('Updated')
  43. @manage_ac_rest_blueprint.route('/manage/access-control/audit/users/<int:cur_id>', methods=['GET'])
  44. @ac_api_requires(Permissions.server_administrator)
  45. def manage_ac_audit_user(cur_id):
  46. user_audit = {
  47. 'access_audit': ac_trace_user_effective_cases_access_2(cur_id),
  48. 'permissions_audit': ac_trace_effective_user_permissions(cur_id)
  49. }
  50. return response_success(data=user_audit)