# Edit this configuration file to define what should be installed on # your system. Help is available in the configuration.nix(5) man page # and in the NixOS manual (accessible by running ‘nixos-help’). { inputs, config, pkgs, myhostname, ... }: let theme = "mocha"; in { imports = [ ./hardware-configuration.nix ../../moduler/base.nix ../../moduler/users.nix ../../moduler/git.nix ../../moduler/network.nix ../../moduler/programs.nix ../../moduler/system.nix ../../moduler/dev.nix ../../moduler/lsp.nix ../../moduler/hyprland.nix ../../moduler/sound.nix ../../moduler/programs/kubernetes-tools.nix ../../moduler/programs/confetti ]; kubernetes-tools.enable = true; networking.networkmanager = { enable = true; plugins = with pkgs; [ networkmanager-openvpn ]; }; stylix = { enable = true; base16Scheme = "${pkgs.base16-schemes}/share/themes/catppuccin-${theme}.yaml"; }; programs.ssh.knownHosts = { desktop = { extraHostNames = [ "192.168.1.227" ]; publicKeyFile = ../../keys/rsa_pubkey; }; "192.168.1.227" = { publicKeyFile = ../../keys/rsa_pubkey; }; }; hyprland = { enable = true; theme = theme; }; home-manager.extraSpecialArgs = { inherit inputs pkgs; }; home-manager.users.fw = { imports = [ ./../../moduler/home.nix ./../../moduler/programs/waybar inputs.catppuccin.homeModules.catppuccin ]; waybar = { enable = true; configPath = ./../../moduler/programs/waybar/waybar.jsonc; stylePath = ./../../moduler/programs/waybar/waybar-${theme}.css; }; gtk = { enable = true; iconTheme = { name = "oomox-gruvbox-dark"; package = pkgs.gruvbox-dark-icons-gtk; }; }; kitty = { enable = true; theme = theme; }; fish = { theme = theme; }; k9s = { enable = true; theme = theme; }; programs.zsh = { enable = true; enableCompletion = true; autosuggestion.enable = true; syntaxHighlighting.enable = true; shellAliases = { ll = "ls -l"; update = "sudo nixos-rebuild switch"; }; history.size = 10000; }; oh-my-posh = { enable = true; theme = theme; }; catppuccin = { librewolf = { enable = true; flavor = theme; accent = "peach"; }; }; programs.ranger.enable = true; stylix.targets = { lazygit.enable = false; fish.enable = false; kitty.enable = false; waybar.enable = false; tmux.enable = false; k9s.enable = false; }; }; security.sudo.wheelNeedsPassword = false; users.users.root.openssh.authorizedKeys.keys = [ "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDALsdpwvC0w/Aj+1fWtzJyyWoUrGkdh8o2thVHeQQBNo0D7cmVberYmi4Cv9gWGX6PaElrnOl0KRdGyro2wxOYokSxgk2VgWW67BFITAQAbKyG2NhXXPbhb4jccDo7WH7TtOG8IofuJTPRu1Duda6k4RN0I0CkyAN6LGX+zy49cq0qKf9ijXYhCDYNih3+Fu/ig0aW/SYmsVoUl2VFTWdI5x5/wLvIjTEZhmAtYIeYADaLnom356cFrUysZa++FUujQAz3Ow236BvP95XZdTsqvfWNZFNIpC9VYF72JeIDCs5wDIr0GFmanF2On1nar+jJpoOE8SdHt357p5g/PqXV5TisN2xQRkqVwO9tWtMl4sF84jA4ULnY2gQWv9jErMxymUQ1IwuPUzDDlbRHCtfexAtkBy7wv6xslKAzG1QahvF/btNs5Caj3LN31rgAuxyooCbKGKTeBP3kHPKcz1iupgidfbO/QqVXBRQJTEdGyAKa8hVmLQZZPC/XUhxESAk= fw@fw-nix" "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC8ku8iCb7tXd/tfxYDW+Tj8K9kpfrYZciYUZ6tBpO80inm4EImtfyEeJTuqDWMKov2BftUKs8brNeTBCXUEvU1P0+cpOP9RtYA5tfBXf3su+iVSswJJStIxNboXHrEGKdJJRNsTv/9agshDSUBy6G5TI1cXhv/updornfA4fwOMqOmtlYEn6XCRnsrO6NBLc/uLckdbF75HOsoLvezRvuqTLjpapjaUKGVPrgNXiclIKHmuOx71kgD4FX3rSz9FgKjnfu3a7DBbrHsf/g+N9PjNF1muN9UOV6nK3WwiO9BMWi7NpAWfzJOeZg9chqzI+U6CcsqYVeESgL41so+dnv3 fw@laptop" "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIP34dnsZSnWdDvd+3BXDwcw7wP0PjPEx2eCdBQJyGD6O fw@laptop" "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAII60tdNsG0z9q2jHmoTKvkeLQE6OF0bmTsDX1bpqpoG7 fw@jobb" ]; services.upower = { enable = true; }; boot.kernelPackages = pkgs.linuxPackages_latest; networking.hostName = myhostname; system.stateVersion = "25.05"; }