2020-01-04 06:06:31 +01:00
|
|
|
{ pkgs ? import <nixpkgs> { } }:
|
2020-01-02 05:55:19 +01:00
|
|
|
let
|
|
|
|
configs = "${toString ./.}#nixosConfigurations";
|
2020-08-02 23:24:00 +02:00
|
|
|
build = "config.system.build";
|
2020-01-02 05:55:19 +01:00
|
|
|
|
2020-08-02 23:24:00 +02:00
|
|
|
rebuild = pkgs.writeShellScriptBin "rebuild" ''
|
|
|
|
if [[ -z $1 ]]; then
|
2020-08-03 00:10:53 +02:00
|
|
|
echo "Usage: $(basename $0) host {switch|boot|test|iso}"
|
2020-08-02 23:24:00 +02:00
|
|
|
elif [[ $1 == "iso" ]]; then
|
|
|
|
nix build ${configs}.niximg.${build}.isoImage
|
|
|
|
else
|
|
|
|
sudo -E nix shell -vv ${configs}.$1.${build}.toplevel -c switch-to-configuration $2
|
|
|
|
fi
|
2020-01-02 05:55:19 +01:00
|
|
|
'';
|
2020-07-31 06:17:28 +02:00
|
|
|
in
|
|
|
|
pkgs.mkShell {
|
2020-07-27 06:24:28 +02:00
|
|
|
name = "nixflk";
|
2020-08-03 00:10:53 +02:00
|
|
|
nativeBuildInputs = with pkgs; [
|
|
|
|
git
|
|
|
|
git-crypt
|
|
|
|
nixFlakes
|
|
|
|
rebuild
|
|
|
|
];
|
2020-01-02 05:01:58 +01:00
|
|
|
|
2020-01-04 01:54:27 +01:00
|
|
|
shellHook = ''
|
|
|
|
mkdir -p secrets
|
2020-07-24 01:03:08 +02:00
|
|
|
PATH=${
|
|
|
|
pkgs.writeShellScriptBin "nix" ''
|
2020-08-02 06:23:35 +02:00
|
|
|
${pkgs.nixFlakes}/bin/nix --option experimental-features "nix-command flakes ca-references" "$@"
|
2020-07-24 01:03:08 +02:00
|
|
|
''
|
|
|
|
}/bin:$PATH
|
2020-01-04 01:54:27 +01:00
|
|
|
'';
|
2020-01-02 05:01:58 +01:00
|
|
|
}
|