Нет описания

manage_access_control.py 2.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. # IRIS Source Code
  2. # contact@dfir-iris.org
  3. #
  4. # This program is free software; you can redistribute it and/or
  5. # modify it under the terms of the GNU Lesser General Public
  6. # License as published by the Free Software Foundation; either
  7. # version 3 of the License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. # Lesser General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU Lesser General Public License
  15. # along with this program; if not, write to the Free Software Foundation,
  16. # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  17. from flask import Blueprint
  18. from flask import render_template
  19. from flask import url_for
  20. from flask_wtf import FlaskForm
  21. from werkzeug.utils import redirect
  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_requires
  26. manage_ac_blueprint = Blueprint(
  27. 'access_control',
  28. __name__,
  29. template_folder='templates/access_control'
  30. )
  31. @manage_ac_blueprint.route('/manage/access-control', methods=['GET'])
  32. @ac_requires(Permissions.server_administrator)
  33. def manage_ac_index(caseid, url_redir):
  34. if url_redir:
  35. return redirect(url_for('access_control.manage_ac_index', cid=caseid))
  36. form = FlaskForm()
  37. return render_template("manage_access-control.html", form=form)
  38. @manage_ac_blueprint.route('/manage/access-control/audit/users/<int:cur_id>/modal', methods=['GET'])
  39. @ac_requires(Permissions.server_administrator, no_cid_required=True)
  40. def manage_ac_audit_user_modal(cur_id, caseid, url_redir):
  41. if url_redir:
  42. return redirect(url_for('access_control.manage_ac_index', cid=caseid))
  43. access_audit = ac_trace_user_effective_cases_access_2(cur_id)
  44. permissions_audit = ac_trace_effective_user_permissions(cur_id)
  45. return render_template("modal_user_audit.html", access_audit=access_audit, permissions_audit=permissions_audit)
  46. @manage_ac_blueprint.route('/manage/access-control/audit/users', methods=['GET'])
  47. @ac_requires(Permissions.server_administrator)
  48. def manage_ac_audit_users_page(caseid, url_redir):
  49. form = FlaskForm()
  50. return render_template("manage_user_audit.html", form=form)