add mac addresses for bosminer, and reformat
This commit is contained in:
@@ -4,7 +4,6 @@ import toml
|
|||||||
from config.bos import bos_config_convert, general_config_convert_bos
|
from config.bos import bos_config_convert, general_config_convert_bos
|
||||||
import logging
|
import logging
|
||||||
from settings import MINER_FACTORY_GET_VERSION_RETRIES as DATA_RETRIES
|
from settings import MINER_FACTORY_GET_VERSION_RETRIES as DATA_RETRIES
|
||||||
import asyncssh
|
|
||||||
|
|
||||||
|
|
||||||
class BOSMiner(BaseMiner):
|
class BOSMiner(BaseMiner):
|
||||||
@@ -371,41 +370,6 @@ class BOSMiner(BaseMiner):
|
|||||||
|
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
async def get_mac(self):
|
||||||
class BOSMinerOld(BaseMiner):
|
result = await self.send_ssh_command("cat /sys/class/net/eth0/address")
|
||||||
def __init__(self, ip: str) -> None:
|
return result.upper()
|
||||||
super().__init__(ip)
|
|
||||||
self.api = BOSMinerAPI(ip)
|
|
||||||
self.api_type = "BOSMiner"
|
|
||||||
self.uname = "root"
|
|
||||||
self.pwd = "admin"
|
|
||||||
|
|
||||||
async def send_ssh_command(self, cmd: str) -> str or None:
|
|
||||||
"""Send a command to the miner over ssh.
|
|
||||||
|
|
||||||
:return: Result of the command or None.
|
|
||||||
"""
|
|
||||||
result = None
|
|
||||||
|
|
||||||
# open an ssh connection
|
|
||||||
async with await asyncssh.connect("192.168.1.11", username="root") as conn:
|
|
||||||
# 3 retries
|
|
||||||
for i in range(3):
|
|
||||||
try:
|
|
||||||
# run the command and get the result
|
|
||||||
result = await conn.run(cmd)
|
|
||||||
result = result.stdout
|
|
||||||
except Exception as e:
|
|
||||||
# if the command fails, log it
|
|
||||||
logging.warning(f"{self} command {cmd} error: {e}")
|
|
||||||
|
|
||||||
# on the 3rd retry, return None
|
|
||||||
if i == 3:
|
|
||||||
return
|
|
||||||
continue
|
|
||||||
# return the result, either command output or None
|
|
||||||
return str(result)
|
|
||||||
|
|
||||||
async def update_to_plus(self):
|
|
||||||
result = await self.send_ssh_command("opkg update && opkg install bos_plus")
|
|
||||||
return result
|
|
||||||
|
|||||||
46
miners/_backends/bosminer_old.py
Normal file
46
miners/_backends/bosminer_old.py
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
from miners import BaseMiner
|
||||||
|
from API.bosminer import BOSMinerAPI
|
||||||
|
import toml
|
||||||
|
from config.bos import bos_config_convert, general_config_convert_bos
|
||||||
|
import logging
|
||||||
|
from settings import MINER_FACTORY_GET_VERSION_RETRIES as DATA_RETRIES
|
||||||
|
import asyncssh
|
||||||
|
|
||||||
|
|
||||||
|
class BOSMinerOld(BaseMiner):
|
||||||
|
def __init__(self, ip: str) -> None:
|
||||||
|
super().__init__(ip)
|
||||||
|
self.api = BOSMinerAPI(ip)
|
||||||
|
self.api_type = "BOSMiner"
|
||||||
|
self.uname = "root"
|
||||||
|
self.pwd = "admin"
|
||||||
|
|
||||||
|
async def send_ssh_command(self, cmd: str) -> str or None:
|
||||||
|
"""Send a command to the miner over ssh.
|
||||||
|
|
||||||
|
:return: Result of the command or None.
|
||||||
|
"""
|
||||||
|
result = None
|
||||||
|
|
||||||
|
# open an ssh connection
|
||||||
|
async with await asyncssh.connect("192.168.1.11", username="root") as conn:
|
||||||
|
# 3 retries
|
||||||
|
for i in range(3):
|
||||||
|
try:
|
||||||
|
# run the command and get the result
|
||||||
|
result = await conn.run(cmd)
|
||||||
|
result = result.stdout
|
||||||
|
except Exception as e:
|
||||||
|
# if the command fails, log it
|
||||||
|
logging.warning(f"{self} command {cmd} error: {e}")
|
||||||
|
|
||||||
|
# on the 3rd retry, return None
|
||||||
|
if i == 3:
|
||||||
|
return
|
||||||
|
continue
|
||||||
|
# return the result, either command output or None
|
||||||
|
return str(result)
|
||||||
|
|
||||||
|
async def update_to_plus(self):
|
||||||
|
result = await self.send_ssh_command("opkg update && opkg install bos_plus")
|
||||||
|
return result
|
||||||
@@ -6,7 +6,7 @@ from miners._backends.cgminer import CGMiner
|
|||||||
from miners._backends.bmminer import BMMiner
|
from miners._backends.bmminer import BMMiner
|
||||||
from miners._backends.bosminer import BOSMiner
|
from miners._backends.bosminer import BOSMiner
|
||||||
from miners._backends.btminer import BTMiner
|
from miners._backends.btminer import BTMiner
|
||||||
from miners._backends.bosminer import BOSMinerOld
|
from miners._backends.bosminer_old import BOSMinerOld
|
||||||
|
|
||||||
from miners.unknown import UnknownMiner
|
from miners.unknown import UnknownMiner
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user