updated requirements, and fixed some formatting issues
This commit is contained in:
BIN
requirements.txt
BIN
requirements.txt
Binary file not shown.
@@ -1,5 +1,5 @@
|
|||||||
from tools.web_monitor.app import app
|
from tools.web_monitor.app import app
|
||||||
|
import uvicorn
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == "__main__":
|
||||||
# app.run for running the sanic app inside the file
|
uvicorn.run("app:app", host="127.0.0.1", port=80)
|
||||||
app.run(host="0.0.0.0", port=80)
|
|
||||||
|
|||||||
@@ -1,17 +1,18 @@
|
|||||||
import json
|
|
||||||
import ipaddress
|
|
||||||
import datetime
|
|
||||||
import os
|
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import datetime
|
||||||
|
import ipaddress
|
||||||
|
import os
|
||||||
|
|
||||||
import uvicorn
|
import uvicorn
|
||||||
import websockets.exceptions
|
import websockets.exceptions
|
||||||
from fastapi import FastAPI, Request
|
from fastapi import FastAPI, Request
|
||||||
from fastapi.responses import RedirectResponse
|
|
||||||
from fastapi import WebSocket, WebSocketDisconnect
|
from fastapi import WebSocket, WebSocketDisconnect
|
||||||
from fastapi.templating import Jinja2Templates
|
from fastapi.responses import RedirectResponse
|
||||||
from fastapi.staticfiles import StaticFiles
|
from fastapi.staticfiles import StaticFiles
|
||||||
from tools.web_monitor.miner_factory import miner_factory
|
from fastapi.templating import Jinja2Templates
|
||||||
|
|
||||||
from network import MinerNetwork
|
from network import MinerNetwork
|
||||||
|
from tools.web_monitor.miner_factory import miner_factory
|
||||||
|
|
||||||
app = FastAPI()
|
app = FastAPI()
|
||||||
|
|
||||||
@@ -39,13 +40,15 @@ async def dashboard_websocket(websocket: WebSocket):
|
|||||||
while True:
|
while True:
|
||||||
miners = get_current_miner_list()
|
miners = get_current_miner_list()
|
||||||
all_miner_data = []
|
all_miner_data = []
|
||||||
data_gen = asyncio.as_completed([get_miner_data_dashboard(miner) for miner in miners])
|
data_gen = asyncio.as_completed(
|
||||||
|
[get_miner_data_dashboard(miner_ip) for miner_ip in miners])
|
||||||
for all_data in data_gen:
|
for all_data in data_gen:
|
||||||
data_point = await all_data
|
data_point = await all_data
|
||||||
all_miner_data.append(data_point)
|
all_miner_data.append(data_point)
|
||||||
all_miner_data.sort(key=lambda x: x["ip"])
|
all_miner_data.sort(key=lambda x: x["ip"])
|
||||||
await websocket.send_json({"datetime": datetime.datetime.now().isoformat(),
|
await websocket.send_json(
|
||||||
"miners": all_miner_data})
|
{"datetime": datetime.datetime.now().isoformat(),
|
||||||
|
"miners": all_miner_data})
|
||||||
await asyncio.sleep(1)
|
await asyncio.sleep(1)
|
||||||
except WebSocketDisconnect:
|
except WebSocketDisconnect:
|
||||||
print("Websocket disconnected.")
|
print("Websocket disconnected.")
|
||||||
@@ -56,9 +59,9 @@ async def dashboard_websocket(websocket: WebSocket):
|
|||||||
|
|
||||||
async def get_miner_data_dashboard(miner_ip):
|
async def get_miner_data_dashboard(miner_ip):
|
||||||
try:
|
try:
|
||||||
miner = await asyncio.wait_for(miner_factory.get_miner(miner_ip), 5)
|
miner_ip = await asyncio.wait_for(miner_factory.get_miner(miner_ip), 5)
|
||||||
|
|
||||||
miner_summary = await asyncio.wait_for(miner.api.summary(), 5)
|
miner_summary = await asyncio.wait_for(miner_ip.api.summary(), 5)
|
||||||
if miner_summary:
|
if miner_summary:
|
||||||
if 'MHS av' in miner_summary['SUMMARY'][0].keys():
|
if 'MHS av' in miner_summary['SUMMARY'][0].keys():
|
||||||
hashrate = format(
|
hashrate = format(
|
||||||
@@ -73,13 +76,14 @@ async def get_miner_data_dashboard(miner_ip):
|
|||||||
else:
|
else:
|
||||||
hashrate = 0
|
hashrate = 0
|
||||||
|
|
||||||
return {"ip": str(miner.ip), "hashrate": hashrate}
|
return {"ip": str(miner_ip.ip), "hashrate": hashrate}
|
||||||
|
|
||||||
except asyncio.exceptions.TimeoutError:
|
except asyncio.exceptions.TimeoutError:
|
||||||
return {"ip": miner_ip, "error": "The miner is not responding."}
|
return {"ip": miner_ip, "error": "The miner_ip is not responding."}
|
||||||
|
|
||||||
except KeyError:
|
except KeyError:
|
||||||
return {"ip": miner_ip, "error": "The miner returned unusable/unsupported data."}
|
return {"ip": miner_ip,
|
||||||
|
"error": "The miner_ip returned unusable/unsupported data."}
|
||||||
|
|
||||||
|
|
||||||
@app.get("/scan")
|
@app.get("/scan")
|
||||||
@@ -101,14 +105,15 @@ async def miner_websocket(websocket: WebSocket, miner_ip):
|
|||||||
try:
|
try:
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
cur_miner = await asyncio.wait_for(miner_factory.get_miner(str(miner_ip)), 5)
|
cur_miner = await asyncio.wait_for(
|
||||||
|
miner_factory.get_miner(str(miner_ip)), 5)
|
||||||
|
|
||||||
data = await asyncio.wait_for(cur_miner.api.multicommand("summary", "fans", "stats"), 5)
|
data = await asyncio.wait_for(
|
||||||
|
cur_miner.api.multicommand("summary", "fans", "stats"), 5)
|
||||||
|
|
||||||
miner_model = await cur_miner.get_model()
|
miner_model = await cur_miner.get_model()
|
||||||
|
|
||||||
miner_summary = None
|
miner_summary = None
|
||||||
miner_stats = None
|
|
||||||
miner_fans = None
|
miner_fans = None
|
||||||
if "summary" in data.keys():
|
if "summary" in data.keys():
|
||||||
miner_summary = data["summary"][0]
|
miner_summary = data["summary"][0]
|
||||||
@@ -117,7 +122,8 @@ async def miner_websocket(websocket: WebSocket, miner_ip):
|
|||||||
miner_fans = {"FANS": []}
|
miner_fans = {"FANS": []}
|
||||||
for item in ["Fan Speed In", "Fan Speed Out"]:
|
for item in ["Fan Speed In", "Fan Speed Out"]:
|
||||||
if item in miner_summary["SUMMARY"][0].keys():
|
if item in miner_summary["SUMMARY"][0].keys():
|
||||||
miner_fans["FANS"].append({"RPM": miner_summary["SUMMARY"][0][item]})
|
miner_fans["FANS"].append(
|
||||||
|
{"RPM": miner_summary["SUMMARY"][0][item]})
|
||||||
|
|
||||||
if "fans" in data.keys():
|
if "fans" in data.keys():
|
||||||
miner_fans = data["fans"][0]
|
miner_fans = data["fans"][0]
|
||||||
@@ -127,16 +133,19 @@ async def miner_websocket(websocket: WebSocket, miner_ip):
|
|||||||
miner_fans = {"FANS": []}
|
miner_fans = {"FANS": []}
|
||||||
for item in ["fan1", "fan2", "fan3", "fan4"]:
|
for item in ["fan1", "fan2", "fan3", "fan4"]:
|
||||||
if item in miner_stats["STATS"][1].keys():
|
if item in miner_stats["STATS"][1].keys():
|
||||||
miner_fans["FANS"].append({"RPM": miner_stats["STATS"][1][item]})
|
miner_fans["FANS"].append(
|
||||||
|
{"RPM": miner_stats["STATS"][1][item]})
|
||||||
|
|
||||||
if miner_summary:
|
if miner_summary:
|
||||||
if 'MHS av' in miner_summary['SUMMARY'][0].keys():
|
if 'MHS av' in miner_summary['SUMMARY'][0].keys():
|
||||||
hashrate = format(
|
hashrate = format(
|
||||||
round(miner_summary['SUMMARY'][0]['MHS av'] / 1000000,
|
round(
|
||||||
2), ".2f")
|
miner_summary['SUMMARY'][0]['MHS av'] / 1000000,
|
||||||
|
2), ".2f")
|
||||||
elif 'GHS av' in miner_summary['SUMMARY'][0].keys():
|
elif 'GHS av' in miner_summary['SUMMARY'][0].keys():
|
||||||
hashrate = format(
|
hashrate = format(
|
||||||
round(miner_summary['SUMMARY'][0]['GHS av'] / 1000, 2),
|
round(miner_summary['SUMMARY'][0]['GHS av'] / 1000,
|
||||||
|
2),
|
||||||
".2f")
|
".2f")
|
||||||
else:
|
else:
|
||||||
hashrate = 0
|
hashrate = 0
|
||||||
@@ -164,7 +173,8 @@ async def miner_websocket(websocket: WebSocket, miner_ip):
|
|||||||
await asyncio.sleep(.5)
|
await asyncio.sleep(.5)
|
||||||
except KeyError as e:
|
except KeyError as e:
|
||||||
print(e)
|
print(e)
|
||||||
data = {"error": "The miner returned unusable/unsupported data."}
|
data = {
|
||||||
|
"error": "The miner returned unusable/unsupported data."}
|
||||||
await websocket.send_json(data)
|
await websocket.send_json(data)
|
||||||
await asyncio.sleep(.5)
|
await asyncio.sleep(.5)
|
||||||
except WebSocketDisconnect:
|
except WebSocketDisconnect:
|
||||||
@@ -173,7 +183,6 @@ async def miner_websocket(websocket: WebSocket, miner_ip):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@app.get("/miner/{miner_ip}")
|
@app.get("/miner/{miner_ip}")
|
||||||
def get_miner(request: Request, miner_ip):
|
def get_miner(request: Request, miner_ip):
|
||||||
return templates.TemplateResponse("miner.html", {
|
return templates.TemplateResponse("miner.html", {
|
||||||
@@ -183,18 +192,17 @@ def get_miner(request: Request, miner_ip):
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
@app.get("/miner/{miner_ip}/remove")
|
@app.get("/miner_ip/{miner_ip}/remove")
|
||||||
def get_miner(request: Request, miner_ip):
|
def get_miner(request: Request, miner_ip):
|
||||||
miners = get_current_miner_list()
|
miners = get_current_miner_list()
|
||||||
miners.remove(miner_ip)
|
miners.remove(miner_ip)
|
||||||
with open("miner_list.txt", "w") as file:
|
with open("miner_list.txt", "w") as file:
|
||||||
for miner in miners:
|
for miner_ip in miners:
|
||||||
file.write(miner + "\n")
|
file.write(miner_ip + "\n")
|
||||||
|
|
||||||
return RedirectResponse(request.url_for('dashboard'))
|
return RedirectResponse(request.url_for('dashboard'))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def get_current_miner_list():
|
def get_current_miner_list():
|
||||||
cur_miners = []
|
cur_miners = []
|
||||||
if os.path.exists(os.path.join(os.getcwd(), "miner_list.txt")):
|
if os.path.exists(os.path.join(os.getcwd(), "miner_list.txt")):
|
||||||
@@ -209,8 +217,8 @@ def get_current_miner_list():
|
|||||||
async def add_miners_scan(request: Request):
|
async def add_miners_scan(request: Request):
|
||||||
miners = await request.json()
|
miners = await request.json()
|
||||||
with open("miner_list.txt", "a+") as file:
|
with open("miner_list.txt", "a+") as file:
|
||||||
for miner in miners["miners"]:
|
for miner_ip in miners["miners"]:
|
||||||
file.write(miner + "\n")
|
file.write(miner_ip + "\n")
|
||||||
return scan
|
return scan
|
||||||
|
|
||||||
|
|
||||||
@@ -230,7 +238,8 @@ async def websocket_scan(websocket: WebSocket):
|
|||||||
cur_task = None
|
cur_task = None
|
||||||
await websocket.send_text("Cancelled")
|
await websocket.send_text("Cancelled")
|
||||||
else:
|
else:
|
||||||
cur_task = asyncio.create_task(do_websocket_scan(websocket, ws_data))
|
cur_task = asyncio.create_task(
|
||||||
|
do_websocket_scan(websocket, ws_data))
|
||||||
if cur_task and cur_task.done():
|
if cur_task and cur_task.done():
|
||||||
cur_task = None
|
cur_task = None
|
||||||
except WebSocketDisconnect:
|
except WebSocketDisconnect:
|
||||||
@@ -249,9 +258,9 @@ async def do_websocket_scan(websocket: WebSocket, network_ip: str):
|
|||||||
network = MinerNetwork(network_ip)
|
network = MinerNetwork(network_ip)
|
||||||
miner_generator = network.scan_network_generator()
|
miner_generator = network.scan_network_generator()
|
||||||
miners = []
|
miners = []
|
||||||
async for miner in miner_generator:
|
async for miner_ip in miner_generator:
|
||||||
if miner and str(miner) not in cur_miners:
|
if miner_ip and str(miner_ip) not in cur_miners:
|
||||||
miners.append(miner)
|
miners.append(miner_ip)
|
||||||
|
|
||||||
get_miner_genenerator = miner_factory.get_miner_generator(miners)
|
get_miner_genenerator = miner_factory.get_miner_generator(miners)
|
||||||
all_miners = []
|
all_miners = []
|
||||||
@@ -260,13 +269,14 @@ async def do_websocket_scan(websocket: WebSocket, network_ip: str):
|
|||||||
{"ip": found_miner.ip, "model": await found_miner.get_model()})
|
{"ip": found_miner.ip, "model": await found_miner.get_model()})
|
||||||
all_miners.sort(key=lambda x: x["ip"])
|
all_miners.sort(key=lambda x: x["ip"])
|
||||||
send_miners = []
|
send_miners = []
|
||||||
for miner in all_miners:
|
for miner_ip in all_miners:
|
||||||
send_miners.append(
|
send_miners.append(
|
||||||
{"ip": str(miner["ip"]), "model": miner["model"]})
|
{"ip": str(miner_ip["ip"]), "model": miner_ip["model"]})
|
||||||
await websocket.send_json(send_miners)
|
await websocket.send_json(send_miners)
|
||||||
await websocket.send_text("Done")
|
await websocket.send_text("Done")
|
||||||
except asyncio.CancelledError:
|
except asyncio.CancelledError:
|
||||||
raise
|
raise
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
uvicorn.run("app:app", host="127.0.0.1", port=80)
|
uvicorn.run("app:app", host="127.0.0.1", port=80)
|
||||||
|
|||||||
Reference in New Issue
Block a user