# IRIS Source Code # Copyright (C) 2024 - DFIR-IRIS # contact@dfir-iris.org # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 3 of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with this program; if not, write to the Free Software Foundation, # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. from flask import Blueprint from app.blueprints.access_controls import ac_api_requires from app.blueprints.rest.endpoints import response_api_deleted from app.blueprints.rest.endpoints import response_api_error from app.blueprints.rest.endpoints import response_api_success from app.blueprints.rest.endpoints import response_api_not_found from app.business.assets import assets_delete from app.business.assets import assets_get from app.business.errors import BusinessProcessingError from app.business.errors import ObjectNotFoundError from app.iris_engine.access_control.utils import ac_fast_check_current_user_has_case_access from app.models.authorization import CaseAccessLevel from app.schema.marshables import CaseAssetsSchema from app.blueprints.access_controls import ac_api_return_access_denied assets_blueprint = Blueprint('assets_api_v2', __name__, url_prefix='/assets') @assets_blueprint.get('/') @ac_api_requires() def get_asset(identifier): asset_schema = CaseAssetsSchema() try: asset = assets_get(identifier) # perform authz check if not ac_fast_check_current_user_has_case_access(asset.case_id, [CaseAccessLevel.read_only, CaseAccessLevel.full_access]): return ac_api_return_access_denied(caseid=asset.case_id) return response_api_success(asset_schema.dump(asset)) except ObjectNotFoundError: return response_api_not_found() except BusinessProcessingError as e: return response_api_error(e.get_message()) @assets_blueprint.delete('/') @ac_api_requires() def delete_asset(identifier): try: asset = assets_get(identifier) # perform authz check if not ac_fast_check_current_user_has_case_access(asset.case_id, [CaseAccessLevel.full_access]): return ac_api_return_access_denied(caseid=asset.case_id) assets_delete(asset) return response_api_deleted() except ObjectNotFoundError: return response_api_not_found() except BusinessProcessingError as e: return response_api_error(e.get_message())