fix is_mining for ePIC
This commit is contained in:
@@ -74,6 +74,10 @@ EPIC_DATA_LOC = DataLocations(
|
|||||||
"_get_uptime",
|
"_get_uptime",
|
||||||
[WebAPICommand("web_summary", "summary")],
|
[WebAPICommand("web_summary", "summary")],
|
||||||
),
|
),
|
||||||
|
str(DataOptions.IS_MINING): DataFunction(
|
||||||
|
"_is_mining",
|
||||||
|
[WebAPICommand("web_summary", "summary")],
|
||||||
|
),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -313,8 +317,22 @@ class ePIC(BaseMiner):
|
|||||||
hb_list[hb["Index"]].temp = hb["Temperature"]
|
hb_list[hb["Index"]].temp = hb["Temperature"]
|
||||||
return hb_list
|
return hb_list
|
||||||
|
|
||||||
async def _is_mining(self, *args, **kwargs) -> Optional[bool]:
|
async def _is_mining(self, web_summary, *args, **kwargs) -> Optional[bool]:
|
||||||
return None
|
if web_summary is None:
|
||||||
|
try:
|
||||||
|
web_summary = await self.web.summary()
|
||||||
|
except APIError:
|
||||||
|
pass
|
||||||
|
if web_summary is not None:
|
||||||
|
try:
|
||||||
|
op_state = web_summary["Status"]["Operating State"]
|
||||||
|
except KeyError:
|
||||||
|
return None
|
||||||
|
pass
|
||||||
|
if op_state != "Idling":
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
async def _get_uptime(self, web_summary: dict = None) -> Optional[int]:
|
async def _get_uptime(self, web_summary: dict = None) -> Optional[int]:
|
||||||
if web_summary is None:
|
if web_summary is None:
|
||||||
|
|||||||
Reference in New Issue
Block a user