influx_stats/influx_frontend.py

193 lines
5.7 KiB
Python
Raw Normal View History

2017-01-28 07:09:09 +00:00
from flask import Flask, request, render_template, redirect, url_for
2017-01-29 05:37:38 +00:00
from time import strftime
2022-06-28 11:42:26 +00:00
import pendulum
from dotenv import dotenv_values
import influxdb_client
from influxdb_client.client.write_api import SYNCHRONOUS
from operator import itemgetter
2022-06-28 11:42:26 +00:00
config = dotenv_values(".env")
2016-12-20 06:50:26 +00:00
2016-12-06 12:46:40 +00:00
app = Flask(__name__)
client = influxdb_client.InfluxDBClient(
2022-08-12 06:26:11 +00:00
url=config['DB_URL'],
token=config['DB_TOKEN'],
org=config['DB_ORG']
)
2016-12-06 12:46:40 +00:00
2016-12-20 06:50:26 +00:00
@app.route('/success')
def success():
return "Form success!"
2023-10-18 11:56:29 +00:00
def fetch_timeseries_data(timestamp=None):
query_api = client.query_api()
if timestamp is not None:
newTime = pendulum.parse(timestamp)
print(newTime.to_atom_string())
# "2023-11-14T08:21:00.000Z"
query = 'from(bucket: "gas")\
|> range(start: time(v: "' + str(newTime.subtract(seconds=1).to_atom_string()) + '"), stop: time(v: "' + str(newTime.add(seconds=1).to_atom_string()) + '"))\
|> filter(fn: (r) => r["_measurement"] == "2016_odyssey")\
|> filter(fn: (r) => r["_field"] == "odometer")\
|> sort(columns: ["_value"], desc: false)\
|> yield(name: "last")\
|> limit(n:10)'
print("searching for fixed time")
else:
query = 'from(bucket: "gas")\
|> range(start: -90d)\
|> filter(fn: (r) => r["_measurement"] == "2016_odyssey")\
|> filter(fn: (r) => r["_field"] == "odometer")\
|> sort(columns: ["_value"], desc: false)\
|> yield(name: "last")\
|> limit(n:10)'
result = query_api.query(org=config['DB_ORG'], query=query)
results = []
for table in result:
for record in table.records:
temp = {}
temp[record.get_field()] = record.get_value()
temp['time'] = record.get_time()
try:
temp['oilhealth'] = record['oilhealth']
except KeyError:
pass
2022-08-12 06:26:11 +00:00
try:
temp['fuel'] = record['fuel']
temp['fuelcost'] = record['fuelcost']
except KeyError:
pass
try:
temp['winter'] = record['winter']
except KeyError:
2022-08-12 06:26:11 +00:00
pass
results.append(temp)
# .append((record.get_time(), record.get_field(), record.get_value()))
newlist = sorted(results, key=itemgetter('time'), reverse=True)
2022-08-12 06:26:11 +00:00
oldlist = newlist # temporary to strip the non-unique data
newlist = []
for value in oldlist:
if value in newlist:
continue
else:
newlist.append(value)
print(newlist)
print()
2023-10-18 11:56:29 +00:00
return newlist
2022-08-12 06:26:11 +00:00
2023-10-18 11:56:29 +00:00
@app.route('/', methods=['GET', 'POST'])
def main_page():
# Call fetch function
2023-10-18 11:56:29 +00:00
newlist = fetch_timeseries_data()
2022-08-12 06:26:11 +00:00
# print(newlist)
return render_template('index.html', data=newlist[:10])
2017-01-28 07:09:09 +00:00
@app.route('/add_time', methods=['POST', 'GET'])
def add_time():
2017-01-29 05:37:38 +00:00
today = strftime("%Y-%m-%d")
now = strftime("%H:%M:%S")
# database = request.form['db']
# table = request.form['table']
date = request.form['date']
2017-01-29 05:37:38 +00:00
if date == '':
date = today
time = request.form['time']
2017-01-29 05:37:38 +00:00
if time == '':
time = now
odometer = request.form['odometer']
2022-08-12 06:26:11 +00:00
oilhealth = request.form['oilhealth']
if oilhealth != '':
oilhealth = float(oilhealth)
fuel = request.form['fuel']
if fuel != '':
fuel = float(fuel)
fuelcost = request.form['fuelcost']
if fuelcost != '':
fuelcost = float(fuelcost)
winter = request.form['winter']
2017-04-09 22:36:01 +00:00
if winter == 'TRUE':
winter = 1
2017-04-09 22:36:01 +00:00
else:
winter = 0
json_body = [
2022-08-12 06:26:11 +00:00
{
"time": date + "T" + time + "Z",
"measurement": "odyssey",
"fields": {
"odometer": float(odometer),
"oilhealth": oilhealth,
"fuel": fuel,
"fuelcost": fuelcost,
"winter": winter
}
2022-08-12 06:26:11 +00:00
}
]
2022-08-12 06:26:11 +00:00
2022-06-28 11:42:26 +00:00
timestamp = date + "T" + time + "Z"
dt = pendulum.parse(timestamp)
print()
print(dt)
print()
write_api = client.write_api(write_options=SYNCHRONOUS)
2022-08-12 06:05:13 +00:00
point = influxdb_client.Point("2016_odyssey").time(timestamp).tag("oilhealth", oilhealth)\
2022-07-03 05:20:43 +00:00
.tag("fuel", fuel).tag("fuelcost", fuelcost).tag("winter", winter).field("odometer", float(odometer))
2022-08-12 06:05:13 +00:00
write_api.write(bucket="gas", org=config['DB_ORG'], record=point)
2022-08-12 06:26:11 +00:00
print("Submitting data to DB: {0}".format(json_body))
# client.write_points(json_body)
2022-07-15 05:05:23 +00:00
return redirect(url_for('main_page'))
2023-10-18 11:56:29 +00:00
@app.route('/edit/<timestamp>')
def edit_odometer_entry(timestamp):
'''Retrieve the time entry from influxdb'''
print('Fetching data!')
# Call fetch function
2023-10-18 11:56:29 +00:00
newlist = fetch_timeseries_data()
2023-10-18 11:56:29 +00:00
# Fill entry_data with timestamp based data
entry_data = fetch_timeseries_data(timestamp)
return render_template('index.html', page_title="Edit Entry", timestamp_data=entry_data, data=newlist[:10])
2022-08-12 06:26:11 +00:00
@app.route('/repeat_last_odometer/<odometer>/<winter>')
def repeat_last_odometer(odometer, winter=False):
2022-08-12 06:05:13 +00:00
'''Retrieve the passed in odometer value and submit as a new entry'''
2022-07-15 05:05:23 +00:00
date = strftime("%Y-%m-%d")
time = strftime("%H:%M:%S")
timestamp = date + "T" + time + "Z"
2022-08-12 06:05:13 +00:00
print("Putting %s to database for %s" % (odometer, timestamp))
2022-07-15 05:05:23 +00:00
write_api = client.write_api(write_options=SYNCHRONOUS)
2022-08-12 06:26:11 +00:00
point = influxdb_client.Point("2016_odyssey").time(
timestamp).tag("winter", winter).field("odometer", float(odometer))
2022-08-12 06:05:13 +00:00
write_api.write(bucket="gas", org=config['DB_ORG'], record=point)
2017-01-28 07:09:09 +00:00
return redirect(url_for('main_page'))
2022-08-12 06:26:11 +00:00
@app.route('/admin')
def admin_index():
return 'admin'
2022-08-12 06:26:11 +00:00
@app.route('/login')
def login():
pass
2022-08-12 06:26:11 +00:00
@app.route('/logout')
def logout():
pass
2022-08-12 06:26:11 +00:00
if __name__ == '__main__':
app.run(debug=True, host='0.0.0.0', port='9001')