# HG changeset patch # User Edouard Tisserant # Date 1576672282 -3600 # Node ID 769fefae7c81385ad49c4745506428f445004c25 # Parent b98d9e08231f8c13e0125bfa25525cfae8546e9f Add --on-plc-start --on-plc-stop and --status-change to runtime command line, calling given command respectively on start stop or any event. Command line string is python formated (to eventually include status with {}) before being split (supports quoted strings) and passed to Popen for non-blocking execution. diff -r b98d9e08231f -r 769fefae7c81 Beremiz_service.py --- a/Beremiz_service.py Mon Nov 25 08:10:45 2019 +0100 +++ b/Beremiz_service.py Wed Dec 18 13:31:22 2019 +0100 @@ -30,6 +30,7 @@ import sys import getopt import threading +import shlex from threading import Thread, Semaphore, Lock, currentThread from builtins import str as text from past.builtins import execfile @@ -44,6 +45,10 @@ from runtime.Stunnel import ensurePSK import util.paths as paths +try: + from runtime.spawn_subprocess import Popen +except ImportError: + from subprocess import Popen def version(): from version import app_version @@ -72,7 +77,7 @@ try: - opts, argv = getopt.getopt(sys.argv[1:], "i:p:n:x:t:a:w:c:e:s:h", ["help", "version"]) + opts, argv = getopt.getopt(sys.argv[1:], "i:p:n:x:t:a:w:c:e:s:h", ["help", "version", "status-change=", "on-plc-start=", "on-plc-stop="]) except getopt.GetoptError as err: # print help information and exit: print(str(err)) # will print something like "option -a not recognized" @@ -93,6 +98,13 @@ havetwisted = False extensions = [] +statuschange = [] +def status_change_call_factory(wanted, args): + def status_change_call(status): + if wanted is None or status is wanted: + cmd = shlex.split(args.format(status)) + Popen(cmd) + return status_change_call for o, a in opts: if o == "-h" or o == "--help": @@ -101,6 +113,12 @@ if o == "--version": version() sys.exit() + if o == "--on-plc-start": + statuschange.append(status_change_call_factory(PlcStatus.Started, a)) + elif o == "--on-plc-stop": + statuschange.append(status_change_call_factory(PlcStatus.Stopped, a)) + elif o == "--status-change": + statuschange.append(status_change_call_factory(None, a)) elif o == "-i": if len(a.split(".")) == 4: interface = a @@ -401,7 +419,6 @@ havetwisted = False pyruntimevars = {} -statuschange = [] if havetwisted: if havewx: