123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- # coding: utf-8
- """A tornado based Jupyter lab server."""
- # Copyright (c) Jupyter Development Team.
- # Distributed under the terms of the Modified BSD License.
- # ----------------------------------------------------------------------------
- # Module globals
- # ----------------------------------------------------------------------------
- import os
- DEV_NOTE = """You're running JupyterLab from source.
- If you're working on the TypeScript sources of JupyterLab, try running
- jupyter lab --dev-mode --watch
- to have the system incrementally watch and build JupyterLab for you, as you
- make changes.
- """
- CORE_NOTE = """
- Running the core application with no additional extensions or settings
- """
- def load_jupyter_server_extension(nbapp):
- """Load the JupyterLab server extension.
- """
- # Delay imports to speed up jlpmapp
- from json import dumps
- from jupyterlab_launcher import add_handlers, LabConfig
- from notebook.utils import url_path_join as ujoin, url_escape
- from notebook._version import version_info
- from tornado.ioloop import IOLoop
- from markupsafe import Markup
- from .build_handler import build_path, Builder, BuildHandler
- from .extension_manager_handler import (
- extensions_handler_path, ExtensionManager, ExtensionHandler
- )
- from .commands import (
- get_app_dir, get_user_settings_dir, watch, ensure_dev, watch_dev,
- pjoin, DEV_DIR, HERE, get_app_info, ensure_core, get_workspaces_dir
- )
- web_app = nbapp.web_app
- logger = nbapp.log
- config = LabConfig()
- app_dir = getattr(nbapp, 'app_dir', get_app_dir())
- user_settings_dir = getattr(
- nbapp, 'user_settings_dir', get_user_settings_dir()
- )
- workspaces_dir = getattr(
- nbapp, 'workspaces_dir', get_workspaces_dir()
- )
- # Print messages.
- logger.info('JupyterLab extension loaded from %s' % HERE)
- logger.info('JupyterLab application directory is %s' % app_dir)
- config.app_name = 'JupyterLab Beta'
- config.app_namespace = 'jupyterlab'
- config.page_url = '/lab'
- config.cache_files = True
- # Check for core mode.
- core_mode = False
- if getattr(nbapp, 'core_mode', False) or app_dir.startswith(HERE):
- core_mode = True
- logger.info('Running JupyterLab in core mode')
- # Check for dev mode.
- dev_mode = False
- if getattr(nbapp, 'dev_mode', False) or app_dir.startswith(DEV_DIR):
- dev_mode = True
- logger.info('Running JupyterLab in dev mode')
- # Check for watch.
- watch_mode = getattr(nbapp, 'watch', False)
- if watch_mode and core_mode:
- logger.warn('Cannot watch in core mode, did you mean --dev-mode?')
- watch_mode = False
- if core_mode and dev_mode:
- logger.warn('Conflicting modes, choosing dev_mode over core_mode')
- core_mode = False
- page_config = web_app.settings.setdefault('page_config_data', dict())
- page_config['buildAvailable'] = not core_mode and not dev_mode
- page_config['buildCheck'] = not core_mode and not dev_mode
- page_config['token'] = nbapp.token
- page_config['devMode'] = dev_mode
- # Export the version info tuple to a JSON array. This gets printed
- # inside double quote marks, so we render it to a JSON string of the
- # JSON data (so that we can call JSON.parse on the frontend on it).
- # We also have to wrap it in `Markup` so that it isn't escaped
- # by Jinja. Otherwise, if the version has string parts these will be
- # escaped and then will have to be unescaped on the frontend.
- page_config['notebookVersion'] = Markup(dumps(dumps(version_info))[1:-1])
- if nbapp.file_to_run and type(nbapp).__name__ == "LabApp":
- relpath = os.path.relpath(nbapp.file_to_run, nbapp.notebook_dir)
- uri = url_escape(ujoin('/lab/tree', *relpath.split(os.sep)))
- nbapp.default_url = uri
- nbapp.file_to_run = ''
- if core_mode:
- app_dir = HERE
- logger.info(CORE_NOTE.strip())
- ensure_core(logger)
- elif dev_mode:
- app_dir = DEV_DIR
- ensure_dev(logger)
- if not watch_mode:
- logger.info(DEV_NOTE)
- config.app_settings_dir = pjoin(app_dir, 'settings')
- config.schemas_dir = pjoin(app_dir, 'schemas')
- config.themes_dir = pjoin(app_dir, 'themes')
- config.workspaces_dir = workspaces_dir
- info = get_app_info(app_dir)
- config.app_version = info['version']
- public_url = info['publicUrl']
- if public_url:
- config.public_url = public_url
- else:
- config.static_dir = pjoin(app_dir, 'static')
- config.user_settings_dir = user_settings_dir
- # The templates end up in the built static directory.
- config.templates_dir = pjoin(app_dir, 'static')
- if watch_mode:
- logger.info('Starting JupyterLab watch mode...')
- # Set the ioloop in case the watch fails.
- nbapp.ioloop = IOLoop.current()
- if dev_mode:
- watch_dev(logger)
- else:
- watch(app_dir, logger)
- page_config['buildAvailable'] = False
- config.cache_files = False
- base_url = web_app.settings['base_url']
- build_url = ujoin(base_url, build_path)
- builder = Builder(logger, core_mode, app_dir)
- build_handler = (build_url, BuildHandler, {'builder': builder})
- handlers = [build_handler]
- if not core_mode:
- ext_url = ujoin(base_url, extensions_handler_path)
- ext_manager = ExtensionManager(logger, app_dir)
- ext_handler = (ext_url, ExtensionHandler, {'manager': ext_manager})
- handlers.append(ext_handler)
- # Must add before the launcher handlers to avoid shadowing.
- web_app.add_handlers('.*$', handlers)
- add_handlers(web_app, config)
|