| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- # IRIS Source Code
- # Copyright (C) 2024 - DFIR-IRIS
- # contact@dfir-iris.org
- #
- # This program is free software; you can redistribute it and/or
- # modify it under the terms of the GNU Lesser General Public
- # License as published by the Free Software Foundation; either
- # version 3 of the License, or (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- # Lesser General Public License for more details.
- #
- # You should have received a copy of the GNU Lesser General Public License
- # along with this program; if not, write to the Free Software Foundation,
- # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- from flask import Blueprint
- from app.business.users import users_reset_mfa
- from app.iris_engine.access_control.utils import ac_recompute_all_users_effective_ac
- from app.iris_engine.access_control.utils import ac_recompute_effective_ac
- from app.iris_engine.access_control.utils import ac_trace_effective_user_permissions
- from app.iris_engine.access_control.utils import ac_trace_user_effective_cases_access_2
- from app.models.authorization import Permissions
- from app.blueprints.access_controls import ac_api_requires
- from app.blueprints.responses import response_success
- manage_ac_rest_blueprint = Blueprint('access_control_rest', __name__)
- @manage_ac_rest_blueprint.route('/manage/access-control/recompute-effective-users-ac', methods=['GET'])
- @ac_api_requires(Permissions.server_administrator)
- def manage_ac_compute_effective_all_ac():
- ac_recompute_all_users_effective_ac()
- return response_success('Updated')
- @manage_ac_rest_blueprint.route('/manage/access-control/recompute-effective-user-ac/<int:cur_id>', methods=['GET'])
- @ac_api_requires(Permissions.server_administrator)
- def manage_ac_compute_effective_ac(cur_id):
- ac_recompute_effective_ac(cur_id)
- return response_success('Updated')
- @manage_ac_rest_blueprint.route('/manage/access-control/reset-mfa/<int:cur_id>', methods=['GET'])
- @ac_api_requires(Permissions.server_administrator)
- def manage_ac_reset_mfa(cur_id):
- users_reset_mfa(cur_id)
- return response_success('Updated')
- @manage_ac_rest_blueprint.route('/manage/access-control/audit/users/<int:cur_id>', methods=['GET'])
- @ac_api_requires(Permissions.server_administrator)
- def manage_ac_audit_user(cur_id):
- user_audit = {
- 'access_audit': ac_trace_user_effective_cases_access_2(cur_id),
- 'permissions_audit': ac_trace_effective_user_permissions(cur_id)
- }
- return response_success(data=user_audit)
|