-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathzuki.py
executable file
·111 lines (94 loc) · 4.49 KB
/
zuki.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
from flask import Flask, render_template, request,json, jsonify
from flask_sqlalchemy import SQLAlchemy
from flask_user import login_required, UserManager, UserMixin, SQLAlchemyAdapter
import string, random, datetime, time
from models import *
from security import *
## string of 64 random ascii chars
app_salt = 'ms7kmVj9svyy5dERCdcJ57zKFpgE29YGoUHiQMR3eEIuhB493XhYiPcjRLxbcCls'
@app.route('/')
def index():
records = db.session.query(Devices.name, Instances.id, Devices.desc, Devices.ipaddress, db.func.count(Instances.device).label("num")).outerjoin(Instances).group_by(Devices.id).filter(Devices.display==1)
instances = Instances.query.all()
context = { 'menu': 'home', 'records' : records, 'instances': instances}
return render_template('index.html', context = context)
@app.route('/getinstance/<id>', methods=['GET','POST'])
def getinstancechart(id):
print("getting ID " + str(id))
current_value = db.session.query(Devicedata.id, Instances.itype, Devicedata.id, Devicedata.timestamp, Devicedata.data, Devicedata.device).outerjoin(Instances).filter(Devicedata.device==str(id)).order_by(Devicedata.timestamp.desc()).limit(30).all()
if not current_value:
return '{"current":"no data","type": "", "values": "", "timestamps": ""}'
current = current_value[0].data
devtype = current_value[0].itype
values = ",".join( [ x.data for x in current_value ])
timestamps = ",".join( [ time.strftime('%H:%M:%S', time.localtime(x.timestamp)) for x in current_value ])
return '{"current":"'+str(current)+'","type": "'+str(devtype)+'", "values": "'+values+'", "timestamps": "'+timestamps+'"}'
pass
@app.route('/logout')
def logout():
pass
@app.route('/adddevice')
def adddevice():
context = { 'menu': 'adddevice'}
return render_template('adddevice.html', context=context)
@app.route("/processdevice", methods=["POST"])
def processd():
name = request.form['name']
desc = request.form['desc']
devtype = request.form['devtype']
ipaddress = request.form['ipaddress']
hashk=hashkey(20)
display = 1
device = Devices(name=name, desc=desc, devtype=devtype, ipaddress=ipaddress, hashkey=hashk, display=display)
db.session.add(device)
db.session.commit()
records = db.session.query(Devices.name, Devices.desc, Devices.ipaddress, db.func.count(Instances.device).label("num")).outerjoin(Instances).group_by(Devices.id).filter(Devices.display==1)
context = { 'menu': 'home', 'records' : records}
return render_template('index.html', context = context)
@app.route("/processinstance", methods=["POST"])
def processi():
name = request.form['name']
desc = request.form['desc']
itype = request.form['itype']
device = request.form['device']
direction = request.form['direction']
url = request.form['url']
instance = Instances(name=name, desc=desc, itype=itype, device=device, direction=direction, url=url)
db.session.add(instance)
db.session.commit()
records = db.session.query(Devices.name, Devices.desc, Devices.ipaddress, db.func.count(Instances.device).label("num")).outerjoin(Instances).group_by(Devices.id).filter(Devices.display==1)
context = { 'menu': 'home', 'records' : records}
return render_template('index.html', context = context)
@app.route("/adddata", methods=['POST', 'GET'])
def addd():
if request.form.get('data',None):
print(request.form.get('data'))
device = request.form['device']
hashkey = request.form['hashkey']
datai = request.form['datai']
data = request.form['data']
timestamp = int(time.time())
dev = db.session.query(Devices).filter(Devices.hashkey == hashkey, Devices.id == device).first()
if dev is None:
return "auth error"
dev = db.session.query(Instances).filter(Instances.id == datai).first()
if dev is None:
return "instance error"
devicedata = Devicedata(device=datai, data=data, timestamp=timestamp)
db.session.add(devicedata)
db.session.commit()
else:
return "No data"
return 'ok'
@app.route("/viewdata")
def viewdata():
records = Devicedata.query.all()
context = { 'menu': 'home', 'records' : records}
return render_template('viewdata.html', context = context)
@app.route('/addinstance')
def addinstance():
records = Devices.query.all()
context = { 'menu': 'addinstance', 'records' : records}
return render_template('addinstance.html', context = context)
if __name__ == '__main__':
app.run(debug=True, host='0.0.0.0')