forked from Fediversity/Fediversity
Co-authored-by: Valentin Gagarin <valentin.gagarin@tweag.io> Reviewed-on: Fediversity/Fediversity#412 Reviewed-by: Valentin Gagarin <valentin.gagarin@tweag.io> Co-authored-by: Kiara Grouwstra <kiara@procolix.eu> Co-committed-by: Kiara Grouwstra <kiara@procolix.eu>
57 lines
1.5 KiB
Nix
57 lines
1.5 KiB
Nix
{
|
|
system ? builtins.currentSystem,
|
|
sources ? import ../npins,
|
|
pkgs ? import sources.nixpkgs {
|
|
inherit system;
|
|
config = { };
|
|
overlays = [ (import ./nix/overlay.nix) ];
|
|
},
|
|
}:
|
|
let
|
|
inherit (pkgs) lib;
|
|
manage = pkgs.writeScriptBin "manage" ''
|
|
exec ${pkgs.lib.getExe pkgs.python3} ${toString ./src/manage.py} $@
|
|
'';
|
|
package = pkgs.callPackage ./nix/package.nix { };
|
|
in
|
|
{
|
|
shell = pkgs.mkShellNoCC {
|
|
inputsFrom = [ package ];
|
|
packages = [
|
|
pkgs.npins
|
|
manage
|
|
|
|
pkgs.nixops4
|
|
pkgs.nix
|
|
pkgs.openssh
|
|
];
|
|
env = {
|
|
DEPLOYMENT_FLAKE = toString ../.;
|
|
DEPLOYMENT_NAME = "test";
|
|
NPINS_DIRECTORY = toString ../npins;
|
|
CREDENTIALS_DIRECTORY = toString ./.credentials;
|
|
DATABASE_URL = "sqlite:///${toString ./src}/db.sqlite3";
|
|
};
|
|
shellHook = ''
|
|
${lib.concatStringsSep "\n" (
|
|
map (file: "ln -sf ${file.from} ${toString ./src/${file.to}}") package.generated
|
|
)}
|
|
|
|
# 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)
|
|
inherit
|
|
sources
|
|
system
|
|
pkgs
|
|
;
|
|
}
|