This repository has been archived on 2024-07-08. You can view files and clone it, but cannot push or open issues or pull requests.
nix-config-tn/flake.nix

183 lines
5.8 KiB
Nix
Raw Normal View History

2024-03-13 06:55:17 -05:00
{
2024-05-31 09:21:59 -05:00
description = "My NixOS homelab";
2024-03-13 06:55:17 -05:00
inputs = {
# Nixpkgs and unstable
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
nixpkgs-stable.url = "github:nixos/nixpkgs/nixos-23.11";
# impermanence
# https://github.com/nix-community/impermanence
impermanence.url = "github:nix-community/impermanence";
# nur
nur.url = "github:nix-community/NUR";
# nix-community hardware quirks
# https://github.com/nix-community
2024-03-18 16:16:39 -05:00
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
# home-manager - unstable
# https://github.com/nix-community/home-manager
2024-03-18 16:16:39 -05:00
home-manager = {
url = "github:nix-community/home-manager/master";
2024-03-18 16:16:39 -05:00
inputs.nixpkgs.follows = "nixpkgs";
};
2024-03-13 06:55:17 -05:00
# home-manager - stable
# https://github.com/nix-community/home-manager
home-manager-stable = {
url = "github:nix-community/home-manager/release-23.11";
inputs.nixpkgs.follows = "nixpkgs-stable";
};
# sops-nix - secrets with mozilla sops
# https://github.com/Mic92/sops-nix
2024-03-13 06:55:17 -05:00
sops-nix = {
url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-03-13 06:55:17 -05:00
# VSCode community extensions
# https://github.com/nix-community/nix-vscode-extensions
2024-03-13 06:55:17 -05:00
nix-vscode-extensions = {
url = "github:nix-community/nix-vscode-extensions";
inputs.nixpkgs.follows = "nixpkgs";
};
# nix-index database
# https://github.com/nix-community/nix-index-database
nix-index-database = {
url = "github:nix-community/nix-index-database";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-05-10 10:06:16 -05:00
# nix-inspect - inspect nix derivations usingn a TUI interface
# https://github.com/bluskript/nix-inspect
nix-inspect = {
url = "github:bluskript/nix-inspect";
};
2024-03-13 06:55:17 -05:00
};
2024-05-31 09:21:59 -05:00
2024-03-18 04:26:02 -05:00
outputs =
{ self
, nixpkgs
, sops-nix
, home-manager
, nix-vscode-extensions
, impermanence
2024-03-18 04:26:02 -05:00
, ...
} @ inputs:
2024-03-24 02:34:14 -05:00
2024-03-18 04:26:02 -05:00
let
inherit (self) outputs;
forAllSystems = nixpkgs.lib.genAttrs [
"aarch64-linux"
"x86_64-linux"
];
in
rec {
2024-03-13 06:55:17 -05:00
# Use nixpkgs-fmt for 'nix fmt'
2024-03-18 04:06:00 -05:00
formatter = forAllSystems (system: nixpkgs.legacyPackages."${system}".nixpkgs-fmt);
2024-03-13 06:55:17 -05:00
# setup devshells against shell.nix
2024-05-30 21:33:06 -05:00
# devShells = forAllSystems (pkgs: import ./shell.nix { inherit pkgs; });
# extend lib with my custom functions
lib = nixpkgs.lib.extend (
final: prev: {
inherit inputs;
myLib = import ./nixos/lib { inherit inputs; lib = final; };
}
);
2024-03-18 16:16:39 -05:00
nixosConfigurations =
let
inherit inputs outputs;
# Import overlays for building nixosconfig with them.
overlays = import ./nixos/overlays { inherit inputs; };
2024-03-23 04:45:09 -05:00
# generate a base nixos configuration with the
# specified overlays, hardware modules, and any extraModules applied
mkNixosConfig =
{ hostname
, system ? "x86_64-linux"
, nixpkgs ? inputs.nixpkgs
2024-03-24 07:21:13 -05:00
, hardwareModules ? [ ]
# basemodules is the base of the entire machine building
# here we import all the modules and setup home-manager
2024-03-23 04:45:09 -05:00
, baseModules ? [
sops-nix.nixosModules.sops
home-manager.nixosModules.home-manager
impermanence.nixosModules.impermanence
./nixos/profiles/global.nix # all machines get a global profile
./nixos/modules/nixos # all machines get nixos modules
./nixos/hosts/${hostname} # load this host's config folder for machine-specific config
{
home-manager = {
useUserPackages = true;
useGlobalPkgs = true;
extraSpecialArgs = {
inherit inputs hostname system;
};
};
}
2024-03-23 04:45:09 -05:00
]
2024-03-24 17:23:35 -05:00
, profileModules ? [ ]
2024-03-23 04:45:09 -05:00
}:
nixpkgs.lib.nixosSystem {
inherit system lib;
2024-03-24 17:23:35 -05:00
modules = baseModules ++ hardwareModules ++ profileModules;
2024-03-23 04:45:09 -05:00
specialArgs = { inherit self inputs nixpkgs; };
# Add our overlays
pkgs = import nixpkgs {
inherit system;
overlays = builtins.attrValues overlays;
config = {
allowUnfree = true;
allowUnfreePredicate = _: true;
};
};
2024-03-23 04:45:09 -05:00
};
2024-03-18 16:16:39 -05:00
in
{
2024-05-10 10:06:16 -05:00
"durincore" = mkNixosConfig {
# T470 Thinkpad
# Nix dev laptop
2024-05-10 10:06:16 -05:00
hostname = "durincore";
2024-03-21 06:59:23 -05:00
system = "x86_64-linux";
2024-03-23 04:45:09 -05:00
hardwareModules = [
2024-05-10 10:12:30 -05:00
./nixos/profiles/hw-thinkpad-t470.nix
2024-05-10 10:06:16 -05:00
inputs.nixos-hardware.nixosModules.lenovo-thinkpad-t470s
2024-03-21 06:59:23 -05:00
];
2024-03-24 17:23:35 -05:00
profileModules = [
2024-05-10 10:15:37 -05:00
./nixos/profiles/role-workstation.nix
2024-05-05 06:51:48 -05:00
./nixos/profiles/role-dev.nix
2024-05-10 10:06:16 -05:00
{ home-manager.users.jahanson = ./nixos/home/jahanson/workstation.nix; }
];
};
2024-05-10 16:50:09 -05:00
"varda" = mkNixosConfig {
# Arm64 cax21 @ Hetzner
# forgejo server
2024-05-10 16:50:09 -05:00
hostname = "varda";
system = "aarch64-linux";
hardwareModules = [
./nixos/profiles/hw-hetzner-cax.nix
];
profileModules = [
./nixos/profiles/role-server.nix
2024-05-10 20:45:26 -05:00
{ home-manager.users.jahanson = ./nixos/home/jahanson/server.nix; }
2024-05-10 16:50:09 -05:00
];
};
2024-03-18 16:16:39 -05:00
};
# Convenience output that aggregates the outputs for home, nixos.
2024-03-26 07:11:49 -05:00
# Also used in ci to build targets generally.
top =
let
nixtop = nixpkgs.lib.genAttrs
(builtins.attrNames inputs.self.nixosConfigurations)
(attr: inputs.self.nixosConfigurations.${attr}.config.system.build.toplevel);
in
nixtop;
2024-03-16 07:46:36 -05:00
};
}