Daemonization

This commit is contained in:
Lynn Ochs 2019-05-12 13:32:28 +02:00
parent 4df94c8793
commit 8500b77024
Signed by: apo
GPG Key ID: 588AD47B1D06BE99

View File

@ -5,6 +5,8 @@ import os
import tempfile
import mailcap
import sys
import argparse
import daemon
sockpath = "mailcap.sock"
@ -97,16 +99,36 @@ class Server(object):
return None
if __name__ == "__main__":
if len(sys.argv) > 1:
if sys.argv[1] == "-h":
print("Usage: %s [socket_path = mailcap.sock]" % (sys.argv[0],))
parser = argparse.ArgumentParser()
parser.add_argument('--pid', '-p', default=os.path.join(os.environ['HOME'], '.mailcap.pid'))
parser.add_argument('--action', '-a', default='run', choices=['run', 'kill'])
parser.add_argument('--no-daemonize', '-n', action='store_true')
parser.add_argument('--socket', '-s', default=os.path.join(os.environ['HOME'], '.mailcap.sock'))
args = parser.parse_args()
if args.action == 'kill':
if os.path.exists(args.socket):
os.remove(args.socket)
if os.path.exists(args.pid):
pid = int(open(args.pid).read())
try:
os.kill(pid, 3)
except ProcessLookupError as e:
print("Failed to kill process with pid %d:" % (pid,), str(e))
os.remove(args.pid)
if os.path.exists(args.socket):
os.remove(args.socket)
elif args.action == 'run':
if os.path.exists(args.pid):
print("Already running with pid %d" % (int(open(args.pid).read()),))
exit()
else:
sockpath = sys.argv[1]
if os.path.exists(sockpath):
os.remove(sockpath)
sv = Server(sockpath)
if os.path.exists(args.socket):
os.remove(args.socket)
with daemon.DaemonContext(detach_process=not args.no_daemonize, files_preserve=[1,2]):
sv = Server(args.socket)
caps = mailcap.getcaps()
open(args.pid, "w+").write(str(os.getpid()))
while True:
rv = sv.next_file()
if rv: