2019-11-06 13:45:08 +00:00
|
|
|
from app import db, socketio
|
2019-11-06 13:35:33 +00:00
|
|
|
from app.events import connected_sessions
|
2019-11-06 13:45:08 +00:00
|
|
|
from app.models import Corpus
|
2019-11-06 13:35:33 +00:00
|
|
|
from flask import current_app, request
|
|
|
|
from flask_login import login_required
|
2019-11-07 14:51:01 +00:00
|
|
|
from .CQiWrapper.CQiWrapper import CQiWrapper
|
2019-11-06 13:35:33 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
|
2019-11-11 13:20:44 +00:00
|
|
|
'''
|
|
|
|
' A dictionary containing lists of with corpus ids associated Socket.IO session
|
|
|
|
' ids (sid). {<corpus_id>: [<sid>, ...], ...}
|
|
|
|
'''
|
2019-11-11 10:51:18 +00:00
|
|
|
analysis_sessions = {}
|
2019-11-11 13:20:44 +00:00
|
|
|
'''
|
|
|
|
' A dictionary containing Socket.IO session id - CQi client pairs.
|
|
|
|
' {<sid>: CQi client, ...}
|
|
|
|
'''
|
2019-11-07 13:33:58 +00:00
|
|
|
analysis_clients = {}
|
2019-11-06 13:35:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
@socketio.on('init_corpus_analysis')
|
|
|
|
@login_required
|
|
|
|
def init_corpus_analysis(corpus_id):
|
|
|
|
''' TODO: Check if current_user is allowed to subscribe to this '''
|
2019-11-11 10:51:18 +00:00
|
|
|
if str(corpus_id) not in analysis_sessions:
|
|
|
|
analysis_sessions[str(corpus_id)] = [request.sid]
|
2019-11-06 13:45:08 +00:00
|
|
|
socketio.start_background_task(observe_corpus_analysis_connection,
|
2019-11-06 13:35:33 +00:00
|
|
|
current_app._get_current_object(),
|
2019-11-11 10:51:18 +00:00
|
|
|
corpus_id, request.sid)
|
2019-11-06 13:35:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
@socketio.on('query_event')
|
|
|
|
def recv_query(message):
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
logger.warning(message)
|
2019-11-11 13:20:44 +00:00
|
|
|
analysis_client = analysis_clients[request.sid]
|
|
|
|
corpus_name = 'CORPUS'
|
|
|
|
result_subcorpus_name = 'Query-results' # should be set by the user somehow
|
|
|
|
query = message['query']
|
2019-11-11 14:35:37 +00:00
|
|
|
analysis_client.set_corpus_name(corpus_name)
|
|
|
|
analysis_client.create_attribute_strings()
|
|
|
|
analysis_client.query_subcorpus(result_subcorpus_name, query)
|
|
|
|
results = analysis_client.show_results()
|
|
|
|
logger.warning('Query results: {}'.format(str(results)))
|
2019-11-06 13:35:33 +00:00
|
|
|
|
|
|
|
|
2019-11-06 13:45:08 +00:00
|
|
|
def observe_corpus_analysis_connection(app, corpus_id, session_id):
|
2019-11-06 13:35:33 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
with app.app_context():
|
2019-11-07 09:55:23 +00:00
|
|
|
corpus = Corpus.query.filter_by(id=corpus_id).first()
|
2019-11-07 14:28:07 +00:00
|
|
|
while corpus.status != 'analysing':
|
|
|
|
db.session.refresh(corpus)
|
|
|
|
socketio.sleep(3)
|
2019-11-11 10:51:18 +00:00
|
|
|
analysis_client = CQiWrapper(host='{}_analysis_container{}'.format(corpus.creator.username, corpus.id),
|
|
|
|
password='opaque', port=4877,
|
|
|
|
username='opaque')
|
2019-11-07 14:58:24 +00:00
|
|
|
analysis_client.connect()
|
2019-11-11 13:20:44 +00:00
|
|
|
analysis_clients[session_id] = analysis_client
|
2019-11-11 14:57:55 +00:00
|
|
|
socketio.emit('init_corpus_analysis', 'Ready', room=session_id)
|
2019-11-06 13:35:33 +00:00
|
|
|
while session_id in connected_sessions:
|
2019-11-11 13:20:44 +00:00
|
|
|
try:
|
|
|
|
analysis_client.ctrl_ping()
|
|
|
|
except Exception as err:
|
|
|
|
logger.warning('[Exception]: {}'.format(err))
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
socketio.sleep(3)
|
|
|
|
analysis_client.disconnect()
|
2019-11-07 14:28:07 +00:00
|
|
|
analysis_clients.pop(session_id, None)
|
2019-11-11 10:51:18 +00:00
|
|
|
analysis_sessions[str(corpus_id)].remove(session_id)
|
|
|
|
if not analysis_sessions[str(corpus_id)]:
|
|
|
|
analysis_sessions.pop(str(corpus_id), None)
|
|
|
|
corpus.status = 'stop analysis'
|
2019-11-06 13:45:08 +00:00
|
|
|
db.session.commit()
|