Files
nix-config/flake.nix
2024-05-16 15:39:29 +02:00

136 lines
4.3 KiB
Nix

{
description = "Kop's NixOS Flake";
inputs = {
# secrets management
agenix.url = "github:ryantm/agenix";
nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11";
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
home-manager = {
url = "github:nix-community/home-manager/release-23.11";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager-unstable = {
url = "github:nix-community/home-manager/master";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
nixos-wsl = {
url = "github:nix-community/NixOS-WSL";
inputs.nixpkgs.follows = "nixpkgs";
};
nix-colors.url = "github:misterio77/nix-colors";
nur = { url = "github:nix-community/NUR"; };
nixos-cosmic = {
url = "github:lilyinstarlight/nixos-cosmic";
inputs.nixpkgs.follows = "nixpkgs";
};
nixvim = {
url = "github:nix-community/nixvim";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self,
nur,
nixpkgs,
nixos-hardware,
nixos-wsl,
nixpkgs-unstable,
agenix,
home-manager,
home-manager-unstable,
nix-colors,
nixos-cosmic,
nixvim
}@inputs:
let
inherit (self) outputs;
system = "x86_64-linux";
# helper function to create a machine
mkHost = ({modules, specialArgs ? { pkgsVersion = nixpkgs-unstable;}}: nixpkgs-unstable.lib.nixosSystem {
inherit system;
modules = modules ++ [
./modules
({ config, outputs, ... }: { nixpkgs.overlays = with outputs.overlays; [additions modifications unstable-packages nur.overlay]; })
home-manager-unstable.nixosModules.home-manager
agenix.nixosModules.default
nixos-cosmic.nixosModules.default
];
specialArgs = specialArgs // { inherit inputs outputs;};
});
in {
overlays = import ./overlays.nix {inherit inputs;};
nixosConfigurations.server = mkHost {
modules = [
./users/anon
./modules/collections/server.nix
./systems/server/configuration.nix
];
specialArgs = {
## Custom variables (e.g. ip, interface, etc)
vars = import ./systems/userdata-default.nix // import ./systems/server/userdata.nix;
pkgsVersion = nixpkgs-unstable;
};
};
nixosConfigurations."kop-pc" = mkHost {
modules = [
./users/kopatz
./systems/pc/configuration.nix
];
};
nixosConfigurations."nix-laptop" = mkHost {
specialArgs = {
## Custom variables (e.g. ip, interface, etc)
vars = import ./systems/userdata-default.nix // import ./systems/laptop/userdata.nix;
pkgsVersion = nixpkgs-unstable;
inherit nix-colors;
};
modules = [
### User specific ###
./users/kopatz
./systems/laptop/configuration.nix
./modules/collections/laptop.nix
./modules/ecryptfs.nix
./modules/services/syncthing.nix
./modules/fh/scanning.nix
./modules/support/ntfs.nix
./modules/thunderbolt.nix
#./modules/vmware-host.nix
#./modules/fh/forensik.nix
#./modules/no-sleep-lid-closed.nix
#./modules/static-ip.nix
#./modules/wake-on-lan.nix
];
};
nixosConfigurations."mini-pc" = mkHost {
specialArgs = {
vars = import ./systems/userdata-default.nix;
pkgsVersion = nixpkgs-unstable;
};
modules = [
./users/anon
./systems/mini-pc/configuration.nix
];
};
# build vm -> nixos-rebuild build-vm --flake .#vm
nixosConfigurations."vm" = mkHost {
specialArgs = {
vars = import ./systems/userdata-default.nix;
pkgsVersion = nixpkgs-unstable;
};
modules = [
./users/vm
./systems/vm/configuration.nix
];
};
nixosConfigurations."wsl" = mkHost {
modules = [
#"${nixpkgs}/nixos/modules/profiles/minimal.nix"
./users/anon
./modules/nix/settings.nix
./systems/wsl/configuration.nix
];
};
};
}