2021-11-29 15:20:54 +00:00
|
|
|
# Copyright (C) 2021 Neythen Treloar neythen@fintic.io
|
2021-04-26 18:51:21 +00:00
|
|
|
#
|
|
|
|
# This file is part of stockTicker project for justinodunn.
|
|
|
|
#
|
|
|
|
# stockTicker can not be copied and/or distributed without the express
|
2021-11-29 15:20:54 +00:00
|
|
|
# permission of Neythen Treloar
|
2021-04-26 18:51:21 +00:00
|
|
|
|
|
|
|
from flask import Flask, render_template, request
|
2021-04-26 19:27:34 +00:00
|
|
|
from stockTicker import StockTicker
|
2021-04-26 18:51:21 +00:00
|
|
|
from werkzeug.utils import secure_filename
|
|
|
|
import os
|
|
|
|
import datetime
|
|
|
|
import threading
|
|
|
|
import csv
|
2021-05-01 10:39:20 +00:00
|
|
|
import pexpect
|
2021-05-05 21:14:04 +00:00
|
|
|
import time
|
2021-05-27 19:10:57 +00:00
|
|
|
import json
|
2021-05-01 10:39:20 +00:00
|
|
|
from multiprocessing import Process
|
2022-01-24 18:40:06 +00:00
|
|
|
import subprocess
|
2021-05-01 10:39:20 +00:00
|
|
|
from subprocess import Popen, PIPE
|
2021-08-11 19:58:01 +00:00
|
|
|
import numpy as np
|
2021-12-10 17:06:47 +00:00
|
|
|
import copy
|
2022-01-24 18:40:06 +00:00
|
|
|
import urllib.request
|
2022-02-28 16:38:24 +00:00
|
|
|
import sys
|
2021-05-01 10:39:20 +00:00
|
|
|
#stock_ticker = StockTicker()
|
2021-10-25 18:42:00 +00:00
|
|
|
#print('API CALLER NOT STARTED')
|
2021-12-22 09:43:36 +00:00
|
|
|
|
2021-12-29 13:05:45 +00:00
|
|
|
#open('log.txt', 'w').close() #wipe logs
|
2021-12-22 09:43:36 +00:00
|
|
|
|
2022-02-28 16:38:24 +00:00
|
|
|
|
2022-01-24 18:40:06 +00:00
|
|
|
#api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 api_caller.py")
|
2022-03-02 05:10:57 +00:00
|
|
|
api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 database_caller.py")
|
2022-02-28 16:38:24 +00:00
|
|
|
time.sleep(3)
|
2022-02-28 16:38:45 +00:00
|
|
|
|
2022-03-01 18:27:45 +00:00
|
|
|
|
2022-02-28 16:38:45 +00:00
|
|
|
api_caller.sendline('A')
|
|
|
|
|
2022-03-01 18:27:45 +00:00
|
|
|
|
|
|
|
#os.system("sudo ./check_update.sh")
|
2022-02-28 16:38:24 +00:00
|
|
|
|
2021-11-17 19:34:13 +00:00
|
|
|
displaying_screensaver = False
|
2021-12-29 13:05:45 +00:00
|
|
|
uploading = False
|
2021-11-17 19:34:13 +00:00
|
|
|
screensaver_p = None
|
2022-02-21 18:54:35 +00:00
|
|
|
ticker_stopped = False
|
2021-11-22 19:19:26 +00:00
|
|
|
professional = json.load(open('csv/display_settings.json', 'r'))[0] == "Professional"
|
2021-04-26 19:27:34 +00:00
|
|
|
|
2021-04-26 18:51:21 +00:00
|
|
|
command = 300
|
|
|
|
tickerList = 0
|
|
|
|
DelayTime = 20
|
|
|
|
LastCommand = ''
|
2021-12-29 13:05:45 +00:00
|
|
|
speedTime = 25 #print('save')
|
2021-04-26 18:51:21 +00:00
|
|
|
|
|
|
|
LOGO_FOLDER = 'logos/'
|
|
|
|
CSV_FOLDER = 'csv/new/'
|
|
|
|
ALLOWED_EXTENSIONS = {'csv', 'png'}
|
|
|
|
|
2021-11-29 15:20:54 +00:00
|
|
|
ticker = pexpect.spawn("sudo -E python3 stockTicker.py")
|
2022-02-15 18:33:32 +00:00
|
|
|
time.sleep(2) # give the ticker time to initialise
|
2022-02-14 18:48:27 +00:00
|
|
|
|
|
|
|
system_info = json.load(open('csv/system_info.json'))
|
|
|
|
|
2022-02-15 18:33:32 +00:00
|
|
|
ticker.sendline('*') # run startup gif by default
|
|
|
|
time.sleep(8)
|
2022-02-14 18:48:27 +00:00
|
|
|
if system_info['first_boot']: # let startup message display
|
|
|
|
|
2022-02-15 18:33:32 +00:00
|
|
|
ticker.sendline('-')
|
2022-02-14 18:48:27 +00:00
|
|
|
system_info['first_boot'] = False
|
|
|
|
json.dump(system_info, open('csv/system_info.json', 'w'))
|
2022-02-15 18:33:32 +00:00
|
|
|
else:
|
|
|
|
ticker.sendline('A') # run by default
|
2021-07-08 18:42:21 +00:00
|
|
|
|
2021-04-26 18:51:21 +00:00
|
|
|
def allowed_file(filename):
|
|
|
|
return '.' in filename and filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS
|
|
|
|
|
|
|
|
def process_file(path, filename):
|
2021-12-14 15:38:09 +00:00
|
|
|
default_csv = csv.writer(open('csv/tickers.csv', 'w+'))
|
2021-04-26 18:51:21 +00:00
|
|
|
new_csv = csv.reader(open((path), 'r'))
|
|
|
|
|
|
|
|
for row in new_csv:
|
|
|
|
default_csv.writerow(row)
|
|
|
|
|
2021-12-06 20:10:14 +00:00
|
|
|
class DummyProcess():
|
|
|
|
def close(self):
|
|
|
|
return True
|
2021-05-01 11:08:15 +00:00
|
|
|
|
2021-04-26 18:51:21 +00:00
|
|
|
|
|
|
|
app = Flask(__name__)
|
|
|
|
@app.route("/", methods=['GET', 'POST'])
|
2021-08-18 19:50:02 +00:00
|
|
|
def index():
|
2021-11-22 19:08:14 +00:00
|
|
|
global command
|
|
|
|
all_features = ['Current Weather','Daily Forecast','News', 'Sports (Upcoming Games)','Sports (Past Games)','Sports (Live Games)',
|
2021-09-20 19:46:15 +00:00
|
|
|
'Sports (Team Stats)','Custom Images', 'Custom GIFs', 'Custom Messages', 'Stocks', 'Crypto', 'Forex']
|
2021-11-22 19:08:14 +00:00
|
|
|
|
|
|
|
global professional
|
|
|
|
|
|
|
|
feature_settings = json.load(open('csv/display_settings.json', 'r'))
|
2022-02-26 17:00:19 +00:00
|
|
|
|
|
|
|
print('professional',professional)
|
2021-11-22 19:08:14 +00:00
|
|
|
|
|
|
|
if not professional:
|
|
|
|
currently_displaying = json.load(open('csv/display_settings.json', 'r'))[1]
|
2022-02-24 17:05:37 +00:00
|
|
|
not_displaying = [f for f in all_features if f not in currently_displaying[0]]
|
2021-11-22 19:08:14 +00:00
|
|
|
|
|
|
|
elif professional:
|
|
|
|
currently_displaying = json.load(open('csv/display_settings.json', 'r'))[1]
|
|
|
|
not_displaying = [f for f in all_features if f not in currently_displaying[0] and f not in currently_displaying[1]]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
now = datetime.datetime.now()
|
|
|
|
timeString = now.strftime("%Y-%m-%d %H:%M")
|
|
|
|
logos_path = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos')
|
|
|
|
LogoList = os.listdir(logos_path)
|
|
|
|
|
|
|
|
stocks_settings = json.load(open('csv/stocks_settings.json', 'r'))
|
|
|
|
crypto_settings = json.load(open('csv/crypto_settings.json', 'r'))
|
|
|
|
forex_settings = json.load(open('csv/forex_settings.json', 'r'))
|
|
|
|
current_weather= json.load(open('csv/current_weather.json', 'r'))
|
|
|
|
daily_weather = json.load(open('csv/daily_weather.json', 'r'))
|
|
|
|
news_settings = json.load(open('csv/news_settings.json', 'r'))
|
|
|
|
upcoming_games = json.load(open('csv/upcoming_games.json', 'r'))
|
|
|
|
live_games = json.load(open('csv/live_games.json', 'r'))
|
|
|
|
past_games = json.load(open('csv/past_games.json', 'r'))
|
|
|
|
team_stats = json.load(open('csv/league_tables.json', 'r'))
|
|
|
|
image_settings = json.load(open('csv/image_settings.json', 'r'))
|
|
|
|
GIF_settings = json.load(open('csv/GIF_settings.json', 'r'))
|
|
|
|
message_settings = json.load(open('csv/message_settings.json', 'r'))
|
2021-12-06 20:10:14 +00:00
|
|
|
general_settings = json.load(open('csv/general_settings.json', 'r'))
|
2021-11-22 19:08:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
templateData = {
|
2022-02-27 09:52:37 +00:00
|
|
|
'system_info':system_info,
|
2021-09-20 19:46:15 +00:00
|
|
|
'currently_displaying': currently_displaying,
|
|
|
|
'not_displaying': not_displaying,
|
|
|
|
'stocks_settings': stocks_settings,
|
|
|
|
'crypto_settings': crypto_settings,
|
|
|
|
'forex_settings': forex_settings,
|
|
|
|
'current_weather': current_weather,
|
|
|
|
'daily_weather': daily_weather,
|
|
|
|
'news_settings': news_settings,
|
|
|
|
'upcoming_games': upcoming_games,
|
|
|
|
'past_games': past_games,
|
|
|
|
'live_games': live_games,
|
|
|
|
'team_stats': team_stats,
|
|
|
|
'image_settings':image_settings,
|
2021-10-12 19:52:52 +00:00
|
|
|
'GIF_settings':GIF_settings,
|
2021-11-22 19:08:14 +00:00
|
|
|
'message_settings':message_settings,
|
2021-12-06 20:10:14 +00:00
|
|
|
'professional':professional,
|
|
|
|
'general_settings':general_settings
|
2021-04-26 18:51:21 +00:00
|
|
|
}
|
2021-11-22 19:08:14 +00:00
|
|
|
return render_template('index.html', **templateData)
|
2021-04-26 18:51:21 +00:00
|
|
|
|
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
|
|
|
|
def save_displaying(input_settings):
|
2021-12-29 13:05:45 +00:00
|
|
|
#print('save')
|
2022-02-24 17:23:18 +00:00
|
|
|
global professional
|
2022-02-24 17:05:37 +00:00
|
|
|
print('save_displaying_input:', input_settings)
|
2021-08-11 19:58:01 +00:00
|
|
|
all_settings = ['Stocks', 'Crypto', 'Forex', 'Current Weather', 'Daily Forecast', 'News', 'Sports (Upcoming Games)', 'Sports (Past Games)',
|
|
|
|
'Sports (Live Games)', 'Sports (Team Stats)', 'Custom Images', 'Custom GIFs', 'Custom Messages']
|
2022-02-24 17:23:18 +00:00
|
|
|
professional = len(input_settings) == 2
|
2021-08-18 19:50:02 +00:00
|
|
|
if professional:
|
|
|
|
all_settings = ['Stocks', 'Crypto', 'Forex', 'Current Weather', 'News']
|
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
|
2021-08-11 19:58:01 +00:00
|
|
|
positions = []
|
|
|
|
display_settings = []
|
2021-12-10 17:06:47 +00:00
|
|
|
|
2021-11-22 19:19:26 +00:00
|
|
|
if professional:
|
2022-02-24 17:23:18 +00:00
|
|
|
|
2021-11-22 19:19:26 +00:00
|
|
|
input_settings[0] = [i for i in input_settings[0] if i in all_settings]
|
|
|
|
input_settings[1] = [i for i in input_settings[1] if i in all_settings]
|
2022-02-24 17:05:37 +00:00
|
|
|
|
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
|
|
|
|
|
2021-08-11 19:58:01 +00:00
|
|
|
|
2021-11-22 19:08:14 +00:00
|
|
|
s = "Professional" if professional else "Standard"
|
|
|
|
display_settings = [s] + [input_settings]
|
2022-02-24 17:05:37 +00:00
|
|
|
print(display_settings)
|
2021-08-11 19:58:01 +00:00
|
|
|
with open('csv/display_settings.json', 'w+') as f:
|
|
|
|
json.dump(list(display_settings), f)
|
2021-12-10 17:06:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route ("/start", methods = ['PUT', 'POST'])
|
|
|
|
def start():
|
2022-02-15 19:50:20 +00:00
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
global displaying_screensaver
|
|
|
|
global ticker
|
|
|
|
global api_caller
|
|
|
|
global professional
|
2022-02-21 18:54:35 +00:00
|
|
|
global ticker_stopped
|
2021-12-10 17:06:47 +00:00
|
|
|
if displaying_screensaver:
|
|
|
|
screensaver_p.close()
|
|
|
|
ticker = pexpect.spawn("sudo -E python3 stockTicker.py")
|
2022-02-21 18:38:05 +00:00
|
|
|
#api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 api_caller.py")
|
|
|
|
api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 database_caller.py")
|
2021-12-10 17:06:47 +00:00
|
|
|
displaying_screensaver = False
|
2022-02-21 18:54:35 +00:00
|
|
|
|
|
|
|
if ticker_stopped:
|
|
|
|
ticker = pexpect.spawn("sudo -E python3 stockTicker.py")
|
|
|
|
ticker_stopped = False
|
|
|
|
|
2022-02-15 19:50:20 +00:00
|
|
|
api_caller.sendline('A')
|
2021-08-11 19:58:01 +00:00
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
|
2021-08-18 19:50:02 +00:00
|
|
|
ticker.sendline('A')
|
|
|
|
return index()
|
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
@app.route("/stop")
|
|
|
|
def stop():
|
|
|
|
print('stop')
|
|
|
|
global displaying_screensaver
|
2021-12-06 20:10:14 +00:00
|
|
|
global ticker
|
|
|
|
global api_caller
|
|
|
|
global professional
|
2022-02-21 18:54:35 +00:00
|
|
|
global ticker_stopped
|
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
if not displaying_screensaver:
|
2022-02-22 12:41:30 +00:00
|
|
|
time.sleep(0.1) # give time for leds to turn off
|
2022-02-21 18:54:35 +00:00
|
|
|
ticker.close()
|
2021-11-18 17:50:50 +00:00
|
|
|
else:
|
|
|
|
screensaver_p.close()
|
|
|
|
|
2022-02-21 18:54:35 +00:00
|
|
|
if not ticker_stopped:
|
|
|
|
|
2022-02-22 12:41:30 +00:00
|
|
|
time.sleep(0.1) # give time for leds to turn off
|
2022-02-21 18:54:35 +00:00
|
|
|
ticker.close()
|
|
|
|
ticker_stopped = True
|
|
|
|
|
2021-12-29 13:05:45 +00:00
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
if displaying_screensaver:
|
|
|
|
screensaver_p.close()
|
2021-12-06 20:10:14 +00:00
|
|
|
ticker = pexpect.spawn("sudo -E python3 stockTicker.py")
|
2022-02-21 18:38:05 +00:00
|
|
|
#api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 api_caller.py")
|
|
|
|
api_caller = pexpect.spawn("sudo -E taskset -c 3 python3 database_caller.py")
|
2021-11-18 17:50:50 +00:00
|
|
|
displaying_screensaver = False
|
2022-02-21 18:54:35 +00:00
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
return index()
|
2021-11-20 15:30:31 +00:00
|
|
|
|
|
|
|
@app.route("/update", methods=['PUT','POST'])
|
|
|
|
def update():
|
2022-02-27 09:52:37 +00:00
|
|
|
uptodate = os.system('sudo ./check_update.sh')
|
|
|
|
print('python:', uptodate)
|
|
|
|
|
|
|
|
print(uptodate == 'not up to date')
|
|
|
|
print(uptodate == 'up to date')
|
|
|
|
#os.system("./update.sh")
|
|
|
|
#os.system("sudo reboot now")
|
2021-12-01 16:47:08 +00:00
|
|
|
return index()
|
2021-11-20 15:30:31 +00:00
|
|
|
|
2022-02-26 15:50:10 +00:00
|
|
|
@app.route("/restart")
|
2022-02-24 18:35:43 +00:00
|
|
|
def restart():
|
|
|
|
os.system("sudo reboot now")
|
2021-08-18 19:50:02 +00:00
|
|
|
return index()
|
|
|
|
|
2022-02-26 16:35:15 +00:00
|
|
|
@app.route("/reset")
|
|
|
|
def reset():
|
|
|
|
print('reset')
|
|
|
|
os.system("sudo ./setup_config_files.sh")
|
|
|
|
return index()
|
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
@app.route("/save", methods = ['PUT', 'POST', 'GET'])
|
|
|
|
def save():
|
2021-12-29 13:05:45 +00:00
|
|
|
print('save')
|
|
|
|
global uploading
|
2022-01-15 11:11:32 +00:00
|
|
|
|
2021-09-16 19:23:04 +00:00
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
data = str(request.data.decode('utf-8'))
|
|
|
|
|
2021-12-29 13:05:45 +00:00
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
input_settings = json.loads(data)
|
2021-12-15 11:06:54 +00:00
|
|
|
|
2021-12-29 13:05:45 +00:00
|
|
|
|
|
|
|
print(input_settings)
|
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
save_displaying(input_settings['displaying'])
|
|
|
|
|
|
|
|
input_settings= input_settings['feature_settings']
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
feature = input_settings['feature']
|
|
|
|
if feature in ['Stocks', 'Crypto', 'Forex']:
|
|
|
|
save_trade_settings(input_settings)
|
|
|
|
elif feature in ['Current Weather', 'Daily Forecast']:
|
|
|
|
save_weather_settings(input_settings)
|
|
|
|
elif feature == 'News':
|
|
|
|
save_news_settings(input_settings)
|
|
|
|
elif 'Sports' in feature:
|
|
|
|
save_sports_settings(input_settings)
|
|
|
|
|
|
|
|
elif feature in ['Custom GIFs', 'Custom Images']:
|
2021-12-29 13:05:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
images = request.files
|
|
|
|
names = list(request.files.keys())
|
|
|
|
print(names)
|
|
|
|
|
|
|
|
for name in names:
|
|
|
|
print(name)
|
|
|
|
images[name].save('user_uploads/' +name)
|
|
|
|
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
save_image_settings(input_settings)
|
|
|
|
|
2021-10-11 19:16:04 +00:00
|
|
|
elif feature == 'Custom Messages':
|
|
|
|
save_message_settings(input_settings)
|
|
|
|
|
2021-09-16 19:23:04 +00:00
|
|
|
return index()
|
2021-09-19 18:19:09 +00:00
|
|
|
|
2021-10-07 19:40:43 +00:00
|
|
|
# saves files uploaded to the webpage for images and GIFs
|
|
|
|
@app.route("/upload", methods = ['PUT', 'POST', 'GET'])
|
|
|
|
def upload():
|
2021-12-29 13:05:45 +00:00
|
|
|
print('upload')
|
|
|
|
global uploading
|
|
|
|
uploading = True
|
2021-10-07 19:40:43 +00:00
|
|
|
try:
|
2021-12-22 09:43:36 +00:00
|
|
|
|
2021-10-07 19:40:43 +00:00
|
|
|
images = request.files
|
|
|
|
names = list(request.files.keys())
|
2021-12-21 17:21:04 +00:00
|
|
|
|
2021-10-07 19:40:43 +00:00
|
|
|
for name in names:
|
|
|
|
images[name].save('user_uploads/' +name)
|
|
|
|
|
|
|
|
except Exception as e:
|
2022-03-02 10:50:06 +00:00
|
|
|
#print(e)
|
2022-03-02 10:42:50 +00:00
|
|
|
uploading = False
|
2021-10-07 19:40:43 +00:00
|
|
|
return index()
|
2021-11-20 15:30:31 +00:00
|
|
|
|
2021-12-21 17:21:04 +00:00
|
|
|
def remove_old_uploads():
|
|
|
|
#remove old files
|
|
|
|
|
|
|
|
image_settings = json.load(open('csv/image_settings.json', 'r'))
|
|
|
|
GIF_settings = json.load(open('csv/GIF_settings.json', 'r'))
|
|
|
|
for filename in os.listdir('user_uploads'):
|
|
|
|
if filename not in image_settings['images'] and filename not in GIF_settings['images']:
|
|
|
|
os.remove('user_uploads/'+filename)
|
2021-11-20 15:30:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
@app.route("/brightness", methods=['PUT','POST'])
|
|
|
|
def brightness():
|
|
|
|
global brightness
|
|
|
|
|
|
|
|
data= request.data.decode('utf-8')
|
|
|
|
settings = json.loads(data)
|
|
|
|
print(settings)
|
|
|
|
brightness =settings['brightness']
|
2021-12-06 20:10:14 +00:00
|
|
|
|
2021-12-08 16:57:45 +00:00
|
|
|
ticker.sendline(str(int(brightness)-1))
|
2021-12-06 20:10:14 +00:00
|
|
|
|
|
|
|
general_settings = json.load(open('csv/general_settings.json', 'r'))
|
|
|
|
|
2021-12-08 17:00:42 +00:00
|
|
|
general_settings['brightness'] = int(brightness)
|
2021-12-06 20:10:14 +00:00
|
|
|
json.dump(general_settings, open('csv/general_settings.json', 'w+'))
|
2021-11-18 17:50:50 +00:00
|
|
|
return index()
|
2021-10-07 19:40:43 +00:00
|
|
|
|
2021-11-18 19:41:50 +00:00
|
|
|
|
|
|
|
def edit_wpa_sup(country, ssid, pwd):
|
|
|
|
current_wpa = open('/etc/wpa_supplicant/wpa_supplicant.conf')
|
|
|
|
|
|
|
|
wpa_lines = current_wpa.readlines()
|
|
|
|
|
|
|
|
wpa_lines[2] = 'country={}\n'.format(country)
|
|
|
|
|
|
|
|
current_wpa.close()
|
|
|
|
|
2021-12-15 09:05:53 +00:00
|
|
|
#remove this line to append to end instead of overwriting all networks
|
2021-12-16 14:41:39 +00:00
|
|
|
wpa_lines = wpa_lines[0:3]
|
2021-12-15 09:05:53 +00:00
|
|
|
print(wpa_lines)
|
|
|
|
|
2021-12-16 14:49:34 +00:00
|
|
|
# create new file from scratch
|
|
|
|
wpa_lines = []
|
2021-12-16 15:03:30 +00:00
|
|
|
wpa_lines.append('ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev\n')
|
|
|
|
wpa_lines.append('update_config=1\n')
|
2021-12-16 14:56:15 +00:00
|
|
|
wpa_lines.append('country={}\n'.format(country))
|
2021-12-16 14:49:34 +00:00
|
|
|
|
|
|
|
|
2021-11-18 19:41:50 +00:00
|
|
|
wpa_lines.append('\n')
|
|
|
|
wpa_lines.append('network={\n')
|
|
|
|
wpa_lines.append('\tssid="{}"\n'.format(ssid))
|
|
|
|
wpa_lines.append('\tpsk="{}"\n'.format(pwd))
|
|
|
|
wpa_lines.append('}\n')
|
|
|
|
|
|
|
|
wpa_string = ''.join(wpa_lines)
|
|
|
|
print(wpa_string)
|
|
|
|
current_wpa = open('/etc/wpa_supplicant/wpa_supplicant.conf', 'w+')
|
|
|
|
current_wpa.write(wpa_string)
|
|
|
|
|
|
|
|
|
|
|
|
@app.route("/wifi", methods = ['PUT', 'POST', 'GET'])
|
2022-01-24 18:40:06 +00:00
|
|
|
def set_wifi():
|
2021-11-18 19:41:50 +00:00
|
|
|
|
|
|
|
data= request.data.decode('utf-8')
|
|
|
|
print(str(data))
|
|
|
|
settings = json.loads(data)
|
|
|
|
|
|
|
|
country = settings['country'].upper()
|
|
|
|
ssid = settings['ssid']
|
|
|
|
pwd = settings['pwd']
|
|
|
|
|
2021-12-06 20:10:14 +00:00
|
|
|
general_settings = json.load(open('csv/general_settings.json', 'r'))
|
|
|
|
|
|
|
|
general_settings['country_code'] = country
|
|
|
|
json.dump(general_settings, open('csv/general_settings.json', 'w+'))
|
|
|
|
|
2021-11-18 19:41:50 +00:00
|
|
|
edit_wpa_sup(country, ssid, pwd)
|
|
|
|
# resstart netoworking
|
|
|
|
os.system('wpa_cli -i wlan0 reconfigure')
|
|
|
|
return index()
|
2021-11-29 15:17:55 +00:00
|
|
|
|
2022-01-24 18:40:06 +00:00
|
|
|
def check_internet_connection(host='http://google.com'):
|
|
|
|
|
|
|
|
try:
|
|
|
|
urllib.request.urlopen(host) #Python 3.x
|
|
|
|
return True
|
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
|
|
|
def check_network_connection():
|
|
|
|
ps = subprocess.Popen(['iwconfig'], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
|
|
|
try:
|
|
|
|
output = subprocess.check_output(('grep', 'ESSID'), stdin=ps.stdout)
|
|
|
|
return True
|
|
|
|
except subprocess.CalledProcessError:
|
|
|
|
# grep did not match any lines
|
|
|
|
print("No wireless networks connected")
|
|
|
|
return False
|
|
|
|
|
2021-11-29 15:17:55 +00:00
|
|
|
def edit_hosts(hostname):
|
|
|
|
current_hosts = open('/etc/hosts')
|
|
|
|
|
|
|
|
hosts_lines = current_hosts.readlines()
|
|
|
|
print(hosts_lines[5])
|
|
|
|
|
|
|
|
hosts_lines[5] = '127.0.1.1 {}'.format(hostname)
|
|
|
|
|
|
|
|
current_hosts.close()
|
|
|
|
|
|
|
|
hosts_string = ''.join(hosts_lines)
|
|
|
|
|
|
|
|
current_hosts = open('/etc/hosts', 'w+')
|
|
|
|
current_hosts.write(hosts_string)
|
2021-11-18 19:41:50 +00:00
|
|
|
|
2021-11-26 15:33:10 +00:00
|
|
|
@app.route("/hostname", methods = ['PUT', 'POST', 'GET'])
|
|
|
|
def hostname():
|
|
|
|
data= request.data.decode('utf-8')
|
|
|
|
settings = json.loads(data)
|
|
|
|
hostname = settings['hostname']
|
|
|
|
print('hostname', hostname)
|
2021-11-29 15:17:55 +00:00
|
|
|
|
|
|
|
edit_hosts(hostname)
|
2021-11-26 15:33:10 +00:00
|
|
|
os.system("sudo hostnamectl set-hostname {}".format(hostname))
|
|
|
|
os.system("sudo systemctl restart avahi-daemon")
|
2021-11-18 19:41:50 +00:00
|
|
|
|
2021-12-06 20:10:14 +00:00
|
|
|
general_settings = json.load(open('csv/general_settings.json', 'r'))
|
|
|
|
|
|
|
|
general_settings['hostname'] = hostname
|
|
|
|
json.dump(general_settings, open('csv/general_settings.json', 'w+'))
|
|
|
|
|
2021-11-26 15:33:10 +00:00
|
|
|
return index()
|
2022-02-24 18:35:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
@app.route("/saveWeatherAPIKey", methods = ['PUT', 'POST'])
|
|
|
|
def saveWeatherAPIKey():
|
2021-11-18 19:41:50 +00:00
|
|
|
|
2022-02-24 18:35:43 +00:00
|
|
|
data= request.data.decode('utf-8')
|
|
|
|
settings = json.loads(data)
|
|
|
|
|
|
|
|
key = settings['api_key']
|
|
|
|
print(key)
|
|
|
|
with open('./api_keys.txt') as f:
|
|
|
|
lines = f.readlines()
|
|
|
|
if len(lines) == 1:
|
|
|
|
lines.append(str(key))
|
|
|
|
elif len(lines) == 2:
|
|
|
|
lines[1] = str(key)
|
|
|
|
print(lines)
|
|
|
|
with open('./api_keys.txt', 'w') as f:
|
|
|
|
for line in lines:
|
|
|
|
f.write(line)
|
|
|
|
return index()
|
2021-11-18 19:41:50 +00:00
|
|
|
|
2021-11-17 19:34:13 +00:00
|
|
|
@app.route("/screensaver", methods = ['PUT', 'POST'])
|
|
|
|
def screensaver():
|
|
|
|
global displaying_screensaver
|
|
|
|
global ticker
|
|
|
|
global api_caller
|
|
|
|
global screensaver_p
|
2022-02-26 15:50:10 +00:00
|
|
|
|
2021-11-17 19:34:13 +00:00
|
|
|
data = str(request.data)
|
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
if displaying_screensaver:
|
|
|
|
screensaver_p.close()
|
2022-02-26 15:50:10 +00:00
|
|
|
else:
|
|
|
|
api_caller.close()
|
|
|
|
ticker.close()
|
2021-12-06 20:10:14 +00:00
|
|
|
|
2021-11-17 19:34:13 +00:00
|
|
|
|
|
|
|
if "Pulsating Colors" in data:
|
2021-12-05 19:55:09 +00:00
|
|
|
screensaver_p = pexpect.spawn("sudo -E python3 ./rpi-rgb-led-matrix/bindings/python/samples/pulsing-colors.py --led-gpio-mapping=adafruit-hat --led-slowdown-gpio=4 -r 32 --led-cols 64 -c 2 -P 1")
|
2021-11-17 19:34:13 +00:00
|
|
|
|
|
|
|
elif "Rotating Square" in data:
|
2021-12-05 19:55:09 +00:00
|
|
|
screensaver_p = pexpect.spawn("sudo -E python3 ./rpi-rgb-led-matrix/bindings/python/samples/rotating-block-generator.py --led-gpio-mapping=adafruit-hat --led-slowdown-gpio=4 -r 32 --led-cols 64 -c 2 -P 1")
|
2021-11-17 19:34:13 +00:00
|
|
|
|
|
|
|
elif "Pulsating brightness" in data:
|
2021-12-05 19:55:09 +00:00
|
|
|
screensaver_p = pexpect.spawn("sudo -E python3 ./rpi-rgb-led-matrix/bindings/python/samples/pulsing-brightness.py --led-gpio-mapping=adafruit-hat --led-slowdown-gpio=4 -r 32 --led-cols 64 -c 2 -P 1")
|
2021-11-17 19:34:13 +00:00
|
|
|
|
|
|
|
elif "Game of Life" in data:
|
|
|
|
screensaver_p = pexpect.spawn("sudo -E python3 game_of_life.py")
|
|
|
|
|
2021-12-06 20:10:14 +00:00
|
|
|
elif "Sleep" in data:
|
|
|
|
screensaver_p = DummyProcess()
|
2022-01-15 11:11:32 +00:00
|
|
|
else: #default in case user hasnt set one yet
|
|
|
|
screensaver_p = DummyProcess()
|
|
|
|
|
2021-12-06 20:10:14 +00:00
|
|
|
|
2021-11-17 19:34:13 +00:00
|
|
|
displaying_screensaver = True
|
|
|
|
return index()
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
def combine_dict(current_settings, input_symbols, current_key):
|
|
|
|
# removes keys not in input from current_settings[current_key] and adds keys not in current from input
|
2021-12-10 17:06:47 +00:00
|
|
|
new_settings = copy.deepcopy(current_settings)
|
|
|
|
new_settings[current_key] = {}
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
current_symbols = list(current_settings[current_key].keys())
|
|
|
|
|
|
|
|
# add any stock that arent current in the settings
|
|
|
|
for IS in input_symbols:
|
|
|
|
if IS not in current_symbols:
|
2021-12-10 17:06:47 +00:00
|
|
|
new_settings[current_key][IS] = []
|
|
|
|
else:
|
|
|
|
new_settings[current_key][IS] = current_settings[current_key][IS]
|
2021-12-14 15:38:09 +00:00
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
|
2021-12-10 17:06:47 +00:00
|
|
|
return new_settings
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
def save_trade_settings(input_settings):
|
|
|
|
|
|
|
|
|
|
|
|
filename = input_settings['feature'].lower() + '_settings.json'
|
|
|
|
|
|
|
|
current_settings = json.load(open('csv/' + filename, 'r'))
|
|
|
|
|
|
|
|
current_settings['speed'] = input_settings['speed'].lower()
|
|
|
|
current_settings['animation'] = input_settings['animation'].lower()
|
|
|
|
current_settings['percent'] = input_settings['percent']
|
|
|
|
current_settings['point'] = input_settings['point']
|
2021-09-23 19:44:14 +00:00
|
|
|
current_settings['logos'] = input_settings['logos']
|
2021-09-19 18:19:09 +00:00
|
|
|
current_settings['title'] = input_settings['title']
|
|
|
|
|
|
|
|
|
|
|
|
current_settings = combine_dict(current_settings, input_settings['symbols'], 'symbols')
|
|
|
|
|
|
|
|
json.dump(current_settings, open('csv/' + filename, 'w+'))
|
|
|
|
|
2021-11-16 19:11:32 +00:00
|
|
|
if input_settings['feature'].lower() == 'stocks':
|
|
|
|
api_caller.sendline('s')
|
|
|
|
elif input_settings['feature'].lower() == 'crypto':
|
|
|
|
api_caller.sendline('c')
|
|
|
|
elif input_settings['feature'].lower() == 'forex':
|
|
|
|
api_caller.sendline('f')
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
def save_weather_settings(input_settings):
|
2021-12-04 15:54:31 +00:00
|
|
|
|
|
|
|
print(input_settings)
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
filename = 'current_weather.json' if input_settings['feature'] == 'Current Weather' else 'daily_weather.json'
|
2021-12-04 15:54:31 +00:00
|
|
|
print(filename)
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
current_settings = json.load(open('csv/' + filename, 'r'))
|
|
|
|
|
|
|
|
current_settings['speed'] = input_settings['speed'].lower()
|
|
|
|
current_settings['animation'] = input_settings['animation'].lower()
|
|
|
|
current_settings['temp'] = input_settings['temp'].lower()
|
|
|
|
current_settings['wind_speed'] = input_settings['wind_speed'].lower()
|
2021-12-22 09:43:36 +00:00
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
current_settings['title'] = input_settings['title']
|
|
|
|
|
|
|
|
if input_settings['feature'] == 'Daily Forecast':
|
|
|
|
current_settings['current_weather'] = input_settings['current_weather']
|
2021-09-16 19:23:04 +00:00
|
|
|
|
2021-12-14 15:38:09 +00:00
|
|
|
'''
|
2021-12-04 15:54:31 +00:00
|
|
|
locations = {}
|
|
|
|
for key in input_settings['locations']:
|
|
|
|
locations[key] = []
|
|
|
|
current_settings['locations'] = locations
|
2021-12-14 15:38:09 +00:00
|
|
|
'''
|
|
|
|
|
|
|
|
current_settings = combine_dict(current_settings, input_settings['locations'], 'locations')
|
2021-09-19 18:19:09 +00:00
|
|
|
json.dump(current_settings, open('csv/' + filename, 'w+'))
|
|
|
|
|
2021-11-16 19:11:32 +00:00
|
|
|
api_caller.sendline('w')
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
def save_news_settings(input_settings):
|
|
|
|
filename = 'news_settings.json'
|
|
|
|
|
|
|
|
current_settings = json.load(open('csv/' + filename, 'r'))
|
|
|
|
|
2022-01-24 18:40:06 +00:00
|
|
|
print(current_settings)
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
current_settings['speed'] = input_settings['speed'].lower()
|
|
|
|
current_settings['animation'] = input_settings['animation'].lower()
|
|
|
|
current_settings['title'] = input_settings['title']
|
2022-02-24 19:42:33 +00:00
|
|
|
current_settings['category'] = input_settings['category']
|
2021-09-19 18:19:09 +00:00
|
|
|
current_settings['country'] = input_settings['country']
|
2022-02-24 19:42:33 +00:00
|
|
|
current_settings['use_category'] = input_settings['use_category']
|
|
|
|
current_settings['use_country'] = input_settings['use_country']
|
|
|
|
current_settings['num_headlines'] = input_settings['num_headlines']
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
|
2022-02-24 19:42:33 +00:00
|
|
|
|
2022-01-24 18:40:06 +00:00
|
|
|
print(current_settings)
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
json.dump(current_settings, open('csv/' + filename, 'w+'))
|
2021-11-16 19:11:32 +00:00
|
|
|
api_caller.sendline('n')
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
def save_sports_settings(input_settings):
|
|
|
|
|
|
|
|
feature = input_settings['feature']
|
|
|
|
|
|
|
|
if feature == 'Sports (Upcoming Games)':
|
|
|
|
filename = 'upcoming_games.json'
|
|
|
|
elif feature == 'Sports (Past Games)':
|
|
|
|
filename = 'past_games.json'
|
|
|
|
elif feature == 'Sports (Live Games)':
|
|
|
|
filename = 'live_games.json'
|
|
|
|
elif feature == 'Sports (Team Stats)':
|
2021-09-25 09:40:29 +00:00
|
|
|
filename = 'league_tables.json'
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
current_settings = json.load(open('csv/' + filename, 'r'))
|
|
|
|
|
|
|
|
current_settings['speed'] = input_settings['speed'].lower()
|
|
|
|
current_settings['animation'] = input_settings['animation'].lower()
|
|
|
|
current_settings['title'] = input_settings['title']
|
2021-09-25 09:40:29 +00:00
|
|
|
current_settings['feature'] = input_settings['feature']
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
current_settings = combine_dict(current_settings, input_settings['leagues'], 'leagues')
|
|
|
|
|
|
|
|
json.dump(current_settings, open('csv/' + filename, 'w+'))
|
|
|
|
|
2021-11-16 19:11:32 +00:00
|
|
|
api_caller.sendline('S')
|
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
# for images and GIFs
|
|
|
|
def save_image_settings(input_settings):
|
|
|
|
filename = 'image_settings.json' if input_settings['feature'] == 'Custom Images' else 'GIF_settings.json'
|
|
|
|
|
|
|
|
current_settings = input_settings
|
|
|
|
|
|
|
|
current_settings['speed'] = input_settings['speed'].lower()
|
|
|
|
current_settings['animation'] = input_settings['animation'].lower()
|
2021-12-08 17:26:35 +00:00
|
|
|
|
2021-09-19 18:19:09 +00:00
|
|
|
|
|
|
|
del current_settings['feature']
|
|
|
|
json.dump(current_settings, open('csv/' + filename, 'w+'))
|
2021-12-22 09:43:36 +00:00
|
|
|
remove_old_uploads()
|
2021-12-15 11:06:54 +00:00
|
|
|
|
|
|
|
|
2021-10-11 19:16:04 +00:00
|
|
|
def save_message_settings(input_settings):
|
|
|
|
|
2021-12-15 11:06:54 +00:00
|
|
|
current_settings = json.load(open('csv/message_settings.json', 'r'))
|
|
|
|
new_settings = copy.deepcopy(input_settings)
|
|
|
|
print(current_settings)
|
|
|
|
print()
|
|
|
|
print(input_settings)
|
|
|
|
print()
|
|
|
|
for i,IS in enumerate(input_settings['messages']):
|
|
|
|
|
|
|
|
# check if this is in current_settings
|
|
|
|
for CS in current_settings['messages']:
|
|
|
|
if IS['name'] == CS['name']:
|
|
|
|
new_settings['messages'][i] = CS
|
|
|
|
print(CS)
|
|
|
|
break
|
|
|
|
|
|
|
|
print(new_settings)
|
|
|
|
json.dump(new_settings, open('csv/message_settings.json', 'w+'))
|
2021-10-11 19:16:04 +00:00
|
|
|
|
2021-11-18 17:50:50 +00:00
|
|
|
|
2021-08-11 19:58:01 +00:00
|
|
|
|
|
|
|
@app.route("/shutdown")
|
|
|
|
def shutdown():
|
|
|
|
os.system("sudo shutdown now")
|
2021-08-18 19:50:02 +00:00
|
|
|
return index()
|
2021-11-26 15:33:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-08-11 19:58:01 +00:00
|
|
|
|
|
|
|
@app.route("/matrix")
|
2021-04-26 18:51:21 +00:00
|
|
|
def matrix():
|
2021-08-11 19:58:01 +00:00
|
|
|
|
2021-05-21 13:24:37 +00:00
|
|
|
if "Run Stocks" in request.form:
|
|
|
|
ticker.sendline('K')
|
2021-05-03 10:39:31 +00:00
|
|
|
ticker.sendline('S')
|
2021-07-06 19:15:05 +00:00
|
|
|
elif "Run Crypto" in request.form:
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('C')
|
2021-05-01 10:39:20 +00:00
|
|
|
|
2021-07-06 19:15:05 +00:00
|
|
|
elif "Run Forex" in request.form:
|
|
|
|
ticker.sendline('K')
|
2021-07-08 16:48:03 +00:00
|
|
|
ticker.sendline('F')
|
2021-05-01 10:39:20 +00:00
|
|
|
|
2021-06-07 20:03:03 +00:00
|
|
|
elif "Run News" in request.form:
|
2021-07-06 19:15:05 +00:00
|
|
|
|
2021-05-21 13:24:37 +00:00
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('N')
|
|
|
|
|
2021-06-07 20:03:03 +00:00
|
|
|
elif "Run Weather" in request.form:
|
|
|
|
|
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('W')
|
|
|
|
|
|
|
|
elif "Run Daily Weather" in request.form:
|
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('D')
|
|
|
|
|
2021-06-19 09:53:09 +00:00
|
|
|
elif "Past NHL" in request.form:
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('P')
|
|
|
|
|
|
|
|
elif "Future NHL" in request.form:
|
|
|
|
ticker.sendline('K')
|
2021-07-08 16:48:03 +00:00
|
|
|
ticker.sendline('l')
|
2021-06-19 09:53:09 +00:00
|
|
|
|
|
|
|
elif "Live NHL" in request.form:
|
2021-06-15 18:35:04 +00:00
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('L')
|
|
|
|
|
2021-06-19 09:53:09 +00:00
|
|
|
elif "Premier league table" in request.form:
|
2021-07-08 18:42:21 +00:00
|
|
|
|
2021-06-15 18:35:04 +00:00
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('t')
|
|
|
|
|
2021-07-14 17:02:54 +00:00
|
|
|
elif "Professional" in request.form:
|
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('b')
|
|
|
|
|
2021-06-21 16:39:44 +00:00
|
|
|
elif "All" in request.form:
|
2021-07-08 18:42:21 +00:00
|
|
|
|
2021-06-21 16:39:44 +00:00
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('A')
|
|
|
|
|
2021-07-27 17:33:02 +00:00
|
|
|
elif "Multiple" in request.form:
|
|
|
|
|
|
|
|
ticker.sendline('K')
|
|
|
|
ticker.sendline('+')
|
|
|
|
|
2021-06-07 20:03:03 +00:00
|
|
|
elif "Stop Display" in request.form:
|
2021-07-06 19:15:05 +00:00
|
|
|
|
2021-07-08 18:42:21 +00:00
|
|
|
|
|
|
|
LastCommand = 'Stop display at next checkpoint'
|
|
|
|
ticker.sendline('K')
|
|
|
|
|
2021-05-21 13:24:37 +00:00
|
|
|
elif "Shutdown the pi" in request.form:
|
2021-06-07 20:03:03 +00:00
|
|
|
|
2021-04-26 18:51:21 +00:00
|
|
|
try:
|
2021-05-01 11:08:15 +00:00
|
|
|
os.system("sudo shutdown now")
|
2021-04-26 18:51:21 +00:00
|
|
|
except:
|
|
|
|
print("couldn't shutdown")
|
2021-08-18 19:50:02 +00:00
|
|
|
return index()
|
2021-04-26 18:51:21 +00:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2021-05-31 11:22:56 +00:00
|
|
|
|
|
|
|
app.run(host='0.0.0.0', port=1024, debug=False) # the debuggger causes flickering
|
|
|
|
|
2021-04-26 19:27:34 +00:00
|
|
|
#sudo ./demo -D1 final.ppm -t 50 -m 25 --led-gpio-mapping=adafruit-hat --led-rows=32 --led-cols=256 --led-slowdown-gpio=4
|