Files
WPIQ/wo/cli/plugins/maintenance.py

45 lines
1.4 KiB
Python
Raw Normal View History

2019-07-14 22:50:34 +02:00
"""Maintenance Plugin for WordOps"""
from cement.core.controller import CementBaseController, expose
2019-09-04 20:36:15 +02:00
2019-07-14 22:50:34 +02:00
from wo.core.aptget import WOAptGet
from wo.core.logging import Log
2019-07-14 22:50:34 +02:00
def wo_maintenance_hook(app):
pass
class WOMaintenanceController(CementBaseController):
class Meta:
label = 'maintenance'
stacked_on = 'base'
stacked_type = 'nested'
description = ('update server packages to latest version')
usage = "wo maintenance"
@expose(hide=True)
def default(self):
try:
Log.info(self, "updating apt-cache, please wait...")
WOAptGet.update(self)
2019-07-14 22:50:34 +02:00
Log.info(self, "updating packages, please wait...")
WOAptGet.dist_upgrade(self)
2019-07-14 22:50:34 +02:00
Log.info(self, "cleaning-up packages, please wait...")
WOAptGet.auto_remove(self)
WOAptGet.auto_clean(self)
2019-07-14 22:50:34 +02:00
except OSError as e:
Log.debug(self, str(e))
Log.error(self, "Package updates failed !")
except Exception as e:
Log.debug(self, str(e))
Log.error(self, "Packages updates failed !")
def load(app):
# register the plugin class.. this only happens if the plugin is enabled
2019-09-24 00:01:20 +02:00
app.handler.register(WOMaintenanceController)
2019-07-14 22:50:34 +02:00
# register a hook (function) to run after arguments are parsed.
2019-09-24 00:04:32 +02:00
app.hook.register('post_argument_parsing', wo_maintenance_hook)