##// END OF EJS Templates
New version with cards and status alerts
New version with cards and status alerts

File last commit:

r11:2395d68d2d5f
r11:2395d68d2d5f
Show More
consumers.py
56 lines | 2.2 KiB | text/x-python | PythonLexer
Developer
New version with cards and status alerts
r11 #!/usr/bin/python
# -*- coding: UTF-8 -*-
Juan C. Espinoza
Docker working
r1 import os
First version RTI, Spectra, Noise + Docker
r0 import json
Reorganize models, smaller docker, others
r2
First version RTI, Spectra, Noise + Docker
r0 from datetime import datetime
Juan C. Espinoza
Docker working
r1
First version RTI, Spectra, Noise + Docker
r0 from pymongo import MongoClient
from channels.handler import AsgiHandler
from channels.auth import channel_session_user
from channels import Group
Developer
New version with cards and status alerts
r11 # Here we create the db named "dbplots"
Juan C. Espinoza
Docker working
r1 host = os.environ.get('HOST_MONGO', 'localhost')
CLIENT = MongoClient('{}:27017'.format(host))
First version RTI, Spectra, Noise + Docker
r0 DB = CLIENT['dbplots']
# Connected to websocket.connect
Developer
New version with cards and status alerts
r11 def ws_connect(message, code=None, plot=None):
First version RTI, Spectra, Noise + Docker
r0 message.reply_channel.send({'accept': True})
Developer
New version with cards and status alerts
r11 if plot == 'main':
Group('main').add(message.reply_channel)
print('New main connection')
else:
pk = message.content['query_string'].decode().split('=')[1]
Group('{}_{}'.format(pk, plot)).add(message.reply_channel)
print('New connection from: {}, Group: {}_{}'.format(message.content['client'][0], pk, plot))
First version RTI, Spectra, Noise + Docker
r0
def ws_message(message, code, plot):
# Accept the incoming connection
dt = datetime.strptime(str(json.loads(message.content['text'])['date']), '%d/%m/%Y')
Reorganize models, smaller docker, others
r2 exp = DB.exp_meta.find_one({'code': int(code), 'date': dt})
Fix server for noise data, correct codes
r3
if exp and plot in exp['plots']:
First version RTI, Spectra, Noise + Docker
r0 if plot == 'spc':
Reorganize models, smaller docker, others
r2 datas = DB.exp_data.find({'expmeta': exp['_id']}, ['time', 'data']).sort('time', -1).limit(1)[0]
exp['time'] = [datas['time']]
exp['spc'] = datas['data']['spc']
exp['rti'] = datas['data']['rti']
exp['noise'] = datas['data']['noise']
First version RTI, Spectra, Noise + Docker
r0 else:
Reorganize models, smaller docker, others
r2 datas = DB.exp_data.find({'expmeta': exp['_id']}, ['time', 'data']).sort('time', 1)
First version RTI, Spectra, Noise + Docker
r0 dum = [(d['time'], d['data'][plot]) for d in datas]
Reorganize models, smaller docker, others
r2 exp['time'] = [d[0] for d in dum]
Juan C. Espinoza
Docker working
r1 dum = [d[1] for d in dum]
Developer
New version with cards and status alerts
r11 exp[plot] = [t for t in map(list, zip(*dum))]
print([datetime.fromtimestamp(t) for t in exp['time']])
Reorganize models, smaller docker, others
r2 exp.pop('date', None)
exp.pop('_id', None)
message.reply_channel.send({'text': json.dumps(exp)})
First version RTI, Spectra, Noise + Docker
r0 else:
message.reply_channel.send({'text': json.dumps({'interval': 0})})
# Connected to websocket.disconnect
def ws_disconnect(message, code, plot):
Group('{}_{}'.format(code, plot)).discard(message.reply_channel)