Brak opisu

iocs.py 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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. import logging as log
  19. from flask import Blueprint
  20. from flask import request
  21. from app.blueprints.access_controls import ac_api_requires
  22. from app.blueprints.rest.endpoints import response_api_created
  23. from app.blueprints.rest.endpoints import response_api_deleted
  24. from app.blueprints.rest.endpoints import response_api_not_found
  25. from app.blueprints.rest.endpoints import response_api_error
  26. from app.blueprints.rest.endpoints import response_api_success
  27. from app.blueprints.rest.endpoints import response_api_paginated
  28. from app.blueprints.rest.parsing import parse_pagination_parameters
  29. from app.business.errors import BusinessProcessingError
  30. from app.business.errors import ObjectNotFoundError
  31. from app.business.iocs import iocs_create
  32. from app.business.iocs import iocs_get
  33. from app.business.iocs import iocs_delete
  34. from app.business.iocs import iocs_update
  35. from app.datamgmt.case.case_iocs_db import get_filtered_iocs
  36. from app.iris_engine.access_control.utils import ac_fast_check_current_user_has_case_access
  37. from app.models.authorization import CaseAccessLevel
  38. from app.schema.marshables import IocSchemaForAPIV2
  39. from app.blueprints.access_controls import ac_api_return_access_denied
  40. case_iocs_blueprint = Blueprint('case_ioc_rest_v2',
  41. __name__,
  42. url_prefix='/<int:case_identifier>/iocs')
  43. @case_iocs_blueprint.get('')
  44. @ac_api_requires()
  45. def get_case_iocs(case_identifier):
  46. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  47. return ac_api_return_access_denied(caseid=case_identifier)
  48. pagination_parameters = parse_pagination_parameters(request)
  49. ioc_type_id = request.args.get('ioc_type_id', None, type=int)
  50. ioc_type = request.args.get('ioc_type', None, type=str)
  51. ioc_tlp_id = request.args.get('ioc_tlp_id', None, type=int)
  52. ioc_value = request.args.get('ioc_value', None, type=str)
  53. ioc_description = request.args.get('ioc_description', None, type=str)
  54. ioc_tags = request.args.get('ioc_tags', None, type=str)
  55. filtered_iocs = get_filtered_iocs(
  56. pagination_parameters,
  57. caseid=case_identifier,
  58. ioc_type_id=ioc_type_id,
  59. ioc_type=ioc_type,
  60. ioc_tlp_id=ioc_tlp_id,
  61. ioc_value=ioc_value,
  62. ioc_description=ioc_description,
  63. ioc_tags=ioc_tags
  64. )
  65. if filtered_iocs is None:
  66. return response_api_error('Filtering error')
  67. iocs_schema = IocSchemaForAPIV2()
  68. return response_api_paginated(iocs_schema, filtered_iocs)
  69. @case_iocs_blueprint.post('')
  70. @ac_api_requires()
  71. def add_ioc_to_case(case_identifier):
  72. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.full_access]):
  73. return ac_api_return_access_denied(caseid=case_identifier)
  74. ioc_schema = IocSchemaForAPIV2()
  75. try:
  76. ioc, _ = iocs_create(request.get_json(), case_identifier)
  77. return response_api_created(ioc_schema.dump(ioc))
  78. except BusinessProcessingError as e:
  79. log.error(e)
  80. return response_api_error(e.get_message())
  81. @case_iocs_blueprint.delete('/<int:identifier>')
  82. @ac_api_requires()
  83. def delete_case_ioc(case_identifier, identifier):
  84. try:
  85. ioc = iocs_get(identifier)
  86. if not ac_fast_check_current_user_has_case_access(ioc.case_id, [CaseAccessLevel.full_access]):
  87. return ac_api_return_access_denied(caseid=ioc.case_id)
  88. if ioc.case_id != case_identifier:
  89. raise ObjectNotFoundError()
  90. iocs_delete(ioc)
  91. return response_api_deleted()
  92. except ObjectNotFoundError:
  93. return response_api_not_found()
  94. except BusinessProcessingError as e:
  95. return response_api_error(e.get_message())
  96. @case_iocs_blueprint.get('/<int:identifier>')
  97. @ac_api_requires()
  98. def get_case_ioc(case_identifier, identifier):
  99. ioc_schema = IocSchemaForAPIV2()
  100. try:
  101. ioc = iocs_get(identifier)
  102. if not ac_fast_check_current_user_has_case_access(ioc.case_id, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  103. return ac_api_return_access_denied(caseid=ioc.case_id)
  104. if ioc.case_id != case_identifier:
  105. raise ObjectNotFoundError()
  106. return response_api_success(ioc_schema.dump(ioc))
  107. except ObjectNotFoundError:
  108. return response_api_not_found()
  109. @case_iocs_blueprint.put('/<int:identifier>')
  110. @ac_api_requires()
  111. def update_ioc(case_identifier, identifier):
  112. ioc_schema = IocSchemaForAPIV2()
  113. try:
  114. ioc = iocs_get(identifier)
  115. if not ac_fast_check_current_user_has_case_access(ioc.case_id,
  116. [CaseAccessLevel.full_access]):
  117. return ac_api_return_access_denied(caseid=ioc.case_id)
  118. ioc, _ = iocs_update(ioc, request.get_json())
  119. return response_api_success(ioc_schema.dump(ioc))
  120. except ObjectNotFoundError:
  121. return response_api_not_found()
  122. except BusinessProcessingError as e:
  123. return response_api_error(e.get_message(), data=e.get_data())