app: add a redirect endpoint

Clients can use this in situations where a browser may
prompt the user to take action prior to sending the
request.  After the user accepts, Moonraker will redirect the user to the url provided in the request.

SIgned-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2021-05-28 21:03:03 -04:00
parent 082134b9a0
commit 793ab6b24b
2 changed files with 18 additions and 1 deletions

View File

@ -155,7 +155,8 @@ class MoonrakerApp:
self.mutable_router = MutableRouter(self) self.mutable_router = MutableRouter(self)
app_handlers: List[Any] = [ app_handlers: List[Any] = [
(AnyMatches(), self.mutable_router), (AnyMatches(), self.mutable_router),
(r"/websocket", WebSocket)] (r"/websocket", WebSocket),
(r"/server/redirect", RedirectHandler)]
self.app = tornado.web.Application(app_handlers, **app_args) self.app = tornado.web.Application(app_handlers, **app_args)
self.get_handler_delegate = self.app.get_handler_delegate self.get_handler_delegate = self.app.get_handler_delegate
@ -793,3 +794,18 @@ class AuthorizedErrorHandler(AuthorizedRequestHandler):
err['traceback'] = "\n".join( err['traceback'] = "\n".join(
traceback.format_exception(*kwargs['exc_info'])) traceback.format_exception(*kwargs['exc_info']))
self.finish({'error': err}) self.finish({'error': err})
class RedirectHandler(AuthorizedRequestHandler):
def get(self, *args, **kwargs) -> None:
url: Optional[str] = self.get_argument('url', None)
if url is None:
try:
body_args: Dict[str, Any] = json.loads(self.request.body)
except json.JSONDecodeError:
body_args = {}
if 'url' not in body_args:
raise tornado.web.HTTPError(
400, "No url argument provided")
url = body_args['url']
assert url is not None
self.redirect(url)

View File

@ -154,6 +154,7 @@ class Authorization:
self.prune_handler.start() self.prune_handler.start()
# Register Authorization Endpoints # Register Authorization Endpoints
self.permitted_paths.add("/server/redirect")
self.permitted_paths.add("/access/login") self.permitted_paths.add("/access/login")
self.permitted_paths.add("/access/refresh_jwt") self.permitted_paths.add("/access/refresh_jwt")
self.server.register_endpoint( self.server.register_endpoint(