diff --git a/IPython/html/base/handlers.py b/IPython/html/base/handlers.py index 618e21893..7dc625204 100644 --- a/IPython/html/base/handlers.py +++ b/IPython/html/base/handlers.py @@ -137,6 +137,10 @@ class IPythonHandler(AuthenticatedHandler): def base_url(self): return self.settings.get('base_url', '/') + @property + def default_url(self): + return self.settings.get('default_url', '') + @property def ws_url(self): return self.settings.get('websocket_url', '') @@ -238,6 +242,7 @@ class IPythonHandler(AuthenticatedHandler): def template_namespace(self): return dict( base_url=self.base_url, + default_url=self.default_url, ws_url=self.ws_url, logged_in=self.logged_in, login_available=self.login_available, diff --git a/IPython/html/notebookapp.py b/IPython/html/notebookapp.py index 03872c30d..5d2a1d3ad 100644 --- a/IPython/html/notebookapp.py +++ b/IPython/html/notebookapp.py @@ -243,7 +243,7 @@ class NotebookWebApplication(web.Application): # set the URL that will be redirected from `/` handlers.append( (r'/?', web.RedirectHandler, { - 'url' : url_path_join(settings['base_url'], settings['default_url']), + 'url' : settings['default_url'], 'permanent': False, # want 302, not 301 }) ) @@ -816,6 +816,9 @@ class NotebookApp(BaseIPythonApplication): if self.allow_origin_pat: self.tornado_settings['allow_origin_pat'] = re.compile(self.allow_origin_pat) self.tornado_settings['allow_credentials'] = self.allow_credentials + # ensure default_url starts with base_url + if not self.default_url.startswith(self.base_url): + self.default_url = url_path_join(self.base_url, self.default_url) self.web_app = NotebookWebApplication( self, self.kernel_manager, self.contents_manager, diff --git a/IPython/html/templates/page.html b/IPython/html/templates/page.html index 09131fe5e..191b34bbf 100644 --- a/IPython/html/templates/page.html +++ b/IPython/html/templates/page.html @@ -83,7 +83,7 @@