{ system ? builtins.currentSystem, sources ? import ../npins, pkgs ? import sources.nixpkgs { inherit system; config = { }; overlays = [ (import ./nix/overlay.nix) ]; }, }@args: let inherit (pkgs) lib; manage = pkgs.writeScriptBin "manage" '' exec ${pkgs.lib.getExe pkgs.python3} ${toString ./src/manage.py} $@ ''; in # re-export inputs so they can be overridden granularly # (they can't be accessed from the outside any other way) args // { shell = pkgs.mkShellNoCC { inputsFrom = [ (pkgs.callPackage ./nix/package.nix { }) ]; packages = [ pkgs.npins manage ]; env = import ./env.nix { inherit lib pkgs; } // { NPINS_DIRECTORY = toString ../npins; CREDENTIALS_DIRECTORY = toString ./.credentials; DATABASE_URL = "sqlite:///${toString ./src}/db.sqlite3"; }; shellHook = '' ln -sf ${sources.htmx}/dist/htmx.js src/panel/static/htmx.min.js # in production, secrets are passed via CREDENTIALS_DIRECTORY by systemd. # use this directory for testing with local secrets mkdir -p $CREDENTIALS_DIRECTORY echo secret > ${builtins.toString ./.credentials}/SECRET_KEY ''; }; module = import ./nix/configuration.nix; tests = pkgs.callPackage ./nix/tests.nix { }; } # re-export inputs so they can be overridden granularly # (they can't be accessed from the outside any other way) // args