No Description

tasks.py 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  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 flask import request
  20. from app.blueprints.rest.endpoints import response_api_error
  21. from app.blueprints.rest.endpoints import response_api_not_found
  22. from app.blueprints.rest.endpoints import response_api_deleted
  23. from app.blueprints.rest.endpoints import response_api_success
  24. from app.blueprints.rest.endpoints import response_api_paginated
  25. from app.blueprints.rest.endpoints import response_api_created
  26. from app.blueprints.rest.parsing import parse_pagination_parameters
  27. from app.blueprints.access_controls import ac_api_return_access_denied
  28. from app.blueprints.access_controls import ac_api_requires
  29. from app.schema.marshables import CaseTaskSchema
  30. from app.business.errors import BusinessProcessingError
  31. from app.business.errors import ObjectNotFoundError
  32. from app.business.tasks import tasks_create
  33. from app.business.tasks import tasks_get
  34. from app.business.tasks import tasks_update
  35. from app.business.tasks import tasks_delete
  36. from app.business.tasks import tasks_filter
  37. from app.models.authorization import CaseAccessLevel
  38. from app.iris_engine.access_control.utils import ac_fast_check_current_user_has_case_access
  39. case_tasks_blueprint = Blueprint('case_tasks',
  40. __name__,
  41. url_prefix='/<int:case_identifier>/tasks')
  42. @case_tasks_blueprint.post('')
  43. @ac_api_requires()
  44. def add_case_task(case_identifier):
  45. """
  46. Add a task to a case.
  47. Args:
  48. case_identifier (int): The Case ID for this task
  49. """
  50. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.full_access]):
  51. return ac_api_return_access_denied(caseid=case_identifier)
  52. task_schema = CaseTaskSchema()
  53. try:
  54. _, case = tasks_create(case_identifier, request.get_json())
  55. return response_api_created(task_schema.dump(case))
  56. except BusinessProcessingError as e:
  57. return response_api_error(e.get_message())
  58. @case_tasks_blueprint.get('')
  59. @ac_api_requires()
  60. def case_get_tasks(case_identifier):
  61. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  62. return ac_api_return_access_denied(caseid=case_identifier)
  63. pagination_parameters = parse_pagination_parameters(request)
  64. tasks = tasks_filter(case_identifier, pagination_parameters)
  65. task_schema = CaseTaskSchema()
  66. return response_api_paginated(task_schema, tasks)
  67. @case_tasks_blueprint.get('/<int:identifier>')
  68. @ac_api_requires()
  69. def get_case_task(case_identifier, identifier):
  70. """
  71. Handles getting a task from a case.
  72. Args:
  73. case_identifier (int): The case ID
  74. identifier (int): The task ID
  75. """
  76. try:
  77. task = tasks_get(identifier)
  78. if task.task_case_id != case_identifier:
  79. raise ObjectNotFoundError()
  80. if not ac_fast_check_current_user_has_case_access(task.task_case_id, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  81. return ac_api_return_access_denied(caseid=task.task_case_id)
  82. task_schema = CaseTaskSchema()
  83. return response_api_success(task_schema.dump(task))
  84. except ObjectNotFoundError:
  85. return response_api_not_found()
  86. @case_tasks_blueprint.put('/<int:identifier>')
  87. @ac_api_requires()
  88. def update_case_task(case_identifier, identifier):
  89. try:
  90. task = tasks_get(identifier)
  91. if task.task_case_id != case_identifier:
  92. raise ObjectNotFoundError()
  93. if not ac_fast_check_current_user_has_case_access(task.task_case_id, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  94. return ac_api_return_access_denied(caseid=task.task_case_id)
  95. task = tasks_update(task, request.get_json())
  96. task_schema = CaseTaskSchema()
  97. return response_api_success(task_schema.dump(task))
  98. except ObjectNotFoundError:
  99. return response_api_not_found()
  100. except BusinessProcessingError as e:
  101. return response_api_error(e.get_message())
  102. @case_tasks_blueprint.delete('/<int:identifier>')
  103. @ac_api_requires()
  104. def delete_case_task(case_identifier, identifier):
  105. """
  106. Handle deleting a task from a case
  107. Args:
  108. case_identifier (int): The case ID
  109. identifier (int): The task ID
  110. """
  111. try:
  112. task = tasks_get(identifier)
  113. if task.task_case_id != case_identifier:
  114. raise ObjectNotFoundError()
  115. if not ac_fast_check_current_user_has_case_access(task.task_case_id, [CaseAccessLevel.full_access]):
  116. return ac_api_return_access_denied(caseid=identifier)
  117. tasks_delete(task)
  118. return response_api_deleted()
  119. except ObjectNotFoundError:
  120. return response_api_not_found()
  121. except BusinessProcessingError as e:
  122. return response_api_error(e.get_message())