本文整理匯總了Python中flask_socketio.disconnect方法的典型用法代碼示例。如果您正苦於以下問題:Python flask_socketio.disconnect方法的具體用法?Python flask_socketio.disconnect怎麽用?Python flask_socketio.disconnect使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類flask_socketio
的用法示例。
在下文中一共展示了flask_socketio.disconnect方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: create_app
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def create_app(redis_url):
socketio = SocketIO(logger=True)
app = Flask(__name__)
app.config.from_object(config)
@app.route("/")
def index():
return jsonify({"name": "%s Event stream" % config.APP_NAME})
@socketio.on("connect", namespace="/events")
def connected():
try:
verify_jwt_in_request()
app.logger.info("New websocket client connected")
except Exception:
app.logger.info("New websocket client failed to connect")
disconnect()
return False
@socketio.on("disconnect", namespace="/events")
def disconnected():
app.logger.info("Websocket client disconnected")
@socketio.on_error("/events")
def on_error(error):
app.logger.error(error)
socketio.init_app(app, message_queue=redis_url, async_mode="gevent")
return (app, socketio)
示例2: diagnostic
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def diagnostic():
"""
Get services journal and status
"""
getServicesStatus()
logs = []
for service in services_list:
sysctl_status = subprocess.run(['systemctl', 'status', service['service_unit']],
stdout=subprocess.PIPE,
universal_newlines=True)
journalctl = subprocess.run(['journalctl', '--since', '7 days ago', '-u', service['service_unit']],
stdout=subprocess.PIPE,
universal_newlines=True)
#Replace carrier return to <br> for html view
sysctl_status = sysctl_status.stdout.replace('\n', '<br>')
journalctl = journalctl.stdout.replace('\n', '<br>')
active_state = "Active" if service['active'] == True else "Inactive"
logs.append({'name' : service['service_unit'], 'active' : active_state, 'sysctl_status' : sysctl_status, 'journalctl' : journalctl})
return render_template('diagnostic.html', logs = logs)
#### Handle connect/disconnect events ####
示例3: disconnect_by_sid
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def disconnect_by_sid(sid: str) -> None:
if sid is None:
raise ValueError('need sid to disconnect client')
environ.env._force_disconnect_by_sid(sid, '/ws')
示例4: on_login
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def on_login(data: dict, activity: Activity) -> (int, str):
try:
status_code, msg = api.on_login(data, activity)
if status_code != 200:
disconnect()
return status_code, msg
except Exception as e:
logger.error('could not login, will disconnect client: %s' % str(e))
logger.exception(traceback.format_exc())
environ.env.capture_exception(sys.exc_info())
return 500, str(e)
示例5: on_leave
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def on_leave(data: dict, activity: Activity) -> (int, Union[str, dict, None]):
return api.on_leave(data, activity)
# no pre-processing for disconnect event
示例6: handle_client_disconnect
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def handle_client_disconnect(msg):
disconnect()
# Affectiva Client ready to receive photos (base64_images)
示例7: handle_next_frame_request
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def handle_next_frame_request(json):
global current_frame
# print("Previous frame data: {0}".format(str(json)))
if json['data']:
# anger, contempt, disgust, engagement, fear, joy, sadness, surprise, valence
emotions = json['data'][0]['emotions']
expressions = json['data'][0]['expressions']
eye_closure = expressions['eyeClosure']
emotion_data.append(emotions)
eye_closure_data.append(eye_closure)
else:
# No data was obtained
emotion_data.append(None)
eye_closure_data.append(None)
if current_frame[0] < len(base64_frames):
emit('next_frame', [current_frame[0], base64_frames[current_frame[0]]])
current_frame[0] += 1
else:
emit('no_more_frames', 'Completed')
# disconnect()
# Parse Data and Save Data to Disk
blink_data = detect_blinks(eye_closure_data, video_fps_rate[0])
microexpression_data = microexpression_analyzer(emotion_data, video_fps_rate[0])
json_path = os.path.join(basedir, 'static', 'data', 'tmp_json')
with shelve.open(os.path.join(json_path, 'facial_data.shlf')) as shelf:
shelf['emotion_data'] = emotion_data
shelf['micro_expression_data'] = microexpression_data
shelf['blink_data'] = blink_data
# Notify client that facial data write is complete
emit('data_complete', 'Facial_Complete')
示例8: terminate_interview_connection
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def terminate_interview_connection():
sys.stderr.write("terminate_interview_connection\n")
# hopefully the disconnect will be triggered
# if request.sid in threads:
# rr.publish(request.sid, json.dumps(dict(origin='client', message='KILL', sid=request.sid)))
socketio.emit('terminate', {}, namespace='/wsinterview', room=request.sid)
#disconnect()
示例9: on_interview_manual_disconnect
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def on_interview_manual_disconnect(data):
sys.stderr.write("Client manual disconnect\n")
yaml_filename = data['i']
session_info = get_session(yaml_filename)
session_id = session_info['uid']
the_user_id = session.get('user_id', 't' + str(session.get('tempuser', None)))
if request.sid in secrets:
del secrets[request.sid]
if session_id is not None:
rr.delete('da:interviewsession:uid:' + str(session_id) + ':i:' + str(yaml_filename) + ':userid:' + str(the_user_id))
key = 'da:session:uid:' + str(session_id) + ':i:' + str(yaml_filename) + ':userid:' + str(the_user_id)
rr.expire(key, 10)
rr.publish(request.sid, json.dumps(dict(origin='client', message='KILL', sid=request.sid)))
示例10: terminate_monitor_connection
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def terminate_monitor_connection():
sys.stderr.write("terminate_monitor_connection\n")
# hopefully the disconnect will be triggered
# if request.sid in threads:
# rr.publish(request.sid, json.dumps(dict(origin='client', message='KILL', sid=request.sid)))
socketio.emit('terminate', {}, namespace='/monitor', room=request.sid)
#disconnect()
示例11: terminate_observer_connection
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def terminate_observer_connection():
sys.stderr.write("terminate_observer_connection\n")
# hopefully the disconnect will be triggered
# if request.sid in threads:
# rr.publish(request.sid, json.dumps(dict(origin='client', message='KILL', sid=request.sid)))
socketio.emit('terminate', {}, namespace='/observer', room=request.sid)
#disconnect()
示例12: default_socketio_error_handler
# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import disconnect [as 別名]
def default_socketio_error_handler(e):
disconnect()