update_manager: auto-refresh fix
Only refresh a provider when the update interval has expired. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
56a98aa8ed
commit
08111415be
|
@ -180,7 +180,7 @@ class UpdateManager:
|
||||||
ret = updater.refresh()
|
ret = updater.refresh()
|
||||||
await ret
|
await ret
|
||||||
if self.refresh_timer is not None:
|
if self.refresh_timer is not None:
|
||||||
self.refresh_timer.start()
|
self.refresh_timer.start(delay=UPDATE_REFRESH_INTERVAL)
|
||||||
|
|
||||||
async def _set_klipper_repo(self) -> None:
|
async def _set_klipper_repo(self) -> None:
|
||||||
if self.klippy_identified_evt is not None:
|
if self.klippy_identified_evt is not None:
|
||||||
|
@ -225,7 +225,7 @@ class UpdateManager:
|
||||||
return pstate.lower() == "printing"
|
return pstate.lower() == "printing"
|
||||||
|
|
||||||
async def _handle_auto_refresh(self, eventtime: float) -> float:
|
async def _handle_auto_refresh(self, eventtime: float) -> float:
|
||||||
cur_hour = time.localtime(eventtime).tm_hour
|
cur_hour = time.localtime(time.time()).tm_hour
|
||||||
# Update when the local time is between 12AM and 5AM
|
# Update when the local time is between 12AM and 5AM
|
||||||
if cur_hour >= MAX_UPDATE_HOUR:
|
if cur_hour >= MAX_UPDATE_HOUR:
|
||||||
return eventtime + UPDATE_REFRESH_INTERVAL
|
return eventtime + UPDATE_REFRESH_INTERVAL
|
||||||
|
@ -234,14 +234,18 @@ class UpdateManager:
|
||||||
logging.info("Klippy is printing, auto refresh aborted")
|
logging.info("Klippy is printing, auto refresh aborted")
|
||||||
return eventtime + UPDATE_REFRESH_INTERVAL
|
return eventtime + UPDATE_REFRESH_INTERVAL
|
||||||
vinfo: Dict[str, Any] = {}
|
vinfo: Dict[str, Any] = {}
|
||||||
|
need_notify = False
|
||||||
async with self.cmd_request_lock:
|
async with self.cmd_request_lock:
|
||||||
try:
|
try:
|
||||||
for name, updater in list(self.updaters.items()):
|
for name, updater in list(self.updaters.items()):
|
||||||
|
if updater.needs_refresh():
|
||||||
await updater.refresh()
|
await updater.refresh()
|
||||||
|
need_notify = True
|
||||||
vinfo[name] = updater.get_update_status()
|
vinfo[name] = updater.get_update_status()
|
||||||
except Exception:
|
except Exception:
|
||||||
logging.exception("Unable to Refresh Status")
|
logging.exception("Unable to Refresh Status")
|
||||||
return eventtime + UPDATE_REFRESH_INTERVAL
|
return eventtime + UPDATE_REFRESH_INTERVAL
|
||||||
|
if need_notify:
|
||||||
uinfo = self.cmd_helper.get_rate_limit_stats()
|
uinfo = self.cmd_helper.get_rate_limit_stats()
|
||||||
uinfo['version_info'] = vinfo
|
uinfo['version_info'] = vinfo
|
||||||
uinfo['busy'] = self.cmd_helper.is_update_busy()
|
uinfo['busy'] = self.cmd_helper.is_update_busy()
|
||||||
|
|
Loading…
Reference in New Issue