|
@@ -17,14 +17,11 @@ from pycs.util.RecursiveDictionary import set_recursive
|
|
|
|
|
|
|
|
|
class WebServer:
|
|
|
- def __init__(self, app_status: ApplicationStatus, pipeline_manager: PipelineManager):
|
|
|
+ def __init__(self, app_status: ApplicationStatus):
|
|
|
# initialize web server
|
|
|
if exists('webui/index.html'):
|
|
|
print('production build')
|
|
|
|
|
|
- # TODO update file upload
|
|
|
- # files = FileProvider(app_status)
|
|
|
-
|
|
|
# find svg icons and add them as separate static files to
|
|
|
# set their correct mime type / content_type
|
|
|
static_files = {'/': 'webui/'}
|
|
@@ -42,9 +39,6 @@ class WebServer:
|
|
|
else:
|
|
|
print('development build')
|
|
|
|
|
|
- # TODO update file upload
|
|
|
- # files = FileProvider(app_status, cors=True)
|
|
|
-
|
|
|
self.__sio = socketio.Server(cors_allowed_origins='*')
|
|
|
self.__flask = Flask(__name__)
|
|
|
self.__app = socketio.WSGIApp(self.__sio, self.__flask)
|
|
@@ -60,7 +54,6 @@ class WebServer:
|
|
|
# define events
|
|
|
@self.__sio.event
|
|
|
def connect(id, msg):
|
|
|
- print('connect')
|
|
|
self.__sio.emit('app_status', self.__status, to=id)
|
|
|
|
|
|
@self.__flask.route('/settings', methods=['POST'])
|
|
@@ -68,56 +61,40 @@ class WebServer:
|
|
|
data = request.get_json(force=True)
|
|
|
set_recursive(data, app_status['settings'])
|
|
|
|
|
|
- response = make_response()
|
|
|
- response.headers['Access-Control-Allow-Origin'] = '*'
|
|
|
- return response
|
|
|
+ return response()
|
|
|
|
|
|
@self.__flask.route('/projects', methods=['POST'])
|
|
|
def create_project():
|
|
|
data = request.get_json(force=True)
|
|
|
+ app_status['projects'].create_project(data['name'], data['description'], data['model'])
|
|
|
|
|
|
- # TODO move to project manager
|
|
|
- app_status['projects'].append({
|
|
|
- 'status': 'create',
|
|
|
- 'name': data['name'],
|
|
|
- 'description': data['description'],
|
|
|
- 'model': data['model']
|
|
|
- })
|
|
|
-
|
|
|
- response = make_response()
|
|
|
- response.headers['Access-Control-Allow-Origin'] = '*'
|
|
|
- return response
|
|
|
+ return response()
|
|
|
|
|
|
@self.__flask.route('/projects/<identifier>', methods=['POST'])
|
|
|
def edit_project(identifier):
|
|
|
data = request.get_json(force=True)
|
|
|
|
|
|
- # TODO move to project manager
|
|
|
- for project in app_status['projects']:
|
|
|
- if project['id'] == identifier:
|
|
|
- # delete
|
|
|
- if 'delete' in data.keys():
|
|
|
- project['action'] = 'delete'
|
|
|
- # update
|
|
|
- else:
|
|
|
- set_recursive(data, project)
|
|
|
- project['action'] = 'update'
|
|
|
+ if 'delete' in data.keys():
|
|
|
+ app_status['projects'].delete_project(identifier)
|
|
|
+ elif 'predict' in data.keys():
|
|
|
+ app_status['projects'].predict(identifier, data['predict'])
|
|
|
+ else:
|
|
|
+ app_status['projects'].update_project(identifier, data)
|
|
|
|
|
|
return response()
|
|
|
|
|
|
@self.__flask.route('/projects/<identifier>/data', methods=['POST'])
|
|
|
def upload_file(identifier):
|
|
|
- # TODO move to project manager
|
|
|
- file_uuid = str(uuid1())
|
|
|
+ # abort if project id is not valid
|
|
|
+ if identifier not in app_status['projects'].keys():
|
|
|
+ # TODO return 404
|
|
|
+ return make_response('project does not exist', 500)
|
|
|
|
|
|
- # get current project path
|
|
|
- opened_projects = list(filter(lambda x: x['id'] == identifier, app_status['projects']))
|
|
|
- if len(opened_projects) == 0:
|
|
|
- return make_response('no open project available', 500)
|
|
|
-
|
|
|
- current_project = opened_projects[0]
|
|
|
- upload_path = path.join('projects', current_project['id'], 'data')
|
|
|
+ # get project and upload path
|
|
|
+ project = app_status['projects'][identifier]
|
|
|
+ upload_path, file_uuid = project.new_media_file_path()
|
|
|
|
|
|
+ # prepare wrapper objects
|
|
|
job = GenericWrapper()
|
|
|
file_name = GenericWrapper()
|
|
|
file_extension = GenericWrapper()
|
|
@@ -167,10 +144,7 @@ class WebServer:
|
|
|
job['finished'] = int(time())
|
|
|
|
|
|
# add to project files
|
|
|
- if 'data' not in current_project:
|
|
|
- current_project['data'] = []
|
|
|
-
|
|
|
- current_project['data'].append({
|
|
|
+ project.add_media_file({
|
|
|
'id': file_uuid,
|
|
|
'name': file_name.value,
|
|
|
'extension': file_extension.value,
|
|
@@ -183,32 +157,25 @@ class WebServer:
|
|
|
|
|
|
@self.__flask.route('/projects/<project_identifier>/data/<file_identifier>', methods=['GET'])
|
|
|
def get_file(project_identifier, file_identifier):
|
|
|
- # get current project
|
|
|
- opened_projects = list(filter(lambda x: x['id'] == project_identifier, app_status['projects']))
|
|
|
- if len(opened_projects) == 0:
|
|
|
- return make_response('no open project available', 500)
|
|
|
+ # abort if project id is not valid
|
|
|
+ if project_identifier not in app_status['projects'].keys():
|
|
|
+ return make_response('project does not exist', 500)
|
|
|
|
|
|
- current_project = opened_projects[0]
|
|
|
- file_directory = path.join(getcwd(), 'projects', current_project['id'], 'data')
|
|
|
+ project = app_status['projects'][project_identifier]
|
|
|
|
|
|
- print(current_project)
|
|
|
+ # abort if file id is not valid
|
|
|
+ if file_identifier not in project['data'].keys():
|
|
|
+ return make_response('file does not exist', 500)
|
|
|
|
|
|
- # get object
|
|
|
- data_objects = list(filter(lambda x: x['id'] == file_identifier, current_project['data']))
|
|
|
- if len(data_objects) == 0:
|
|
|
- return make_response('data object not avilable', 500)
|
|
|
+ target_object = project['data'][file_identifier]
|
|
|
|
|
|
- target_object = data_objects[0]
|
|
|
+ # construct directory and filename
|
|
|
+ file_directory = path.join(getcwd(), 'projects', project['id'], 'data')
|
|
|
+ file_name = target_object['id'] + target_object['extension']
|
|
|
|
|
|
# return data
|
|
|
- file_name = target_object['id'] + target_object['extension']
|
|
|
return send_from_directory(file_directory, file_name)
|
|
|
|
|
|
- @self.__flask.route('/projects/<project_identifier>/data/<file_identifier>', methods=['POST'])
|
|
|
- def run_prediction(project_identifier, file_identifier):
|
|
|
- pipeline_manager.run(project_identifier, file_identifier)
|
|
|
- return response()
|
|
|
-
|
|
|
# finally start web server
|
|
|
host = app_status['settings']['frontend']['host']
|
|
|
port = app_status['settings']['frontend']['port']
|