207 lines
6.5 KiB
Nix
207 lines
6.5 KiB
Nix
{
|
|
description = "System configs";
|
|
|
|
inputs = {
|
|
flake-utils.url = "github:numtide/flake-utils";
|
|
devshell.url = "github:numtide/devshell";
|
|
devshell.inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
|
|
nixpkgs-master.url = "nixpkgs";
|
|
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
|
|
nixpkgs-stable.url = "nixpkgs/nixos-21.11";
|
|
nixpkgs-mine.url = "github:devplayer0/nixpkgs";
|
|
|
|
home-manager-unstable.url = "home-manager";
|
|
home-manager-unstable.inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
home-manager-stable.url = "home-manager/release-21.11";
|
|
home-manager-stable.inputs.nixpkgs.follows = "nixpkgs-stable";
|
|
|
|
# Stuff used by the flake for build / deployment
|
|
agenix.url = "github:ryantm/agenix";
|
|
agenix.inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
|
deploy-rs.inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
|
|
# Stuff used by systems
|
|
#impermanence.url = "github:nix-community/impermanence";
|
|
impermanence.url = "github:devplayer0/impermanence/qemu-vm-dirs";
|
|
};
|
|
|
|
outputs =
|
|
inputs@{
|
|
self,
|
|
|
|
flake-utils,
|
|
|
|
nixpkgs-master, nixpkgs-unstable, nixpkgs-stable, nixpkgs-mine,
|
|
home-manager-unstable, home-manager-stable,
|
|
|
|
...
|
|
}:
|
|
let
|
|
inherit (builtins) mapAttrs attrValues;
|
|
inherit (lib.flake) eachDefaultSystem;
|
|
inherit (lib.my) attrsToList mkApp mkShellApp mkShellApp' inlineModules mkDefaultSystemsPkgs flakePackageOverlay;
|
|
|
|
# Extend a lib with extras that _must not_ internally reference private nixpkgs. flake-utils doesn't, but many
|
|
# other flakes (e.g. home-manager) probably do internally.
|
|
libOverlay = final: prev: {
|
|
my = import ./lib.nix { lib = final; };
|
|
flake = flake-utils.lib;
|
|
};
|
|
pkgsLibOverlay = final: prev: { lib = prev.lib.extend libOverlay; };
|
|
|
|
# Override the flake-level lib since we're going to use it for non-config specific stuff
|
|
pkgsFlakes = mapAttrs (_: pkgsFlake: pkgsFlake // { lib = pkgsFlake.lib.extend libOverlay; }) {
|
|
master = nixpkgs-master;
|
|
unstable = nixpkgs-unstable;
|
|
stable = nixpkgs-stable;
|
|
mine = nixpkgs-mine;
|
|
};
|
|
hmFlakes = {
|
|
unstable = home-manager-unstable;
|
|
stable = home-manager-stable;
|
|
};
|
|
|
|
# Should only be used for platform-independent flake stuff! This should never leak into a NixOS or home-manager
|
|
# config - they'll get their own.
|
|
lib = pkgsFlakes.unstable.lib;
|
|
|
|
# pkgs for dev shell etc
|
|
pkgs' = mapAttrs
|
|
(_: path: mkDefaultSystemsPkgs path (system: {
|
|
overlays = [
|
|
pkgsLibOverlay
|
|
inputs.devshell.overlay
|
|
inputs.agenix.overlay
|
|
inputs.deploy-rs.overlay
|
|
(flakePackageOverlay inputs.home-manager-unstable system)
|
|
];
|
|
}))
|
|
pkgsFlakes;
|
|
|
|
# Easiest to build the basic pkgs here (with our lib overlay too)
|
|
configPkgs' = mapAttrs
|
|
(_: path: mkDefaultSystemsPkgs path (_: {
|
|
overlays = [
|
|
pkgsLibOverlay
|
|
];
|
|
}))
|
|
pkgsFlakes;
|
|
|
|
modules = mapAttrs (_: f: ./. + "/nixos/modules/${f}") {
|
|
common = "common.nix";
|
|
build = "build.nix";
|
|
dynamic-motd = "dynamic-motd.nix";
|
|
tmproot = "tmproot.nix";
|
|
firewall = "firewall.nix";
|
|
server = "server.nix";
|
|
};
|
|
homeModules = mapAttrs (_: f: ./. + "/home-manager/modules/${f}") {
|
|
common = "common.nix";
|
|
gui = "gui.nix";
|
|
};
|
|
in
|
|
# Platform independent stuff
|
|
{
|
|
lib = lib.my;
|
|
nixpkgs = pkgs';
|
|
|
|
nixosModules = inlineModules modules;
|
|
homeModules = inlineModules homeModules;
|
|
|
|
nixosConfigurations = import ./nixos {
|
|
inherit lib pkgsFlakes hmFlakes inputs;
|
|
pkgs' = configPkgs';
|
|
modules = attrValues modules;
|
|
homeModules = attrValues homeModules;
|
|
};
|
|
systems = mapAttrs (_: system: system.config.system.build.toplevel) self.nixosConfigurations;
|
|
vms = mapAttrs (_: system: system.config.my.buildAs.devVM) self.nixosConfigurations;
|
|
isos = mapAttrs (_: system: system.config.my.buildAs.iso) self.nixosConfigurations;
|
|
|
|
homeConfigurations = import ./home-manager {
|
|
inherit lib hmFlakes inputs;
|
|
pkgs' = configPkgs';
|
|
modules = attrValues homeModules;
|
|
};
|
|
homes = mapAttrs(_: home: home.activationPackage) self.homeConfigurations;
|
|
} //
|
|
(eachDefaultSystem (system:
|
|
let
|
|
homeFlake = "$HOME/.config/nixpkgs/flake.nix";
|
|
|
|
pkgs = pkgs'.unstable.${system};
|
|
lib = pkgs.lib;
|
|
in
|
|
# Stuff for each platform
|
|
{
|
|
devShell = pkgs.devshell.mkShell {
|
|
env = attrsToList {
|
|
# starship will show this
|
|
name = "devshell";
|
|
|
|
NIX_USER_CONF_FILES = toString (pkgs.writeText "nix.conf"
|
|
''
|
|
experimental-features = nix-command flakes ca-derivations
|
|
'');
|
|
};
|
|
|
|
packages = with pkgs; [
|
|
coreutils
|
|
nixVersions.stable
|
|
agenix
|
|
deploy-rs.deploy-rs
|
|
home-manager
|
|
];
|
|
|
|
commands = [
|
|
{
|
|
name = "repl";
|
|
category = "utilities";
|
|
help = "Open a `nix repl` with this flake";
|
|
command =
|
|
''
|
|
tmp="$(mktemp --tmpdir repl.nix.XXXXX)"
|
|
echo "builtins.getFlake \"$PRJ_ROOT\"" > "$tmp"
|
|
nix repl "$tmp" || true
|
|
rm "$tmp"
|
|
'';
|
|
}
|
|
{
|
|
name = "home-link";
|
|
category = "utilities";
|
|
help = "Install link to flake.nix for home-manager to use";
|
|
command =
|
|
''
|
|
[ -e "${homeFlake}" ] && echo "${homeFlake} already exists" && exit 1
|
|
|
|
mkdir -p "$(dirname "${homeFlake}")"
|
|
ln -s "$(pwd)/flake.nix" "${homeFlake}"
|
|
echo "Installed link to $(pwd)/flake.nix at ${homeFlake}"
|
|
'';
|
|
}
|
|
{
|
|
name = "home-unlink";
|
|
category = "utilities";
|
|
help = "Remove home-manager flake.nix link";
|
|
command = "rm -f ${homeFlake}";
|
|
}
|
|
|
|
{
|
|
name = "fmt";
|
|
category = "tasks";
|
|
help = pkgs.nixpkgs-fmt.meta.description;
|
|
command = ''exec "${pkgs.nixpkgs-fmt}/bin/nixpkgs-fmt" "$@"'';
|
|
}
|
|
{
|
|
name = "home-switch";
|
|
category = "tasks";
|
|
help = "Run `home-manager switch`";
|
|
command = ''home-manager switch --flake . "$@"'';
|
|
}
|
|
];
|
|
};
|
|
}));
|
|
}
|