|
|
@ -3,6 +3,7 @@ from cement.core import handler, hook |
|
|
|
from ee.core.services import EEService |
|
|
|
from ee.core.logging import Log |
|
|
|
from ee.core.variables import EEVariables |
|
|
|
from ee.core.aptget import EEAptGet |
|
|
|
|
|
|
|
|
|
|
|
class EEStackStatusController(CementBaseController): |
|
|
@ -22,158 +23,282 @@ class EEStackStatusController(CementBaseController): |
|
|
|
def start(self): |
|
|
|
"""Start services""" |
|
|
|
services = [] |
|
|
|
if not (self.app.pargs.nginx or self.app.pargs.php |
|
|
|
or self.app.pargs.mysql or self.app.pargs.postfix |
|
|
|
or self.app.pargs.hhvm or self.app.pargs.memcache |
|
|
|
or self.app.pargs.dovecot): |
|
|
|
self.app.pargs.nginx = True |
|
|
|
self.app.pargs.php = True |
|
|
|
self.app.pargs.mysql = True |
|
|
|
self.app.pargs.postfix = True |
|
|
|
self.app.pargs.hhvm = True |
|
|
|
|
|
|
|
if self.app.pargs.nginx: |
|
|
|
Log.debug(self, "nginx service start") |
|
|
|
if EEVariables.ee_platform_distro == 'debian': |
|
|
|
check_nginx = 'nginx-extras' |
|
|
|
else: |
|
|
|
check_nginx = 'nginx-custom' |
|
|
|
|
|
|
|
if EEAptGet.is_installed(self, check_nginx): |
|
|
|
services = services + ['nginx'] |
|
|
|
else: |
|
|
|
Log.info(self, "Nginx is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.php: |
|
|
|
Log.debug(self, "php5-fpm service start") |
|
|
|
if EEAptGet.is_installed(self, 'php5-fpm'): |
|
|
|
services = services + ['php5-fpm'] |
|
|
|
else: |
|
|
|
Log.info(self, "PHP5-FPM is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.mysql: |
|
|
|
if EEVariables.ee_mysql_host is "localhost": |
|
|
|
Log.debug(self, "mysql service start") |
|
|
|
if ((EEVariables.ee_mysql_host is "localhost") or |
|
|
|
(EEVariables.ee_mysql_host is "127.0.0.1")): |
|
|
|
if (EEAptGet.is_installed(self, 'mysql-server') or |
|
|
|
EEAptGet.is_installed(self, 'percona-server-server-5.6') or |
|
|
|
EEAptGet.is_installed(self, 'mariadb-server')): |
|
|
|
services = services + ['mysql'] |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found," |
|
|
|
"unable to start MySQL service") |
|
|
|
Log.info(self, "MySQL is not installed") |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found, " |
|
|
|
"Unable to check MySQL service status") |
|
|
|
|
|
|
|
if self.app.pargs.postfix: |
|
|
|
Log.debug(self, "postfix service start") |
|
|
|
if EEAptGet.is_installed(self, 'postfix'): |
|
|
|
services = services + ['postfix'] |
|
|
|
else: |
|
|
|
Log.info(self, "Postfix is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.hhvm: |
|
|
|
if EEAptGet.is_installed(self, 'hhvm'): |
|
|
|
services = services + ['hhvm'] |
|
|
|
Log.debug(self, "hhvm service start") |
|
|
|
else: |
|
|
|
Log.info(self, "HHVM is not installed") |
|
|
|
if self.app.pargs.memcache: |
|
|
|
Log.debug(self, "memcached service start") |
|
|
|
if EEAptGet.is_installed(self, 'memcached'): |
|
|
|
services = services + ['memcached'] |
|
|
|
else: |
|
|
|
Log.info(self, "Memcache is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.dovecot: |
|
|
|
Log.debug(self, "dovecot service start") |
|
|
|
if EEAptGet.is_installed(self, 'dovecot-core'): |
|
|
|
services = services + ['dovecot'] |
|
|
|
if not services and EEVariables.ee_mysql_host is "localhost": |
|
|
|
services = services + ['nginx', 'php5-fpm', 'mysql', 'postfix', |
|
|
|
'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,mysql,postfix,hhvm services start") |
|
|
|
elif not services: |
|
|
|
services = services + ['nginx', 'php5-fpm', 'postfix', 'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,postfix,hhvm services start") |
|
|
|
else: |
|
|
|
Log.info(self, "Mail server is not installed") |
|
|
|
|
|
|
|
for service in services: |
|
|
|
Log.debug(self, "Starting service: {0}".format(service)) |
|
|
|
EEService.start_service(self, service) |
|
|
|
|
|
|
|
@expose(help="Stop stack services") |
|
|
|
def stop(self): |
|
|
|
"""Stop services""" |
|
|
|
services = [] |
|
|
|
if not (self.app.pargs.nginx or self.app.pargs.php |
|
|
|
or self.app.pargs.mysql or self.app.pargs.postfix |
|
|
|
or self.app.pargs.hhvm or self.app.pargs.memcache |
|
|
|
or self.app.pargs.dovecot): |
|
|
|
self.app.pargs.nginx = True |
|
|
|
self.app.pargs.php = True |
|
|
|
self.app.pargs.mysql = True |
|
|
|
self.app.pargs.postfix = True |
|
|
|
self.app.pargs.hhvm = True |
|
|
|
|
|
|
|
if self.app.pargs.nginx: |
|
|
|
Log.debug(self, "nginx service stop") |
|
|
|
if EEVariables.ee_platform_distro == 'debian': |
|
|
|
check_nginx = 'nginx-extras' |
|
|
|
else: |
|
|
|
check_nginx = 'nginx-custom' |
|
|
|
|
|
|
|
if EEAptGet.is_installed(self, check_nginx): |
|
|
|
services = services + ['nginx'] |
|
|
|
else: |
|
|
|
Log.info(self, "Nginx is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.php: |
|
|
|
Log.debug(self, "php5-fpm service stop") |
|
|
|
if EEAptGet.is_installed(self, 'php5-fpm'): |
|
|
|
services = services + ['php5-fpm'] |
|
|
|
else: |
|
|
|
Log.info(self, "PHP5-FPM is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.mysql: |
|
|
|
if EEVariables.ee_mysql_host is "localhost": |
|
|
|
Log.debug(self, "mysql service stop") |
|
|
|
if ((EEVariables.ee_mysql_host is "localhost") or |
|
|
|
(EEVariables.ee_mysql_host is "127.0.0.1")): |
|
|
|
if (EEAptGet.is_installed(self, 'mysql-server') or |
|
|
|
EEAptGet.is_installed(self, 'percona-server-server-5.6') or |
|
|
|
EEAptGet.is_installed(self, 'mariadb-server')): |
|
|
|
services = services + ['mysql'] |
|
|
|
else: |
|
|
|
Log.info(self, "MySQL is not installed") |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found, " |
|
|
|
"unable to stop MySQL service") |
|
|
|
"Unable to check MySQL service status") |
|
|
|
|
|
|
|
if self.app.pargs.postfix: |
|
|
|
Log.debug(self, "postfix service stop") |
|
|
|
if EEAptGet.is_installed(self, 'postfix'): |
|
|
|
services = services + ['postfix'] |
|
|
|
else: |
|
|
|
Log.info(self, "Postfix is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.hhvm: |
|
|
|
if EEAptGet.is_installed(self, 'hhvm'): |
|
|
|
services = services + ['hhvm'] |
|
|
|
Log.debug(self, "hhvm service stop") |
|
|
|
else: |
|
|
|
Log.info(self, "HHVM is not installed") |
|
|
|
if self.app.pargs.memcache: |
|
|
|
Log.debug(self, "memcached service stop") |
|
|
|
if EEAptGet.is_installed(self, 'memcached'): |
|
|
|
services = services + ['memcached'] |
|
|
|
else: |
|
|
|
Log.info(self, "Memcache is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.dovecot: |
|
|
|
Log.debug(self, "dovecot service stop") |
|
|
|
if EEAptGet.is_installed(self, 'dovecot-core'): |
|
|
|
services = services + ['dovecot'] |
|
|
|
if not services and EEVariables.ee_mysql_host is "localhost": |
|
|
|
services = services + ['nginx', 'php5-fpm', 'mysql', 'postfix', |
|
|
|
'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,mysql,postfix,hhvm services stop") |
|
|
|
elif not services: |
|
|
|
services = services + ['nginx', 'php5-fpm', 'postfix', 'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,postfix,hhvm services stop") |
|
|
|
else: |
|
|
|
Log.info(self, "Mail server is not installed") |
|
|
|
|
|
|
|
for service in services: |
|
|
|
Log.debug(self, "Stopping service: {0}".format(service)) |
|
|
|
EEService.stop_service(self, service) |
|
|
|
|
|
|
|
@expose(help="Restart stack services") |
|
|
|
def restart(self): |
|
|
|
"""Restart services""" |
|
|
|
services = [] |
|
|
|
if not (self.app.pargs.nginx or self.app.pargs.php |
|
|
|
or self.app.pargs.mysql or self.app.pargs.postfix |
|
|
|
or self.app.pargs.hhvm or self.app.pargs.memcache |
|
|
|
or self.app.pargs.dovecot): |
|
|
|
self.app.pargs.nginx = True |
|
|
|
self.app.pargs.php = True |
|
|
|
self.app.pargs.mysql = True |
|
|
|
self.app.pargs.postfix = True |
|
|
|
self.app.pargs.hhvm = True |
|
|
|
|
|
|
|
if self.app.pargs.nginx: |
|
|
|
Log.debug(self, "nginx service restart") |
|
|
|
if EEVariables.ee_platform_distro == 'debian': |
|
|
|
check_nginx = 'nginx-extras' |
|
|
|
else: |
|
|
|
check_nginx = 'nginx-custom' |
|
|
|
|
|
|
|
if EEAptGet.is_installed(self, check_nginx): |
|
|
|
services = services + ['nginx'] |
|
|
|
else: |
|
|
|
Log.info(self, "Nginx is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.php: |
|
|
|
Log.debug(self, "php5-fpm service restart") |
|
|
|
if EEAptGet.is_installed(self, 'php5-fpm'): |
|
|
|
services = services + ['php5-fpm'] |
|
|
|
else: |
|
|
|
Log.info(self, "PHP5-FPM is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.mysql: |
|
|
|
if EEVariables.ee_mysql_host is "localhost": |
|
|
|
Log.debug(self, "mysql service restart") |
|
|
|
if ((EEVariables.ee_mysql_host is "localhost") or |
|
|
|
(EEVariables.ee_mysql_host is "127.0.0.1")): |
|
|
|
if (EEAptGet.is_installed(self, 'mysql-server') or |
|
|
|
EEAptGet.is_installed(self, 'percona-server-server-5.6') or |
|
|
|
EEAptGet.is_installed(self, 'mariadb-server')): |
|
|
|
services = services + ['mysql'] |
|
|
|
else: |
|
|
|
Log.info(self, "MySQL is not installed") |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found, " |
|
|
|
"unable to restart MySQL service") |
|
|
|
"Unable to check MySQL service status") |
|
|
|
|
|
|
|
if self.app.pargs.postfix: |
|
|
|
Log.debug(self, "postfix service restart") |
|
|
|
if EEAptGet.is_installed(self, 'postfix'): |
|
|
|
services = services + ['postfix'] |
|
|
|
else: |
|
|
|
Log.info(self, "Postfix is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.hhvm: |
|
|
|
if EEAptGet.is_installed(self, 'hhvm'): |
|
|
|
services = services + ['hhvm'] |
|
|
|
Log.debug(self, "hhvm service restart") |
|
|
|
else: |
|
|
|
Log.info(self, "HHVM is not installed") |
|
|
|
if self.app.pargs.memcache: |
|
|
|
Log.debug(self, "memcached service restart") |
|
|
|
if EEAptGet.is_installed(self, 'memcached'): |
|
|
|
services = services + ['memcached'] |
|
|
|
else: |
|
|
|
Log.info(self, "Memcache is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.dovecot: |
|
|
|
Log.debug(self, "dovecot service restart") |
|
|
|
if EEAptGet.is_installed(self, 'dovecot-core'): |
|
|
|
services = services + ['dovecot'] |
|
|
|
if not services and EEVariables.ee_mysql_host is "localhost": |
|
|
|
services = services + ['nginx', 'php5-fpm', 'mysql', 'postfix', |
|
|
|
'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,mysql,postfix,hhvm services" |
|
|
|
"restart") |
|
|
|
elif not services: |
|
|
|
services = services + ['nginx', 'php5-fpm', 'postfix', 'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,postfix,hhvm services restart") |
|
|
|
else: |
|
|
|
Log.info(self, "Mail server is not installed") |
|
|
|
|
|
|
|
for service in services: |
|
|
|
Log.debug(self, "Restarting service: {0}".format(service)) |
|
|
|
EEService.restart_service(self, service) |
|
|
|
|
|
|
|
@expose(help="Get stack status") |
|
|
|
def status(self): |
|
|
|
"""Status of services""" |
|
|
|
services = [] |
|
|
|
if not (self.app.pargs.nginx or self.app.pargs.php |
|
|
|
or self.app.pargs.mysql or self.app.pargs.postfix |
|
|
|
or self.app.pargs.hhvm or self.app.pargs.memcache |
|
|
|
or self.app.pargs.dovecot): |
|
|
|
self.app.pargs.nginx = True |
|
|
|
self.app.pargs.php = True |
|
|
|
self.app.pargs.mysql = True |
|
|
|
self.app.pargs.postfix = True |
|
|
|
self.app.pargs.hhvm = True |
|
|
|
|
|
|
|
if self.app.pargs.nginx: |
|
|
|
Log.debug(self, "nginx service status") |
|
|
|
if EEVariables.ee_platform_distro == 'debian': |
|
|
|
check_nginx = 'nginx-extras' |
|
|
|
else: |
|
|
|
check_nginx = 'nginx-custom' |
|
|
|
|
|
|
|
if EEAptGet.is_installed(self, check_nginx): |
|
|
|
services = services + ['nginx'] |
|
|
|
else: |
|
|
|
Log.info(self, "Nginx is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.php: |
|
|
|
Log.debug(self, "php5-fpm service status") |
|
|
|
if EEAptGet.is_installed(self, 'php5-fpm'): |
|
|
|
services = services + ['php5-fpm'] |
|
|
|
else: |
|
|
|
Log.info(self, "PHP5-FPM is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.mysql: |
|
|
|
if EEVariables.ee_mysql_host is "localhost": |
|
|
|
Log.debug(self, "mysql service status") |
|
|
|
if ((EEVariables.ee_mysql_host is "localhost") or |
|
|
|
(EEVariables.ee_mysql_host is "127.0.0.1")): |
|
|
|
if (EEAptGet.is_installed(self, 'mysql-server') or |
|
|
|
EEAptGet.is_installed(self, 'percona-server-server-5.6') or |
|
|
|
EEAptGet.is_installed(self, 'mariadb-server')): |
|
|
|
services = services + ['mysql'] |
|
|
|
else: |
|
|
|
Log.info(self, "MySQL is not installed") |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found, " |
|
|
|
"unable to get MySQL service status") |
|
|
|
"Unable to check MySQL service status") |
|
|
|
|
|
|
|
if self.app.pargs.postfix: |
|
|
|
if EEAptGet.is_installed(self, 'postfix'): |
|
|
|
services = services + ['postfix'] |
|
|
|
Log.debug(self, "postfix service status") |
|
|
|
else: |
|
|
|
Log.info(self, "Postfix is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.hhvm: |
|
|
|
if EEAptGet.is_installed(self, 'hhvm'): |
|
|
|
services = services + ['hhvm'] |
|
|
|
Log.debug(self, "hhvm service status") |
|
|
|
else: |
|
|
|
Log.info(self, "HHVM is not installed") |
|
|
|
if self.app.pargs.memcache: |
|
|
|
Log.debug(self, "memcached service status") |
|
|
|
if EEAptGet.is_installed(self, 'memcached'): |
|
|
|
services = services + ['memcached'] |
|
|
|
else: |
|
|
|
Log.info(self, "Memcache is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.dovecot: |
|
|
|
Log.debug(self, "dovecot service status") |
|
|
|
if EEAptGet.is_installed(self, 'dovecot-core'): |
|
|
|
services = services + ['dovecot'] |
|
|
|
if not services and EEVariables.ee_mysql_host is "localhost": |
|
|
|
services = services + ['nginx', 'php5-fpm', 'mysql', 'postfix', |
|
|
|
'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,mysql,postfix,hhvm services" |
|
|
|
" status") |
|
|
|
elif not services: |
|
|
|
services = services + ['nginx', 'php5-fpm', 'postfix', 'hhvm'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,postfix,hhvm services status") |
|
|
|
else: |
|
|
|
Log.info(self, "Mail server is not installed") |
|
|
|
|
|
|
|
for service in services: |
|
|
|
if EEService.get_service_status(self, service): |
|
|
|
Log.info(self, "{0:10}: {1}".format(service, "Running")) |
|
|
@ -182,35 +307,66 @@ class EEStackStatusController(CementBaseController): |
|
|
|
def reload(self): |
|
|
|
"""Reload service""" |
|
|
|
services = [] |
|
|
|
if not (self.app.pargs.nginx or self.app.pargs.php |
|
|
|
or self.app.pargs.mysql or self.app.pargs.postfix |
|
|
|
or self.app.pargs.hhvm or self.app.pargs.memcache |
|
|
|
or self.app.pargs.dovecot): |
|
|
|
self.app.pargs.nginx = True |
|
|
|
self.app.pargs.php = True |
|
|
|
self.app.pargs.mysql = True |
|
|
|
self.app.pargs.postfix = True |
|
|
|
|
|
|
|
if self.app.pargs.nginx: |
|
|
|
Log.debug(self, "nginx service reload") |
|
|
|
if EEVariables.ee_platform_distro == 'debian': |
|
|
|
check_nginx = 'nginx-extras' |
|
|
|
else: |
|
|
|
check_nginx = 'nginx-custom' |
|
|
|
|
|
|
|
if EEAptGet.is_installed(self, check_nginx): |
|
|
|
services = services + ['nginx'] |
|
|
|
else: |
|
|
|
Log.info(self, "Nginx is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.php: |
|
|
|
Log.debug(self, "php5-fpm service reload") |
|
|
|
if EEAptGet.is_installed(self, 'php5-fpm'): |
|
|
|
services = services + ['php5-fpm'] |
|
|
|
else: |
|
|
|
Log.info(self, "PHP5-FPM is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.mysql: |
|
|
|
if EEVariables.ee_mysql_host is "localhost": |
|
|
|
Log.debug(self, "mysql service reload") |
|
|
|
if ((EEVariables.ee_mysql_host is "localhost") or |
|
|
|
(EEVariables.ee_mysql_host is "127.0.0.1")): |
|
|
|
if (EEAptGet.is_installed(self, 'mysql-server') or |
|
|
|
EEAptGet.is_installed(self, 'percona-server-server-5.6') or |
|
|
|
EEAptGet.is_installed(self, 'mariadb-server')): |
|
|
|
services = services + ['mysql'] |
|
|
|
else: |
|
|
|
Log.info(self, "MySQL is not installed") |
|
|
|
else: |
|
|
|
Log.warn(self, "Remote MySQL found, " |
|
|
|
"unable to remote MySQL service") |
|
|
|
"Unable to check MySQL service status") |
|
|
|
|
|
|
|
if self.app.pargs.postfix: |
|
|
|
Log.debug(self, "postfix service reload") |
|
|
|
if EEAptGet.is_installed(self, 'postfix'): |
|
|
|
services = services + ['postfix'] |
|
|
|
else: |
|
|
|
Log.info(self, "Postfix is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.hhvm: |
|
|
|
Log.warn(self, "hhvm does not support to reload") |
|
|
|
Log.info(self, "HHVM does not support to reload") |
|
|
|
|
|
|
|
if self.app.pargs.memcache: |
|
|
|
Log.debug(self, "memcached service reload") |
|
|
|
if EEAptGet.is_installed(self, 'memcached'): |
|
|
|
services = services + ['memcached'] |
|
|
|
else: |
|
|
|
Log.info(self, "Memcache is not installed") |
|
|
|
|
|
|
|
if self.app.pargs.dovecot: |
|
|
|
Log.debug(self, "dovecot service reload") |
|
|
|
if EEAptGet.is_installed(self, 'dovecot-core'): |
|
|
|
services = services + ['dovecot'] |
|
|
|
if not services and EEVariables.ee_mysql_host is "localhost": |
|
|
|
services = services + ['nginx', 'php5-fpm', 'mysql', 'postfix'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,mysql,postfix services reload") |
|
|
|
elif not services: |
|
|
|
services = services + ['nginx', 'php5-fpm', 'postfix'] |
|
|
|
Log.debug(self, "nginx,php5-fpm,postfix services reload") |
|
|
|
else: |
|
|
|
Log.info(self, "Mail server is not installed") |
|
|
|
|
|
|
|
for service in services: |
|
|
|
Log.debug(self, "Reloading service: {0}".format(service)) |
|
|
|
EEService.reload_service(self, service) |
|
|
|