92 lines
2 KiB
Nix
92 lines
2 KiB
Nix
{ config, common, pkgs, ... }:
|
|
let
|
|
cfg = config.services.jupyter;
|
|
|
|
mkPythonKernel = displayName: env: {
|
|
inherit displayName;
|
|
language = "python";
|
|
argv = [ "${env.interpreter}" "-m" "ipykernel_launcher" "-f" "{connection_file}" ];
|
|
logo32 = "${env}/${env.sitePackages}/ipykernel/resources/logo-32x32.png";
|
|
logo64 = "${env}/${env.sitePackages}/ipykernel/resources/logo-64x64.png";
|
|
};
|
|
|
|
jupyterPath = with pkgs; [
|
|
# export
|
|
pandoc
|
|
(texlive.combine {
|
|
inherit (texlive)
|
|
scheme-medium
|
|
|
|
adjustbox
|
|
enumitem
|
|
environ
|
|
pdfcol
|
|
tcolorbox
|
|
titling
|
|
upquote
|
|
;
|
|
})
|
|
];
|
|
in
|
|
{
|
|
services.jupyter = {
|
|
enable = true;
|
|
package = pkgs.python3.pkgs.jupyterlab;
|
|
extraPackages = with pkgs.python3.pkgs; [
|
|
# extensions
|
|
jupyterlab-lsp
|
|
jupyterlab-myst
|
|
jupyterlab-pygments
|
|
jupyterlab-vim
|
|
jupyterlab-vpython
|
|
|
|
# export
|
|
nbconvert
|
|
nbformat
|
|
|
|
# lsp
|
|
python-lsp-server
|
|
python-lsp-ruff
|
|
];
|
|
|
|
# Hosted behind Tailscale, so security doesn't matter
|
|
command = "jupyter-lab --ServerApp.token='' --ServerApp.password=''";
|
|
password = "''";
|
|
ip = "*";
|
|
|
|
user = "infinidoge";
|
|
group = "users";
|
|
notebookDir = "~/Notebooks";
|
|
|
|
kernels = {
|
|
python3 = mkPythonKernel "Python 3" (pkgs.python3.withPackages (p: with p; [
|
|
ipykernel
|
|
|
|
matplotlib
|
|
numpy
|
|
pandas
|
|
scipy
|
|
]));
|
|
vpython = mkPythonKernel "VPython" (pkgs.python3.withPackages (p: with p; [
|
|
ipykernel
|
|
jupyterlab-vpython
|
|
|
|
vpython-jupyter
|
|
matplotlib
|
|
numpy
|
|
pandas
|
|
scipy
|
|
]));
|
|
};
|
|
};
|
|
|
|
systemd.services.jupyter.path = jupyterPath;
|
|
|
|
services.nginx.virtualHosts."jupyter.internal.inx.moe" = common.nginx.ssl // {
|
|
listenAddresses = [ "100.101.102.124" ];
|
|
locations."/" = {
|
|
proxyPass = "http://localhost:${toString cfg.port}";
|
|
proxyWebsockets = true;
|
|
};
|
|
};
|
|
}
|