mirror of
https://github.com/kaesaecracker/nixos-configuration.git
synced 2025-01-18 10:30:14 +01:00
convoluted solution looking for a problem
unified modules structure
This commit is contained in:
parent
bf3946e06f
commit
1b7989336e
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +1,2 @@
|
|||
.directory
|
||||
result
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
{...}: {
|
||||
{pkgs, ...}: {
|
||||
imports = [
|
||||
./modules/server
|
||||
(import ./modules/hardware "hetzner-vpn1")
|
||||
(import ./modules {
|
||||
hostName = "hetzner-vpn1";
|
||||
enableDesktop = false;
|
||||
})
|
||||
];
|
||||
|
||||
config = {
|
||||
my = {
|
||||
server.enable = true;
|
||||
};
|
||||
my.server.enable = true;
|
||||
|
||||
users.users.root.openssh.authorizedKeys.keys = [
|
||||
''ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICdYqY3Y1/f1bsAi5Qfyr/UWuX9ixu96IeAlhoQaJkbf''
|
||||
|
|
|
@ -1,6 +0,0 @@
|
|||
{...}: {
|
||||
imports = [
|
||||
./i18n.nix
|
||||
./nixpkgs.nix
|
||||
];
|
||||
}
|
16
modules/default.nix
Normal file
16
modules/default.nix
Normal file
|
@ -0,0 +1,16 @@
|
|||
modulesCfg: {lib, ...}: {
|
||||
imports =
|
||||
[
|
||||
./i18n.nix
|
||||
./nixpkgs.nix
|
||||
./server.nix
|
||||
]
|
||||
++ (map (path: (import path modulesCfg)) [
|
||||
./desktop
|
||||
./hardware
|
||||
]);
|
||||
|
||||
config = {
|
||||
my.modulesCfg = modulesCfg;
|
||||
};
|
||||
}
|
|
@ -1,14 +1,14 @@
|
|||
{
|
||||
modulesCfg: {
|
||||
config,
|
||||
pkgs,
|
||||
lib,
|
||||
...
|
||||
}: let
|
||||
isEnabled = modulesCfg.enableDesktop;
|
||||
cfg = config.my.desktop;
|
||||
in {
|
||||
imports = [
|
||||
imports = lib.optionals isEnabled [
|
||||
<home-manager/nixos>
|
||||
../_common
|
||||
./gnome.nix
|
||||
./kde.nix
|
||||
./vinzenz.nix
|
||||
|
@ -16,9 +16,11 @@ in {
|
|||
./gaming.nix
|
||||
];
|
||||
|
||||
options.my.modulesCfg.enableDesktop = lib.mkEnableOption "enable desktop module";
|
||||
|
||||
options.my.desktop = {
|
||||
enable = lib.mkEnableOption "desktop";
|
||||
gnome .enable = lib.mkEnableOption "gnome desktop";
|
||||
gnome.enable = lib.mkEnableOption "gnome desktop";
|
||||
kde.enable = lib.mkEnableOption "KDE desktop";
|
||||
ronja.enable = lib.mkEnableOption "user ronja";
|
||||
vinzenz.enable = lib.mkEnableOption "user vinzenz";
|
||||
|
|
|
@ -1,9 +1,14 @@
|
|||
{
|
||||
lib,
|
||||
pkgs,
|
||||
config,
|
||||
...
|
||||
}: {
|
||||
config = {
|
||||
}: let
|
||||
isEnabled = config.my.hardware.enableCommonDesktopSettings;
|
||||
in {
|
||||
options.my.hardware.enableCommonDesktopSettings = lib.mkEnableOption "common hw settings for desktops";
|
||||
|
||||
config = lib.mkIf isEnabled {
|
||||
boot = {
|
||||
kernelPackages = pkgs.linuxPackages_zen;
|
||||
kernelParams = ["quiet" "udev.log_level=3"];
|
||||
|
|
|
@ -1,13 +1,20 @@
|
|||
hostName: {
|
||||
modulesCfg: {
|
||||
modulesPath,
|
||||
lib,
|
||||
...
|
||||
}: {
|
||||
}: let
|
||||
hostName = modulesCfg.hostName;
|
||||
in {
|
||||
imports = [
|
||||
(modulesPath + "/installer/scan/not-detected.nix")
|
||||
(builtins.toString ./. + "/${hostName}.nix")
|
||||
./common-desktop.nix
|
||||
];
|
||||
|
||||
options.my.modulesCfg.hostName = lib.mkOption {
|
||||
type = lib.types.str;
|
||||
};
|
||||
|
||||
config = {
|
||||
networking.hostName = hostName;
|
||||
|
||||
|
|
|
@ -1,9 +1,7 @@
|
|||
{...}: {
|
||||
imports = [
|
||||
./common-desktop.nix
|
||||
];
|
||||
|
||||
config = {
|
||||
my.hardware.enableCommonDesktopSettings = true;
|
||||
|
||||
boot = {
|
||||
initrd.availableKernelModules = ["xhci_pci" "ehci_pci" "ahci" "usbhid" "usb_storage" "sd_mod" "sdhci_pci"];
|
||||
initrd.kernelModules = [];
|
||||
|
|
|
@ -1,9 +1,7 @@
|
|||
{...}: {
|
||||
imports = [
|
||||
./common-desktop.nix
|
||||
];
|
||||
|
||||
config = {
|
||||
my.hardware.enableCommonDesktopSettings = true;
|
||||
|
||||
boot = {
|
||||
initrd.availableKernelModules = ["nvme" "xhci_pci" "ahci" "usbhid" "sd_mod"]; # "usb_storage"
|
||||
initrd.kernelModules = [];
|
||||
|
|
|
@ -6,10 +6,6 @@
|
|||
}: let
|
||||
cfg = config.my.server;
|
||||
in {
|
||||
imports = [
|
||||
../_common
|
||||
];
|
||||
|
||||
options.my.server = {
|
||||
enable = lib.mkEnableOption "server role";
|
||||
};
|
|
@ -1,18 +1,17 @@
|
|||
{...}: {
|
||||
imports = [
|
||||
./modules/desktop
|
||||
(import ./modules/hardware "vinzenz-lpt")
|
||||
(import ./modules {
|
||||
hostName = "vinzenz-lpt";
|
||||
enableDesktop = true;
|
||||
})
|
||||
];
|
||||
|
||||
config = {
|
||||
my = {
|
||||
desktop = {
|
||||
enable = true;
|
||||
my.desktop = {
|
||||
gnome.enable = true;
|
||||
vinzenz.enable = true;
|
||||
gaming.enable = true;
|
||||
};
|
||||
};
|
||||
|
||||
# flatpak xdg-portal-kde crashes, otherwise this would be global
|
||||
services.flatpak.enable = true;
|
||||
|
|
|
@ -1,12 +1,13 @@
|
|||
{pkgs, ...}: {
|
||||
imports = [
|
||||
./modules/desktop
|
||||
(import ./modules/hardware "vinzenz-pc2")
|
||||
(import ./modules {
|
||||
hostName = "vinzenz-pc2";
|
||||
enableDesktop = true;
|
||||
})
|
||||
];
|
||||
|
||||
config = {
|
||||
my.desktop = {
|
||||
enable = true;
|
||||
kde.enable = true;
|
||||
vinzenz.enable = true;
|
||||
ronja.enable = true;
|
||||
|
|
Loading…
Reference in a new issue