docs: add generated configurations readme
All checks were successful
Discord / discord commits (push) Has been skipped

This commit is contained in:
matt1432 2025-01-20 19:04:05 -05:00
parent 6aca512b8a
commit 5194199d25
14 changed files with 105 additions and 21 deletions

View file

@ -1,9 +1,11 @@
packageMetaFunc=$(cat << EOF
getMetaFunc=$(cat << EOF
(x: {
attrs = builtins.mapAttrs (_: v: {
desc = builtins.replaceStrings ["\n"] [" "] (v.meta.description or "");
homepage = v.meta.homepage or "";
}) (builtins.removeAttrs x.\${builtins.currentSystem} ["default"]);
roleDesc = builtins.replaceStrings ["\n"] [" "] (v.config.meta.roleDescription or "");
hwDesc = builtins.replaceStrings ["\n"] [" "] (v.config.meta.hardwareDescription or "");
}) (builtins.removeAttrs (x.\${builtins.currentSystem} or x) ["default"]);
})
EOF
)
@ -15,12 +17,13 @@ substitute() {
--impure \
--json \
"$FLAKE"#"$1" \
--apply "$packageMetaFunc" |
--apply "$getMetaFunc" |
jq -r
) -t markdown --template "$2" -o "$3"
) -t markdown --template "$FLAKE/apps/gen-docs/templates/$2.md" -o "$FLAKE/$2/README.md"
}
# TODO: add configurations, homeManagerModules, lib, modules, nixFastChecks, overlays, scopedPackages
substitute "appsPackages" "$FLAKE/apps/gen-docs/templates/apps.md" "$FLAKE/apps/README.md"
substitute "devShells" "$FLAKE/apps/gen-docs/templates/devShells.md" "$FLAKE/devShells/README.md"
substitute "packages" "$FLAKE/apps/gen-docs/templates/packages.md" "$FLAKE/packages/README.md"
# TODO: add homeManagerModules, lib, modules, nixFastChecks, overlays, scopedPackages
substitute "appsPackages" "apps"
substitute "nixosConfigurations" "configurations"
substitute "devShells" "devShells"
substitute "packages" "packages"

View file

@ -0,0 +1,13 @@
# nixosConfigurations
This directory contains every device's main configuration file, their `hardware-configuration.nix` and some custom modules
unique to them.
## List of my Devices
| Name | Model / Specs | Description |
| --------- | ------------- | ------------------------------------------------------------------------------------------------ |
| `android` | OnePlus 9 Pro | [Nix-On-Droid](https://github.com/nix-community/nix-on-droid) configuration for my OnePlus 9 Pro |
$for(attrs/pairs)$
| `$it.key$` | $it.value.hwDesc/nowrap$ | $it.value.roleDesc/nowrap$ |
$endfor$

View file

@ -4,8 +4,8 @@ This directory contains every derivations for packages exposed by this flake.
## List of my packages found in `self.packages`
| Name | Description |
| ---- | ----------- |
| Name | Description | Homepage |
| ---- | ----------- | -------- |
$for(attrs/pairs)$
| `$it.key$` | $it.value.desc/nowrap$ | $it.value.homepage/nowrap$ |
$endfor$

View file

@ -6,13 +6,14 @@ unique to them.
## List of my Devices
| Name | Model / Specs | Description |
| ------------- | --------------------------------------------- | ------------------------------------------------------------------------------------------------------------- |
| --------- | ------------- | ------------------------------------------------------------------------------------------------ |
| `android` | OnePlus 9 Pro | [Nix-On-Droid](https://github.com/nix-community/nix-on-droid) configuration for my OnePlus 9 Pro |
| `bbsteamie` | 512GB OLED | My wife's SteamDeck that has a pink case (it took a lot of convincing for this) |
| `binto` | NVIDIA 3070 with Ryzen 7 3700X | Desktop PC with a multi-monitor setup |
| `cluster` | Lenovo ThinkCentre M900 | Two Lenovo mini PCs that make use of [NixOS-pcsd](https://github.com/matt1432/nixos-pcsd) to form a cluster |
| `live-image` | USB key | Basic configuration that serves as my custom ISO target |
| `homie` | Lenovo Thinkcentre M910q | Mini PC that serves as a Home-assistant server |
| `live-image` | USB key | Basic configuration that serves as my custom ISO target |
| `nos` | NVIDIA 3060 with i5-3600 | Custom built NAS and seedbox for Linux ISOs ;) |
| `servivi` | Headless Ryzen 5 3600 | Gaming PC in a previous life, it is now used as a build farm and hosts game servers |
| `thingone` | Lenovo ThinkCentre M900 | Mini PC that makes use of [NixOS-pcsd](https://github.com/matt1432/nixos-pcsd) to form a cluster with its twin |
| `thingtwo` | Lenovo ThinkCentre M900 | Mini PC that makes use of [NixOS-pcsd](https://github.com/matt1432/nixos-pcsd) to form a cluster with its twin |
| `wim` | ThinkPad L13 Yoga Gen 3 (Ryzen 7 PRO 5875U) | 2-1 Lenovo Laptop that I use for university |

View file

@ -13,6 +13,7 @@
self.nixosModules.base
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.plymouth
self.nixosModules.server
];
@ -41,6 +42,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "My wife's SteamDeck that has a pink case (it took a lot of convincing for this)";
hardwareDescription = "512GB OLED";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -14,6 +14,7 @@
self.nixosModules.base
self.nixosModules.desktop
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.server
];
@ -49,6 +50,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "Desktop PC with a multi-monitor setup";
hardwareDescription = "NVIDIA 3070 with Ryzen 7 3700X";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -16,6 +16,7 @@ in {
self.nixosModules.base
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.server
];
@ -53,6 +54,14 @@ in {
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = ''
Mini PC that makes use of [NixOS-pcsd](https://github.com/matt1432/nixos-pcsd)
to form a cluster with its twin. Files located in `cluster`
'';
hardwareDescription = "Lenovo ThinkCentre M900";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -14,6 +14,7 @@
self.nixosModules.base
self.nixosModules.docker
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.server
];
@ -42,6 +43,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "Mini PC that serves as a Home-assistant server";
hardwareDescription = "Lenovo Thinkcentre M910q";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -11,12 +11,18 @@
"${nixpkgs}/nixos/modules/installer/cd-dvd/installation-cd-minimal.nix"
self.nixosModules.base
self.nixosModules.meta
self.nixosModules.server
];
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "Basic configuration that serves as my custom ISO target";
hardwareDescription = "USB key";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -14,6 +14,7 @@
self.nixosModules.base
self.nixosModules.docker
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.server
];
@ -43,6 +44,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "Custom built NAS and seedbox for Linux ISOs ;)";
hardwareDescription = "NVIDIA 3060 with i5-3600";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -14,6 +14,7 @@
self.nixosModules.base
self.nixosModules.docker
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.server
];
@ -56,6 +57,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "Gaming PC in a previous life, it is now used as a build farm and hosts game servers";
hardwareDescription = "Headless Ryzen 5 3600";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -16,6 +16,7 @@
self.nixosModules.desktop
self.nixosModules.docker
self.nixosModules.kmscon
self.nixosModules.meta
self.nixosModules.plymouth
self.nixosModules.server
];
@ -59,6 +60,11 @@
# ------------------------------------------------
# `Self` Modules configuration
# ------------------------------------------------
meta = {
roleDescription = "2-1 Lenovo Laptop that I use for university";
hardwareDescription = "ThinkPad L13 Yoga Gen 3 (Ryzen 7 PRO 5875U)";
};
roles.base = {
enable = true;
user = mainUser;

View file

@ -9,6 +9,7 @@ self: {
ha-plus = import ./ha-plus;
kmscon = import ./kmscon;
nvidia = import ./nvidia;
meta = import ./meta;
plymouth = import ./plymouth;
server = import ./server;
tmux = import ./tmux;

15
modules/meta/default.nix Normal file
View file

@ -0,0 +1,15 @@
{lib, ...}: let
inherit (lib) mkOption types;
in {
options.meta = {
roleDescription = mkOption {
type = types.str;
default = "";
};
hardwareDescription = mkOption {
type = types.str;
default = "";
};
};
}