Nav apraksta

assets.py 5.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  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.access_controls import ac_api_requires
  21. from app.blueprints.rest.endpoints import response_api_created, response_api_deleted
  22. from app.blueprints.rest.endpoints import response_api_error
  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_not_found
  26. from app.blueprints.rest.parsing import parse_pagination_parameters
  27. from app.business.cases import cases_exists
  28. from app.business.assets import assets_create
  29. from app.business.assets import assets_filter
  30. from app.business.assets import assets_get
  31. from app.business.assets import assets_update
  32. from app.business.assets import assets_delete
  33. from app.business.errors import BusinessProcessingError
  34. from app.business.errors import ObjectNotFoundError
  35. from app.iris_engine.access_control.utils import ac_fast_check_current_user_has_case_access
  36. from app.models.authorization import CaseAccessLevel
  37. from app.schema.marshables import CaseAssetsSchema
  38. from app.blueprints.access_controls import ac_api_return_access_denied
  39. case_assets_blueprint = Blueprint('case_assets',
  40. __name__,
  41. url_prefix='/<int:case_identifier>/assets')
  42. @case_assets_blueprint.get('')
  43. @ac_api_requires()
  44. def case_list_assets(case_identifier):
  45. try:
  46. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.full_access]):
  47. return ac_api_return_access_denied(caseid=case_identifier)
  48. pagination_parameters = parse_pagination_parameters(request)
  49. assets = assets_filter(case_identifier, pagination_parameters)
  50. asset_schema = CaseAssetsSchema()
  51. return response_api_paginated(asset_schema, assets)
  52. except ObjectNotFoundError:
  53. return response_api_not_found()
  54. except BusinessProcessingError as e:
  55. return response_api_error(e.get_message())
  56. @case_assets_blueprint.post('')
  57. @ac_api_requires()
  58. def add_asset(case_identifier):
  59. if not cases_exists(case_identifier):
  60. return response_api_not_found()
  61. if not ac_fast_check_current_user_has_case_access(case_identifier, [CaseAccessLevel.full_access]):
  62. return ac_api_return_access_denied(caseid=case_identifier)
  63. asset_schema = CaseAssetsSchema()
  64. try:
  65. _, asset = assets_create(case_identifier, request.get_json())
  66. return response_api_created(asset_schema.dump(asset))
  67. except BusinessProcessingError as e:
  68. return response_api_error(e.get_message(), e.get_data())
  69. @case_assets_blueprint.get('/<int:identifier>')
  70. @ac_api_requires()
  71. def get_asset(case_identifier, identifier):
  72. asset_schema = CaseAssetsSchema()
  73. try:
  74. asset = assets_get(identifier)
  75. _check_asset_and_case_identifier_match(asset, case_identifier)
  76. # perform authz check
  77. if not ac_fast_check_current_user_has_case_access(asset.case_id, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]):
  78. return ac_api_return_access_denied(caseid=asset.case_id)
  79. return response_api_success(asset_schema.dump(asset))
  80. except ObjectNotFoundError:
  81. return response_api_not_found()
  82. except BusinessProcessingError as e:
  83. return response_api_error(e.get_message())
  84. @case_assets_blueprint.put('/<int:identifier>')
  85. @ac_api_requires()
  86. def update_asset(case_identifier, identifier):
  87. try:
  88. asset = assets_get(identifier)
  89. _check_asset_and_case_identifier_match(asset, case_identifier)
  90. if not ac_fast_check_current_user_has_case_access(asset.case_id,[CaseAccessLevel.full_access]):
  91. return ac_api_return_access_denied(caseid=asset.case_id)
  92. asset = assets_update(asset, request.get_json())
  93. asset_schema = CaseAssetsSchema()
  94. result = asset_schema.dump(asset)
  95. return response_api_success(result)
  96. except ObjectNotFoundError:
  97. return response_api_not_found()
  98. except BusinessProcessingError as e:
  99. return response_api_error(e.get_message(), data=e.get_data())
  100. @case_assets_blueprint.delete('/<int:identifier>')
  101. @ac_api_requires()
  102. def delete_asset(case_identifier, identifier):
  103. try:
  104. asset = assets_get(identifier)
  105. _check_asset_and_case_identifier_match(asset, case_identifier)
  106. # perform authz check
  107. if not ac_fast_check_current_user_has_case_access(asset.case_id, [CaseAccessLevel.full_access]):
  108. return ac_api_return_access_denied(caseid=asset.case_id)
  109. assets_delete(asset)
  110. return response_api_deleted()
  111. except ObjectNotFoundError:
  112. return response_api_not_found()
  113. except BusinessProcessingError as e:
  114. return response_api_error(e.get_message())
  115. def _check_asset_and_case_identifier_match(asset, case_identifier):
  116. if asset.case_id != case_identifier:
  117. raise ObjectNotFoundError