165 lines
6.1 KiB
Nix
165 lines
6.1 KiB
Nix
{
|
|
description = "Kop's NixOS Flake";
|
|
inputs = {
|
|
# secrets management
|
|
agenix.url = "github:ryantm/agenix";
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
|
|
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
|
|
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-24.05";
|
|
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-unstable";
|
|
};
|
|
nixvim = {
|
|
url = "github:nix-community/nixvim";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
stylix.url = "github:danth/stylix";
|
|
disko.url = "github:nix-community/disko";
|
|
disko.inputs.nixpkgs.follows = "nixpkgs";
|
|
flake-utils.url = "github:numtide/flake-utils";
|
|
hyprland.url = "git+https://github.com/hyprwm/Hyprland?submodules=1";
|
|
};
|
|
outputs = { self, nur, nixpkgs, nixos-hardware, nixos-wsl, nixpkgs-unstable
|
|
, agenix, home-manager, home-manager-unstable, nix-colors, nixos-cosmic
|
|
, nixvim, stylix, disko, flake-utils, ... }@inputs:
|
|
let
|
|
inherit (self) outputs;
|
|
system = "x86_64-linux";
|
|
overlays = { outputs, ... }: {
|
|
nixpkgs.overlays = with outputs.overlays; [
|
|
additions
|
|
modifications
|
|
unstable-packages
|
|
stable-packages
|
|
nur.overlay
|
|
];
|
|
};
|
|
# helper function to create a machine
|
|
mkHost = { modules, specialArgs ? {
|
|
pkgsVersion = nixpkgs-unstable;
|
|
home-manager-version = home-manager-unstable;
|
|
}, system ? "x86_64-linux", minimal ? false, graphical ? true }:
|
|
let lib = specialArgs.pkgsVersion.lib;
|
|
in specialArgs.pkgsVersion.lib.nixosSystem {
|
|
inherit system;
|
|
modules = modules
|
|
++ [ ./modules agenix.nixosModules.default overlays ]
|
|
++ lib.lists.optionals (!minimal)
|
|
[ specialArgs.home-manager-version.nixosModules.home-manager ]
|
|
++ lib.lists.optionals (!minimal && graphical) [
|
|
./modules/graphical
|
|
stylix.nixosModules.stylix
|
|
./modules/graphical/stylix.nix
|
|
nixos-cosmic.nixosModules.default
|
|
./modules/graphical/cosmic.nix
|
|
({ outputs, ... }: { stylix.image = ./yuyukowallpaper.png; })
|
|
];
|
|
specialArgs = specialArgs // { inherit inputs outputs; };
|
|
};
|
|
mkStableServer = { modules, specialArgs ? {
|
|
pkgsVersion = nixpkgs;
|
|
home-manager-version = home-manager;
|
|
}, system ? "x86_64-linux", minimal ? false }:
|
|
let lib = specialArgs.pkgsVersion.lib;
|
|
in specialArgs.pkgsVersion.lib.nixosSystem {
|
|
inherit system;
|
|
modules = modules
|
|
++ [ ./modules agenix.nixosModules.default overlays ]
|
|
++ lib.lists.optionals (!minimal)
|
|
[ specialArgs.home-manager-version.nixosModules.home-manager ];
|
|
specialArgs = specialArgs // { inherit inputs outputs; };
|
|
};
|
|
in flake-utils.lib.eachDefaultSystem (system: {
|
|
packages =
|
|
import ./pkgs { pkgs = nixpkgs-unstable.legacyPackages.${system}; };
|
|
}) // {
|
|
|
|
overlays = import ./overlays.nix { inherit inputs; };
|
|
|
|
nixosConfigurations = {
|
|
"kop-pc" = mkHost {
|
|
modules = [ ./users/kopatz ./systems/pc/configuration.nix ];
|
|
};
|
|
"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;
|
|
home-manager-version = home-manager-unstable;
|
|
inherit nix-colors;
|
|
};
|
|
modules = [
|
|
### User specific ###
|
|
./users/kopatz
|
|
./systems/laptop/configuration.nix
|
|
./modules/collections/laptop.nix
|
|
./modules/ecryptfs.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
|
|
nixos-hardware.nixosModules.dell-xps-15-7590-nvidia
|
|
];
|
|
};
|
|
"mini-pc" = mkStableServer {
|
|
modules = [ ./users/anon ./systems/mini-pc/configuration.nix ];
|
|
};
|
|
"mini-pc-proxmox" = mkStableServer {
|
|
modules =
|
|
[ ./users/anon ./systems/mini-pc-proxmox/configuration.nix ];
|
|
};
|
|
"wsl" = mkHost {
|
|
modules = [
|
|
#"${nixpkgs}/nixos/modules/profiles/minimal.nix"
|
|
./users/anon
|
|
./modules/nix/settings.nix
|
|
./systems/wsl/configuration.nix
|
|
nixos-wsl.nixosModules.wsl
|
|
];
|
|
};
|
|
#initial install done with nix run github:nix-community/nixos-anywhere/73a6d3fef4c5b4ab9e4ac868f468ec8f9436afa7 -- --flake .#adam-site root@<ip>
|
|
#update with nixos-rebuild switch --flake .#adam-site --target-host "root@<ip>"
|
|
"adam-site" = mkStableServer {
|
|
minimal = true;
|
|
system = "aarch64-linux";
|
|
specialArgs = {
|
|
pkgsVersion = nixpkgs;
|
|
home-manager-version = home-manager;
|
|
};
|
|
modules =
|
|
[ disko.nixosModules.disko ./systems/adam-site/configuration.nix ];
|
|
};
|
|
"proxmox-test-vm" = mkHost {
|
|
minimal = true;
|
|
modules = [
|
|
disko.nixosModules.disko
|
|
./systems/proxmox-test-vm/configuration.nix
|
|
];
|
|
};
|
|
# build vm -> nixos-rebuild build-vm --flake .#vm
|
|
"vm" =
|
|
mkHost { modules = [ ./users/vm ./systems/vm/configuration.nix ]; };
|
|
};
|
|
};
|
|
}
|