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

83 lines
2.8 KiB
Python
Raw Normal View History

2019-04-26 21:30:46 +02:00
import os
import time
2018-11-13 21:55:59 +01:00
from cement.core import handler, hook
2019-04-26 21:30:46 +02:00
from cement.core.controller import CementBaseController, expose
2018-11-13 21:55:59 +01:00
from wo.core.download import WODownload
from wo.core.logging import Log
def wo_update_hook(app):
pass
class WOUpdateController(CementBaseController):
class Meta:
label = 'wo_update'
stacked_on = 'base'
aliases = ['update']
aliases_only = True
2018-11-13 21:55:59 +01:00
stacked_type = 'nested'
description = ('update WordOps to latest version')
arguments = [
(['--force'],
dict(help='Force WordOps update', action='store_true')),
2019-06-18 14:35:05 +02:00
(['--preserve'],
dict(help='Preserve current Nginx configuration',
action='store_true')),
2019-07-19 00:57:32 +02:00
(['--beta'],
dict(help='Update WordOps to latest beta release',
action='store_true')),
2019-06-17 11:44:46 +02:00
(['--travis'],
dict(help='Argument used only for WordOps development',
action='store_true')),
]
usage = "wo update [options]"
2018-11-13 21:55:59 +01:00
@expose(hide=True)
def default(self):
2019-08-07 02:45:26 +02:00
pargs = self.app.pargs
2018-11-13 21:55:59 +01:00
filename = "woupdate" + time.strftime("%Y%m%d-%H%M%S")
2019-06-17 11:56:33 +02:00
2019-08-21 15:02:55 +02:00
if pargs.beta:
2019-07-19 00:57:32 +02:00
wo_branch = "beta"
install_args = ""
2019-06-16 23:03:12 +02:00
else:
2019-07-23 14:42:17 +02:00
wo_branch = "master"
2019-07-19 00:57:32 +02:00
install_args = ""
2019-08-07 02:45:26 +02:00
if pargs.force:
2019-07-19 00:57:32 +02:00
install_args = install_args + "--force "
2019-08-07 02:45:26 +02:00
if pargs.preserve:
2019-07-19 00:57:32 +02:00
install_args = install_args + "--preserve "
WODownload.download(self, [["https://raw.githubusercontent.com/"
"WordOps/WordOps/{0}/install"
.format(wo_branch),
"/var/lib/wo/tmp/{0}".format(filename),
"update script"]])
2019-08-21 15:02:55 +02:00
if pargs.travis:
try:
Log.info(self, "updating WordOps, please wait...")
os.system("/bin/bash install --travis "
"-b $TRAVIS_BRANCH --force")
except OSError as e:
Log.debug(self, str(e))
Log.error(self, "WordOps update failed !")
else:
try:
Log.info(self, "updating WordOps, please wait...")
os.system("/bin/bash /var/lib/wo/tmp/{0} "
"-b {1} {2}".format(filename,
wo_branch, install_args))
except OSError as e:
Log.debug(self, str(e))
Log.error(self, "WordOps update failed !")
2018-11-13 21:55:59 +01:00
def load(app):
# register the plugin class.. this only happens if the plugin is enabled
handler.register(WOUpdateController)
# register a hook (function) to run after arguments are parsed.
hook.register('post_argument_parsing', wo_update_hook)