update_manager: report system package info

Report available package count and a list of available packages.

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Arksine 2020-12-30 07:36:38 -05:00
parent 1acb00e2f1
commit 8fc5aab2f0
1 changed files with 36 additions and 6 deletions

View File

@ -126,7 +126,7 @@ class UpdateManager:
refresh = web_request.get_boolean('refresh', False) refresh = web_request.get_boolean('refresh', False)
vinfo = {} vinfo = {}
for name, updater in self.updaters.items(): for name, updater in self.updaters.items():
await updater.check_initialized(10.) await updater.check_initialized(120.)
if refresh: if refresh:
ret = updater.refresh() ret = updater.refresh()
if asyncio.iscoroutine(ret): if asyncio.iscoroutine(ret):
@ -577,15 +577,38 @@ class PackageUpdater:
def __init__(self, umgr): def __init__(self, umgr):
self.server = umgr.server self.server = umgr.server
self.execute_cmd = umgr.execute_cmd self.execute_cmd = umgr.execute_cmd
self.execute_cmd_with_response = umgr.execute_cmd_with_response
self.notify_update_response = umgr.notify_update_response self.notify_update_response = umgr.notify_update_response
self.available_packages = []
self.init_evt = Event()
IOLoop.current().spawn_callback(self.refresh)
def refresh(self): async def refresh(self):
# TODO: We should be able to determine if packages need to be # TODO: Use python-apt python lib rather than command line for updates
# updated here try:
pass await self.execute_cmd(f"{APT_CMD} update", timeout=300.)
res = await self.execute_cmd_with_response(
"apt list --upgradable")
except Exception:
logging.exception("Error Refreshing System Packages")
else:
pkg_list = [p.strip() for p in res.split("\n") if p.strip()]
if pkg_list:
pkg_list = pkg_list[2:]
self.available_packages = [p.split("/", maxsplit=1)[0]
for p in pkg_list]
pkg_list = "\n".join(self.available_packages)
logging.info(
f"Detected {len(self.available_packages)} package updates:"
f"\n{pkg_list}")
self.init_evt.set()
async def check_initialized(self, timeout=None): async def check_initialized(self, timeout=None):
pass if self.init_evt.is_set():
return
if timeout is not None:
timeout = IOLoop.current().time() + timeout
await self.init_evt.wait(timeout)
async def update(self, *args): async def update(self, *args):
self.notify_update_response("Updating packages...") self.notify_update_response("Updating packages...")
@ -596,9 +619,16 @@ class PackageUpdater:
f"{APT_CMD} upgrade --yes", timeout=3600., notify=True) f"{APT_CMD} upgrade --yes", timeout=3600., notify=True)
except Exception: except Exception:
raise self.server.error("Error updating system packages") raise self.server.error("Error updating system packages")
self.available_packages = []
self.notify_update_response("Package update finished...", self.notify_update_response("Package update finished...",
is_complete=True) is_complete=True)
def get_update_status(self):
return {
'package_count': len(self.available_packages),
'package_list': self.available_packages
}
class ClientUpdater: class ClientUpdater:
def __init__(self, umgr, repo, path): def __init__(self, umgr, repo, path):
self.umgr = umgr self.umgr = umgr