From 9775de7b2f4a9d2894e969690cbb883bbaaf29d7 Mon Sep 17 00:00:00 2001 From: Maximilian Ehlers Date: Sat, 21 Dec 2024 12:58:57 +0100 Subject: [PATCH] nixos/jupyter: Updates jupyter notebook config to work correctly with current versions Signed-off-by: Maximilian Ehlers --- .../manual/release-notes/rl-2411.section.md | 2 + .../manual/release-notes/rl-2505.section.md | 2 + .../services/development/jupyter/default.nix | 65 +++++++++++++------ 3 files changed, 50 insertions(+), 19 deletions(-) diff --git a/nixos/doc/manual/release-notes/rl-2411.section.md b/nixos/doc/manual/release-notes/rl-2411.section.md index 295d3f100b03b6..2bfc050441b68a 100644 --- a/nixos/doc/manual/release-notes/rl-2411.section.md +++ b/nixos/doc/manual/release-notes/rl-2411.section.md @@ -815,6 +815,8 @@ - Kanidm previously had an incorrect systemd service type, causing dependent units with an `after` and `requires` directive to start before `kanidm*` finished startup. The module has now been updated in line with upstream recommendations. +- The [`services.jupyter`](#opt-services.jupyter.enable) service is now compatible with `Jupyter Notebook 7`. See [https://jupyter-notebook.readthedocs.io/en/latest/migrate_to_notebook7.html](https://jupyter-notebook.readthedocs.io/en/latest/migrate_to_notebook7.html) for details. + - The kubelet configuration file can now be amended with arbitrary additional content using the `services.kubernetes.kubelet.extraConfig` option. - The `services.seafile` module was updated to major version 11. diff --git a/nixos/doc/manual/release-notes/rl-2505.section.md b/nixos/doc/manual/release-notes/rl-2505.section.md index 9b39fb1869ea76..a161247a0a82b6 100644 --- a/nixos/doc/manual/release-notes/rl-2505.section.md +++ b/nixos/doc/manual/release-notes/rl-2505.section.md @@ -338,6 +338,8 @@ - `programs.fzf.keybindings` now supports the fish shell. +- The [`services.jupyter`](#opt-services.jupyter.enable) service is now compatible with `Jupyter Notebook 7`. See [https://jupyter-notebook.readthedocs.io/en/latest/migrate_to_notebook7.html](https://jupyter-notebook.readthedocs.io/en/latest/migrate_to_notebook7.html) for details. + ## Nixpkgs Library {#sec-release-25.05-lib} diff --git a/nixos/modules/services/development/jupyter/default.nix b/nixos/modules/services/development/jupyter/default.nix index 5bcbf34548c116..22fa5f2299124e 100644 --- a/nixos/modules/services/development/jupyter/default.nix +++ b/nixos/modules/services/development/jupyter/default.nix @@ -2,13 +2,20 @@ config, lib, pkgs, + options, ... }: let cfg = config.services.jupyter; - package = cfg.package; + package = pkgs.python3.withPackages ( + ps: + [ + cfg.package + ] + ++ cfg.extraPackages + ); kernels = ( pkgs.jupyter-kernel.create { @@ -16,15 +23,18 @@ let } ); - notebookConfig = pkgs.writeText "jupyter_config.py" '' + notebookConfig = pkgs.writeText "jupyter_server_config.py" '' ${cfg.notebookConfig} + c.ServerApp.password = "${cfg.password}" - c.NotebookApp.password = ${cfg.password} ''; in { - meta.maintainers = with lib.maintainers; [ aborsu ]; + meta.maintainers = with lib.maintainers; [ + aborsu + b-m-f + ]; options.services.jupyter = { enable = lib.mkEnableOption "Jupyter development server"; @@ -37,14 +47,36 @@ in ''; }; - # NOTE: We don't use top-level jupyter because we don't - # want to pass in JUPYTER_PATH but use .environment instead, - # saving a rebuild. - package = lib.mkPackageOption pkgs [ "python3" "pkgs" "notebook" ] { }; + package = lib.mkPackageOption pkgs [ + "python3" + "pkgs" + "jupyter" + ] { }; + + extraPackages = lib.mkOption { + type = lib.types.listOf lib.types.package; + default = [ ]; + example = lib.literalExpression '' + [ + pkgs.python3.pkgs.nbconvert + pkgs.python3.pkgs.playwright + ] + ''; + description = ''Extra packages to be available in the jupyter runtime enviroment''; + }; + extraEnvironmentVariables = lib.mkOption { + description = ''Extra enviroment variables to be set in the runtime context of jupyter notebook''; + default = { }; + example = lib.literalExpression '' + PLAYWRIGHT_BROWSERS_PATH = "$${pkgs.playwright-driver.browsers}"; + PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS = "true"; + ''; + inherit (options.environment.variables) type apply; + }; command = lib.mkOption { type = lib.types.str; - default = "jupyter-notebook"; + default = "jupyter notebook"; example = "jupyter-lab"; description = '' Which command the service runs. Note that not all jupyter packages @@ -93,14 +125,7 @@ in type = lib.types.str; description = '' Password to use with notebook. - Can be generated using: - In [1]: from notebook.auth import passwd - In [2]: passwd('test') - Out[2]: 'sha1:1b961dc713fb:88483270a63e57d18d43cf337e629539de1436ba' - NOTE: you need to keep the single quote inside the nix string. - Or you can use a python oneliner: - "open('/path/secret_file', 'r', encoding='utf8').read().strip()" - It will be interpreted at the end of the notebookConfig. + Can be generated following: https://jupyter-server.readthedocs.io/en/stable/operators/public-server.html#preparing-a-hashed-password ''; example = "'sha1:1b961dc713fb:88483270a63e57d18d43cf337e629539de1436ba'"; }; @@ -110,6 +135,7 @@ in default = ""; description = '' Raw jupyter config. + Please use the password configuration option to set a password instead of passing it in here. ''; }; @@ -175,7 +201,7 @@ in environment = { JUPYTER_PATH = toString kernels; - }; + } // cfg.extraEnvironmentVariables; serviceConfig = { Restart = "always"; @@ -185,7 +211,8 @@ in --ip=${cfg.ip} \ --port=${toString cfg.port} --port-retries 0 \ --notebook-dir=${cfg.notebookDir} \ - --NotebookApp.config_file=${notebookConfig} + --JupyterApp.config_file=${notebookConfig} + ''; User = cfg.user; Group = cfg.group;