Brak opisu

case_tasks_routes.py 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. # IRIS Source Code
  2. # Copyright (C) 2021 - Airbus CyberSecurity (SAS) - DFIR-IRIS Team
  3. # ir@cyberactionlab.net - 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 flask import redirect
  20. from flask import render_template
  21. from flask import url_for
  22. from flask_login import current_user
  23. from flask_wtf import FlaskForm
  24. from app.datamgmt.case.case_db import get_case
  25. from app.datamgmt.case.case_tasks_db import get_case_tasks_comments_count
  26. from app.datamgmt.case.case_tasks_db import get_task
  27. from app.datamgmt.case.case_tasks_db import get_task_assignees
  28. from app.datamgmt.case.case_tasks_db import get_tasks_status
  29. from app.datamgmt.manage.manage_attribute_db import get_default_custom_attributes
  30. from app.forms import CaseTaskForm
  31. from app.models.authorization import CaseAccessLevel
  32. from app.models.authorization import User
  33. from app.models.models import CaseTasks
  34. from app.blueprints.access_controls import ac_case_requires
  35. from app.blueprints.responses import response_error
  36. case_tasks_blueprint = Blueprint('case_tasks',
  37. __name__,
  38. template_folder='templates')
  39. @case_tasks_blueprint.route('/case/tasks', methods=['GET'])
  40. @ac_case_requires(CaseAccessLevel.read_only, CaseAccessLevel.full_access)
  41. def case_tasks(caseid, url_redir):
  42. if url_redir:
  43. return redirect(url_for('case_tasks.case_tasks', cid=caseid, redirect=True))
  44. form = FlaskForm()
  45. case = get_case(caseid)
  46. return render_template("case_tasks.html", case=case, form=form)
  47. @case_tasks_blueprint.route('/case/tasks/add/modal', methods=['GET'])
  48. @ac_case_requires(CaseAccessLevel.full_access)
  49. def case_add_task_modal(caseid, url_redir):
  50. if url_redir:
  51. return redirect(url_for('case_tasks.case_tasks', cid=caseid, redirect=True))
  52. task = CaseTasks()
  53. task.custom_attributes = get_default_custom_attributes('task')
  54. form = CaseTaskForm()
  55. form.task_status_id.choices = [(a.id, a.status_name) for a in get_tasks_status()]
  56. form.task_assignees_id.choices = []
  57. return render_template("modal_add_case_task.html", form=form, task=task, uid=current_user.id, user_name=None,
  58. attributes=task.custom_attributes)
  59. @case_tasks_blueprint.route('/case/tasks/<int:cur_id>/modal', methods=['GET'])
  60. @ac_case_requires(CaseAccessLevel.read_only, CaseAccessLevel.full_access)
  61. def case_task_view_modal(cur_id, caseid, url_redir):
  62. if url_redir:
  63. return redirect(url_for('case_tasks.case_tasks', cid=caseid, redirect=True))
  64. form = CaseTaskForm()
  65. task = get_task(task_id=cur_id)
  66. task_assignees = get_task_assignees(cur_id)
  67. form.task_status_id.choices = [(a.id, a.status_name) for a in get_tasks_status()]
  68. form.task_assignees_id.choices = []
  69. if not task:
  70. return response_error("Invalid task ID for this case")
  71. form.task_title.render_kw = {'value': task.task_title}
  72. form.task_description.data = task.task_description
  73. user_name, = User.query.with_entities(User.name).filter(User.id == task.task_userid_update).first()
  74. comments_map = get_case_tasks_comments_count([task.id])
  75. return render_template("modal_add_case_task.html", form=form, task=task, task_assignees=task_assignees,
  76. user_name=user_name, comments_map=comments_map, attributes=task.custom_attributes)
  77. @case_tasks_blueprint.route('/case/tasks/<int:cur_id>/comments/modal', methods=['GET'])
  78. @ac_case_requires(CaseAccessLevel.read_only, CaseAccessLevel.full_access)
  79. def case_comment_task_modal(cur_id, caseid, url_redir):
  80. if url_redir:
  81. return redirect(url_for('case_task.case_task', cid=caseid, redirect=True))
  82. task = get_task(cur_id)
  83. if not task:
  84. return response_error('Invalid task ID')
  85. return render_template("modal_conversation.html", element_id=cur_id, element_type='tasks',
  86. title=task.task_title)