moonraker: Add "/server/restart" endpoint

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Arksine 2020-10-11 08:48:47 -04:00
parent f220e1b2ee
commit 8fcccfd46e
1 changed files with 43 additions and 24 deletions

View File

@ -13,7 +13,8 @@ import logging
import json import json
import confighelper import confighelper
import utils import utils
from tornado import iostream import asyncio
from tornado import iostream, gen
from tornado.ioloop import IOLoop from tornado.ioloop import IOLoop
from tornado.util import TimeoutError from tornado.util import TimeoutError
from tornado.locks import Event from tornado.locks import Event
@ -69,6 +70,8 @@ class Server:
self.register_endpoint( self.register_endpoint(
"/server/info", ['GET'], self._handle_info_request) "/server/info", ['GET'], self._handle_info_request)
self.register_endpoint(
"/server/restart", ['POST'], self._handle_server_restart)
# Setup remote methods accessable to Klippy. Note that all # Setup remote methods accessable to Klippy. Note that all
# registered remote methods should be of the notification type, # registered remote methods should be of the notification type,
@ -155,6 +158,8 @@ class Server:
# ***** Klippy Connection ***** # ***** Klippy Connection *****
async def _connect_klippy(self): async def _connect_klippy(self):
if not self.server_running:
return
ret = await self.klippy_connection.connect(self.klippy_address) ret = await self.klippy_connection.connect(self.klippy_address)
if not ret: if not ret:
self.ioloop.call_later(.25, self._connect_klippy) self.ioloop.call_later(.25, self._connect_klippy)
@ -200,9 +205,12 @@ class Server:
self.send_event("server:klippy_disconnect") self.send_event("server:klippy_disconnect")
if self.init_handle is not None: if self.init_handle is not None:
self.ioloop.remove_timeout(self.init_handle) self.ioloop.remove_timeout(self.init_handle)
self.ioloop.call_later(.25, self._connect_klippy) if self.server_running:
self.ioloop.call_later(.25, self._connect_klippy)
async def _initialize(self): async def _initialize(self):
if not self.server_running:
return
await self._check_ready() await self._check_ready()
await self._request_endpoints() await self._request_endpoints()
# Subscribe to "webhooks" # Subscribe to "webhooks"
@ -356,19 +364,21 @@ class Server:
return result return result
async def _stop_server(self): async def _stop_server(self):
# XXX - Currently this function is not used. self.server_running = False
# Should I expose functionality to shutdown for name, plugin in self.plugins.items():
# or restart the server, or simply remove this?
logging.info(
"Shutting Down Webserver")
for plugin in self.plugins:
if hasattr(plugin, "close"): if hasattr(plugin, "close"):
await plugin.close() ret = plugin.close()
if asyncio.iscoroutine(ret):
await ret
self.klippy_connection.close() self.klippy_connection.close()
if self.server_running: while self.klippy_state != "disconnected":
self.server_running = False await gen.sleep(.1)
await self.moonraker_app.close() await self.moonraker_app.close()
self.ioloop.stop() self.ioloop.stop()
async def _handle_server_restart(self, path, method, args):
self.ioloop.spawn_callback(self._stop_server)
return "ok"
async def _handle_info_request(self, path, method, args): async def _handle_info_request(self, path, method, args):
return { return {
@ -494,20 +504,29 @@ def main():
# Start IOLoop and Server # Start IOLoop and Server
io_loop = IOLoop.current() io_loop = IOLoop.current()
try: estatus = 0
server = Server(cmd_line_args) while True:
except Exception: try:
logging.exception("Moonraker Error") server = Server(cmd_line_args)
ql.stop() except Exception:
exit(1) logging.exception("Moonraker Error")
try: estatus = 1
server.start() break
io_loop.start() try:
except Exception: server.start()
logging.exception("Server Running Error") io_loop.start()
except Exception:
logging.exception("Server Running Error")
estatus = 1
break
# Since we are running outside of the the server
# it is ok to use a blocking sleep here
time.sleep(.5)
logging.info("Attempting Server Restart...")
io_loop.close(True) io_loop.close(True)
logging.info("Server Shutdown") logging.info("Server Shutdown")
ql.stop() ql.stop()
exit(estatus)
if __name__ == '__main__': if __name__ == '__main__':