262 lines
7.5 KiB
Nix
262 lines
7.5 KiB
Nix
{
|
|
description = "Kop's NixOS Flake";
|
|
inputs = {
|
|
flake-utils.url = "github:numtide/flake-utils";
|
|
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
|
|
# nix user repository
|
|
nur = {
|
|
url = "github:nix-community/NUR";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
## stable
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-25.11";
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-25.11";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
# secrets management
|
|
agenix = {
|
|
url = "github:ryantm/agenix";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.home-manager.follows = "home-manager";
|
|
};
|
|
## unstable
|
|
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
|
nixpkgs-xr.url = "github:nix-community/nixpkgs-xr";
|
|
home-manager-unstable = {
|
|
url = "github:nix-community/home-manager/master";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
nixpkgs-working-xrdp.url = "github:NixOS/nixpkgs/b26c89e6aa1d7731d5e267656207f2e1c2f37f1d";
|
|
# cosmic testing
|
|
#nixos-cosmic = {
|
|
# url = "github:lilyinstarlight/nixos-cosmic";
|
|
# inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
#};
|
|
# vim configuration with nix
|
|
nixvim = {
|
|
url = "github:nix-community/nixvim";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
# styling
|
|
stylix = {
|
|
#url = "github:danth/stylix";
|
|
url = "github:make-42/stylix/matugen";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
inputs.home-manager.follows = "home-manager-unstable";
|
|
};
|
|
# disk management
|
|
disko = {
|
|
url = "github:nix-community/disko";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
#hyprland = {
|
|
# url = "git+https://github.com/hyprwm/Hyprland?submodules=1";
|
|
# inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
#};
|
|
#quickshell = {
|
|
# url = "git+https://git.outfoxxed.me/outfoxxed/quickshell";
|
|
# inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
#};
|
|
};
|
|
outputs =
|
|
{
|
|
self,
|
|
nur,
|
|
nixpkgs,
|
|
nixos-hardware,
|
|
nixpkgs-unstable,
|
|
agenix,
|
|
home-manager,
|
|
home-manager-unstable,
|
|
#, nixos-cosmic
|
|
nixvim,
|
|
stylix,
|
|
disko,
|
|
flake-utils,
|
|
...
|
|
}@inputs:
|
|
let
|
|
inherit (self) outputs;
|
|
overlays =
|
|
{ outputs, ... }:
|
|
{
|
|
nixpkgs.overlays = with outputs.overlays; [
|
|
#unstable-packages
|
|
stable-packages
|
|
additions
|
|
modifications
|
|
nur.overlays.default
|
|
];
|
|
};
|
|
defaultModules = [
|
|
./modules
|
|
agenix.nixosModules.default
|
|
overlays
|
|
];
|
|
# 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
|
|
++ defaultModules
|
|
++ lib.lists.optionals (!minimal) [ specialArgs.home-manager-version.nixosModules.home-manager ]
|
|
++ lib.lists.optionals (!minimal && graphical) [
|
|
stylix.nixosModules.stylix
|
|
inputs.nixpkgs-xr.nixosModules.nixpkgs-xr
|
|
./modules/graphical/stylix.nix
|
|
#nixos-cosmic.nixosModules.default
|
|
#./modules/graphical/cosmic.nix
|
|
(
|
|
{ outputs, ... }:
|
|
{
|
|
stylix.image = ./wallpaper/tsukasa.jpg;
|
|
}
|
|
)
|
|
];
|
|
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;
|
|
};
|
|
};
|
|
customPackages = flake-utils.lib.eachDefaultSystem (system: {
|
|
packages = import ./pkgs { pkgs = nixpkgs-unstable.legacyPackages.${system}; };
|
|
});
|
|
in
|
|
{
|
|
overlays = import ./overlays.nix { inherit inputs; };
|
|
|
|
nixosConfigurations = {
|
|
"kop-pc" = mkHost {
|
|
modules = [
|
|
./users/kopatz
|
|
#./users/testuser
|
|
./systems/pc/configuration.nix
|
|
];
|
|
};
|
|
"test-pc" = mkHost {
|
|
modules = [
|
|
./users/kopatz
|
|
./systems/test-pc/configuration.nix
|
|
];
|
|
};
|
|
|
|
"zel-mini-pc" = mkHost {
|
|
modules = [
|
|
disko.nixosModules.disko
|
|
./users/kopatz
|
|
./systems/zel-mini-pc/configuration.nix
|
|
nixos-hardware.nixosModules.common-gpu-intel-kaby-lake
|
|
];
|
|
};
|
|
"framework" = mkHost {
|
|
modules = [
|
|
### User specific ###
|
|
disko.nixosModules.disko
|
|
./users/kopatz
|
|
./systems/laptop/configuration.nix
|
|
];
|
|
};
|
|
"dell" = mkHost {
|
|
modules = [
|
|
### User specific ###
|
|
disko.nixosModules.disko
|
|
./users/kopatz
|
|
./systems/dell/configuration.nix
|
|
];
|
|
};
|
|
#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
|
|
];
|
|
};
|
|
"amd-server" = mkHost {
|
|
modules = [
|
|
./users/kopatz
|
|
./systems/amd-server/configuration.nix
|
|
];
|
|
};
|
|
"amd-server-vpn-vm" = mkHost {
|
|
modules = [
|
|
./users/anon
|
|
./systems/amd-server-vpn-vm/configuration.nix
|
|
disko.nixosModules.disko
|
|
];
|
|
};
|
|
# build vm -> nixos-rebuild build-vm --flake .#vm
|
|
"vm" = mkHost {
|
|
modules = [
|
|
./users/vm
|
|
./systems/vm/configuration.nix
|
|
];
|
|
};
|
|
# nixos-rebuild switch --flake .#server-vm --target-host root@192.168.0.21
|
|
"server-vm" = mkHost {
|
|
minimal = true;
|
|
modules = [
|
|
./users/anon
|
|
./systems/amd-server-vm/configuration.nix
|
|
disko.nixosModules.disko
|
|
];
|
|
};
|
|
"portable-ssd" = mkHost {
|
|
modules = [
|
|
./users/kopatz
|
|
./systems/portable-ssd/configuration.nix
|
|
];
|
|
};
|
|
};
|
|
|
|
packages = customPackages.packages;
|
|
};
|
|
}
|