2018-04-03 12:49:14 +00:00
|
|
|
# Copyright (C) 2018 Avatao.com Innovative Learning Kft.
|
|
|
|
# All Rights Reserved. See LICENSE file for details.
|
|
|
|
|
2018-02-13 16:51:19 +00:00
|
|
|
import xmlrpc.client
|
|
|
|
from xmlrpc.client import Fault as SupervisorFault
|
2018-03-25 13:43:59 +00:00
|
|
|
from contextlib import suppress
|
2018-03-08 15:05:44 +00:00
|
|
|
from os import remove
|
2018-02-13 16:51:19 +00:00
|
|
|
|
2018-06-02 09:48:34 +00:00
|
|
|
from tfw.decorators import lazy_property
|
2018-03-25 14:36:31 +00:00
|
|
|
from tfw.config import TFWENV
|
2018-02-13 16:51:19 +00:00
|
|
|
|
|
|
|
|
2018-05-28 12:32:11 +00:00
|
|
|
class SupervisorBaseMixin:
|
2018-06-02 09:48:34 +00:00
|
|
|
@lazy_property
|
2018-06-01 12:01:32 +00:00
|
|
|
def supervisor(self):
|
|
|
|
return xmlrpc.client.ServerProxy(TFWENV.SUPERVISOR_HTTP_URI).supervisor
|
2018-02-13 16:51:19 +00:00
|
|
|
|
2018-05-28 12:32:11 +00:00
|
|
|
|
|
|
|
class SupervisorMixin(SupervisorBaseMixin):
|
2018-02-27 14:54:10 +00:00
|
|
|
def stop_process(self, process_name):
|
2018-02-13 16:51:19 +00:00
|
|
|
with suppress(SupervisorFault):
|
2018-02-27 14:54:10 +00:00
|
|
|
self.supervisor.stopProcess(process_name)
|
2018-02-13 16:51:19 +00:00
|
|
|
|
2018-02-27 14:54:10 +00:00
|
|
|
def start_process(self, process_name):
|
|
|
|
self.supervisor.startProcess(process_name)
|
2018-02-13 16:51:19 +00:00
|
|
|
|
2018-05-28 12:32:11 +00:00
|
|
|
def restart_process(self, process_name):
|
|
|
|
self.stop_process(process_name)
|
|
|
|
self.start_process(process_name)
|
|
|
|
|
|
|
|
|
|
|
|
class SupervisorLogMixin(SupervisorBaseMixin):
|
2018-05-29 15:59:16 +00:00
|
|
|
def read_stdout(self, process_name, tail=0):
|
|
|
|
return self.supervisor.readProcessStdoutLog(process_name, -tail, 0)
|
2018-05-24 09:20:00 +00:00
|
|
|
|
2018-05-29 15:59:16 +00:00
|
|
|
def read_stderr(self, process_name, tail=0):
|
|
|
|
return self.supervisor.readProcessStderrLog(process_name, -tail, 0)
|
2018-05-24 09:20:00 +00:00
|
|
|
|
|
|
|
def clear_logs(self, process_name):
|
|
|
|
for logfile in ('stdout_logfile', 'stderr_logfile'):
|
2018-05-30 12:03:59 +00:00
|
|
|
with suppress(FileNotFoundError):
|
2018-05-28 14:36:59 +00:00
|
|
|
remove(self.supervisor.getProcessInfo(process_name)[logfile])
|
2018-03-08 15:05:44 +00:00
|
|
|
self.supervisor.clearProcessLogs(process_name)
|