forked from pub-solar/os
e078e7a229
Keep the README.md lean and use DOC.md for more detailed explanations. While revising user documentation, a default `nixos` user profile was created, which serves as a goood base example.
35 lines
1 KiB
Nix
35 lines
1 KiB
Nix
{ pkgs ? import <nixpkgs> { } }:
|
|
let
|
|
configs = "${toString ./.}#nixosConfigurations";
|
|
hostname = pkgs.lib.fileContents /etc/hostname;
|
|
build = "config.system.build";
|
|
|
|
rebuild = pkgs.writeShellScriptBin "rebuild" ''
|
|
if [[ -z $1 ]]; then
|
|
echo "Usage: $0 [host] {switch|boot|test|iso}"
|
|
elif [[ $1 == "iso" ]]; then
|
|
nix build ${configs}.niximg.${build}.isoImage
|
|
elif [[ -z $2 ]]; then
|
|
sudo -E nix run -vv ${configs}.${hostname}.${build}.toplevel -c switch-to-configuration $1
|
|
else
|
|
sudo -E nix run -vv ${configs}.$1.${build}.toplevel -c switch-to-configuration $2
|
|
fi
|
|
'';
|
|
in pkgs.mkShell {
|
|
nativeBuildInputs = with pkgs; [ git git-crypt nixFlakes rebuild ];
|
|
|
|
shellHook = ''
|
|
mkdir -p secrets
|
|
'';
|
|
|
|
NIX_CONF_DIR = let
|
|
current = pkgs.lib.optionalString (builtins.pathExists /etc/nix/nix.conf)
|
|
(builtins.readFile /etc/nix/nix.conf);
|
|
|
|
nixConf = pkgs.writeTextDir "opt/nix.conf" ''
|
|
${current}
|
|
experimental-features = nix-command flakes ca-references
|
|
'';
|
|
in "${nixConf}/opt";
|
|
}
|