update_manager: make auto refresh optional
Decrease the frequency of auto updates roughly every 24 hours. The manager will attempt to update once between 12am and 4am. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
578ce740c5
commit
19bc2bfbb8
|
@ -25,12 +25,12 @@ SUPPLEMENTAL_CFG_PATH = os.path.join(
|
||||||
APT_CMD = "sudo DEBIAN_FRONTEND=noninteractive apt-get"
|
APT_CMD = "sudo DEBIAN_FRONTEND=noninteractive apt-get"
|
||||||
SUPPORTED_DISTROS = ["debian"]
|
SUPPORTED_DISTROS = ["debian"]
|
||||||
|
|
||||||
# Check For Updates Every 2 Hours
|
# Check To see if Updates are necessary each hour
|
||||||
UPDATE_REFRESH_TIME = 7200000
|
UPDATE_REFRESH_INTERVAL_MS = 3600000
|
||||||
# Refresh APT Repo no sooner than 12 hours
|
# Perform auto refresh no sooner than 12 hours apart
|
||||||
MIN_PKG_UPDATE_INTERVAL = 43200
|
MIN_REFRESH_TIME = 43200
|
||||||
# Refresh APT Repo no later than 5am
|
# Perform auto refresh no later than 4am
|
||||||
MAX_PKG_UPDATE_HOUR = 5
|
MAX_PKG_UPDATE_HOUR = 4
|
||||||
|
|
||||||
class UpdateManager:
|
class UpdateManager:
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
|
@ -38,6 +38,7 @@ class UpdateManager:
|
||||||
self.config = config
|
self.config = config
|
||||||
self.config.read_supplemental_config(SUPPLEMENTAL_CFG_PATH)
|
self.config.read_supplemental_config(SUPPLEMENTAL_CFG_PATH)
|
||||||
self.repo_debug = config.getboolean('enable_repo_debug', False)
|
self.repo_debug = config.getboolean('enable_repo_debug', False)
|
||||||
|
auto_refresh_enabled = config.getboolean('enable_auto_refresh', False)
|
||||||
self.distro = config.get('distro', "debian").lower()
|
self.distro = config.get('distro', "debian").lower()
|
||||||
if self.distro not in SUPPORTED_DISTROS:
|
if self.distro not in SUPPORTED_DISTROS:
|
||||||
raise config.error(f"Unsupported distro: {self.distro}")
|
raise config.error(f"Unsupported distro: {self.distro}")
|
||||||
|
@ -84,9 +85,11 @@ class UpdateManager:
|
||||||
self.is_refreshing = False
|
self.is_refreshing = False
|
||||||
|
|
||||||
# Auto Status Refresh
|
# Auto Status Refresh
|
||||||
self.last_package_refresh_time = 0
|
self.last_auto_update_time = 0
|
||||||
|
self.refresh_cb = None
|
||||||
|
if auto_refresh_enabled:
|
||||||
self.refresh_cb = PeriodicCallback(
|
self.refresh_cb = PeriodicCallback(
|
||||||
self._handle_auto_refresh, UPDATE_REFRESH_TIME)
|
self._handle_auto_refresh, UPDATE_REFRESH_INTERVAL_MS)
|
||||||
self.refresh_cb.start()
|
self.refresh_cb.start()
|
||||||
|
|
||||||
AsyncHTTPClient.configure(None, defaults=dict(user_agent="Moonraker"))
|
AsyncHTTPClient.configure(None, defaults=dict(user_agent="Moonraker"))
|
||||||
|
@ -116,11 +119,16 @@ class UpdateManager:
|
||||||
self._initalize_updaters, list(self.updaters.values()))
|
self._initalize_updaters, list(self.updaters.values()))
|
||||||
|
|
||||||
async def _initalize_updaters(self, initial_updaters):
|
async def _initalize_updaters(self, initial_updaters):
|
||||||
|
self.is_refreshing = True
|
||||||
await self._init_api_rate_limit()
|
await self._init_api_rate_limit()
|
||||||
for updater in initial_updaters:
|
for updater in initial_updaters:
|
||||||
|
if isinstance(updater, PackageUpdater):
|
||||||
|
ret = updater.refresh(False)
|
||||||
|
else:
|
||||||
ret = updater.refresh()
|
ret = updater.refresh()
|
||||||
if asyncio.iscoroutine(ret):
|
if asyncio.iscoroutine(ret):
|
||||||
await updater.refresh()
|
await updater.refresh()
|
||||||
|
self.is_refreshing = False
|
||||||
|
|
||||||
async def _set_klipper_repo(self):
|
async def _set_klipper_repo(self):
|
||||||
kinfo = self.server.get_klippy_info()
|
kinfo = self.server.get_klippy_info()
|
||||||
|
@ -150,26 +158,21 @@ class UpdateManager:
|
||||||
# Don't Refresh during a print
|
# Don't Refresh during a print
|
||||||
logging.info("Klippy is printing, auto refresh aborted")
|
logging.info("Klippy is printing, auto refresh aborted")
|
||||||
return
|
return
|
||||||
|
cur_time = time.time()
|
||||||
|
cur_hour = time.localtime(cur_time).tm_hour
|
||||||
|
time_diff = cur_time - self.last_auto_update_time
|
||||||
|
# Update packages if it has been more than 12 hours
|
||||||
|
# and the local time is between 12AM and 5AM
|
||||||
|
if time_diff < MIN_REFRESH_TIME or cur_hour >= MAX_PKG_UPDATE_HOUR:
|
||||||
|
# Not within the update time window
|
||||||
|
return
|
||||||
|
self.last_auto_update_time = cur_time
|
||||||
vinfo = {}
|
vinfo = {}
|
||||||
need_refresh_all = not self.is_refreshing
|
need_refresh_all = not self.is_refreshing
|
||||||
async with self.cmd_request_lock:
|
async with self.cmd_request_lock:
|
||||||
self.is_refreshing = True
|
self.is_refreshing = True
|
||||||
cur_time = time.time()
|
|
||||||
cur_hour = time.localtime(cur_time).tm_hour
|
|
||||||
time_diff = cur_time - self.last_package_refresh_time
|
|
||||||
try:
|
try:
|
||||||
# Update packages if it has been more than 12 hours
|
|
||||||
# and the local time is between 12AM and 5AM
|
|
||||||
if time_diff > MIN_PKG_UPDATE_INTERVAL and \
|
|
||||||
cur_hour <= MAX_PKG_UPDATE_HOUR:
|
|
||||||
self.last_package_refresh_time = cur_time
|
|
||||||
sys_updater = self.updaters['system']
|
|
||||||
await sys_updater.refresh(True)
|
|
||||||
vinfo['system'] = sys_updater.get_update_status()
|
|
||||||
for name, updater in list(self.updaters.items()):
|
for name, updater in list(self.updaters.items()):
|
||||||
if name in vinfo:
|
|
||||||
# System was refreshed and added to version info
|
|
||||||
continue
|
|
||||||
if need_refresh_all:
|
if need_refresh_all:
|
||||||
ret = updater.refresh()
|
ret = updater.refresh()
|
||||||
if asyncio.iscoroutine(ret):
|
if asyncio.iscoroutine(ret):
|
||||||
|
@ -399,6 +402,7 @@ class UpdateManager:
|
||||||
|
|
||||||
def close(self):
|
def close(self):
|
||||||
self.http_client.close()
|
self.http_client.close()
|
||||||
|
if self.refresh_cb is not None:
|
||||||
self.refresh_cb.stop()
|
self.refresh_cb.stop()
|
||||||
|
|
||||||
|
|
||||||
|
@ -768,7 +772,7 @@ class PackageUpdater:
|
||||||
self.init_evt = Event()
|
self.init_evt = Event()
|
||||||
self.refresh_condition = None
|
self.refresh_condition = None
|
||||||
|
|
||||||
async def refresh(self, fetch_packages=False):
|
async def refresh(self, fetch_packages=True):
|
||||||
# TODO: Use python-apt python lib rather than command line for updates
|
# TODO: Use python-apt python lib rather than command line for updates
|
||||||
if self.refresh_condition is None:
|
if self.refresh_condition is None:
|
||||||
self.refresh_condition = Condition()
|
self.refresh_condition = Condition()
|
||||||
|
|
Loading…
Reference in New Issue