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