Source code for csle_rest_api.resources.simulations.routes

"""
Routes and sub-resources for the /simulations resource
"""
import base64
from typing import Tuple
from flask import Blueprint, Response, jsonify, request
import json
import csle_common.constants.constants as constants
from csle_common.controllers.simulation_env_controller import SimulationEnvController
from csle_common.metastore.metastore_facade import MetastoreFacade
from csle_common.dao.encoding.np_encoder import NpEncoder
import csle_rest_api.constants.constants as api_constants
import csle_rest_api.util.rest_api_util as rest_api_util

# Creates a blueprint "sub application" of the main REST app
simulations_bp = Blueprint(
    api_constants.MGMT_WEBAPP.SIMULATIONS_RESOURCE, __name__,
    url_prefix=f"{constants.COMMANDS.SLASH_DELIM}{api_constants.MGMT_WEBAPP.SIMULATIONS_RESOURCE}")


[docs]@simulations_bp.route("", methods=[api_constants.MGMT_WEBAPP.HTTP_REST_GET, api_constants.MGMT_WEBAPP.HTTP_REST_DELETE]) def simulations() -> Tuple[Response, int]: """ The /simulations resource :return: Returns a list of simulations, a list of simulation ids, or deletes all simulations """ requires_admin = False if request.method == api_constants.MGMT_WEBAPP.HTTP_REST_DELETE: requires_admin = True authorized = rest_api_util.check_if_user_is_authorized(request=request, requires_admin=requires_admin) if authorized is not None: return authorized # Check if ids query parameter is True, then only return the ids and not the whole list of simulations ids = request.args.get(api_constants.MGMT_WEBAPP.IDS_QUERY_PARAM) if ids is not None and ids: return simulation_ids() all_simulations = MetastoreFacade.list_simulations() all_images = MetastoreFacade.list_simulation_images() simulations_dicts = [] for sim in all_simulations: if request.method == api_constants.MGMT_WEBAPP.HTTP_REST_GET: for sim_name_img in all_images: sim_name, img = sim_name_img if sim_name == sim.name: sim.image = base64.b64encode(img).decode() elif request.method == api_constants.MGMT_WEBAPP.HTTP_REST_DELETE: SimulationEnvController.uninstall_simulation(sim) if request.method == api_constants.MGMT_WEBAPP.HTTP_REST_GET: simulations_dicts = list(map(lambda x: json.loads(json.dumps(x.to_dict(), indent=4, sort_keys=True, cls=NpEncoder)), all_simulations)) elif request.method == api_constants.MGMT_WEBAPP.HTTP_REST_DELETE: simulations_dicts = [] response = jsonify(simulations_dicts) response.headers.add(api_constants.MGMT_WEBAPP.ACCESS_CONTROL_ALLOW_ORIGIN_HEADER, "*") return response, constants.HTTPS.OK_STATUS_CODE
[docs]def simulation_ids() -> Tuple[Response, int]: """ :return: the list of simulation ids as an HTTP response """ simulation_ids = MetastoreFacade.list_simulation_ids() response_dicts = [] for tup in simulation_ids: response_dicts.append({ api_constants.MGMT_WEBAPP.ID_PROPERTY: tup[0], api_constants.MGMT_WEBAPP.SIMULATION_PROPERTY: tup[1] }) response = jsonify(response_dicts) response.headers.add(api_constants.MGMT_WEBAPP.ACCESS_CONTROL_ALLOW_ORIGIN_HEADER, "*") return response, constants.HTTPS.OK_STATUS_CODE
[docs]@simulations_bp.route('/<simulation_id>', methods=[api_constants.MGMT_WEBAPP.HTTP_REST_GET, api_constants.MGMT_WEBAPP.HTTP_REST_DELETE]) def get_simulation(simulation_id: int) -> Tuple[Response, int]: """ The /simulations/id resource. Gets or deletes a simulation with a given id. :param simulation_id: the id of the simulation :return: the simulation or deletes the simulation """ requires_admin = False if request.method == api_constants.MGMT_WEBAPP.HTTP_REST_DELETE: requires_admin = True authorized = rest_api_util.check_if_user_is_authorized(request=request, requires_admin=requires_admin) if authorized is not None: return authorized simulation = MetastoreFacade.get_simulation(simulation_id) sim_name_img = MetastoreFacade.get_simulation_image(simulation_name=simulation.name) sim_name, img = sim_name_img simulation.image = base64.b64encode(img).decode() response = jsonify({}) if simulation is not None: if request.method == api_constants.MGMT_WEBAPP.HTTP_REST_GET: response = jsonify(json.loads(json.dumps(simulation.to_dict(), indent=4, sort_keys=True, cls=NpEncoder))) elif request.method == api_constants.MGMT_WEBAPP.HTTP_REST_DELETE: SimulationEnvController.uninstall_simulation(simulation) response.headers.add(api_constants.MGMT_WEBAPP.ACCESS_CONTROL_ALLOW_ORIGIN_HEADER, "*") return response, constants.HTTPS.OK_STATUS_CODE