summaryrefslogtreecommitdiff
path: root/src/services
diff options
context:
space:
mode:
authorJohn Estabrook <jestabro@vyos.io>2020-04-20 08:58:20 -0500
committerJohn Estabrook <jestabro@vyos.io>2020-04-20 09:00:22 -0500
commit6b8a6619533c7f47a63e041efb516ad91b10b4da (patch)
treee76412786c8420729ecc7517d6dd256964758465 /src/services
parentcfc474b3e45762e0c15f9cfca76a3c1b66ff233e (diff)
downloadvyos-1x-6b8a6619533c7f47a63e041efb516ad91b10b4da.tar.gz
vyos-1x-6b8a6619533c7f47a63e041efb516ad91b10b4da.zip
http api: T2292: handle SIGTERM from systemd restart; raise SIGINT
Diffstat (limited to 'src/services')
-rwxr-xr-xsrc/services/vyos-http-api-server8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/services/vyos-http-api-server b/src/services/vyos-http-api-server
index b5ad8b159..a3624052e 100755
--- a/src/services/vyos-http-api-server
+++ b/src/services/vyos-http-api-server
@@ -22,6 +22,7 @@ import grp
import json
import traceback
import threading
+import signal
import vyos.config
@@ -350,6 +351,8 @@ def show_op():
return success(res)
+def shutdown():
+ raise KeyboardInterrupt
if __name__ == '__main__':
# systemd's user and group options don't work, do it by hand here,
@@ -372,4 +375,9 @@ if __name__ == '__main__':
app.config['vyos_keys'] = server_config['api_keys']
app.config['vyos_debug'] = server_config['debug']
+ def sig_handler(signum, frame):
+ shutdown()
+
+ signal.signal(signal.SIGTERM, sig_handler)
+
bottle.run(app, host=server_config["listen_address"], port=server_config["port"], debug=True)