nixos-configuration/modules/desktop/default.nix

111 lines
2.3 KiB
Nix
Raw Normal View History

2023-09-24 12:39:28 +02:00
{
2023-09-09 15:44:15 +02:00
config,
pkgs,
lib,
...
}: let
cfg = config.my.desktop;
in {
2023-09-24 12:39:28 +02:00
imports = [
./gnome.nix
./kde.nix
./gaming.nix
];
options.my.desktop.enable = lib.mkEnableOption "desktop";
2023-09-09 15:44:15 +02:00
config = lib.mkIf cfg.enable {
2023-09-11 19:16:26 +02:00
home-manager.useUserPackages = true;
home-manager.useGlobalPkgs = true;
2023-09-09 15:44:15 +02:00
services = {
# Enable the X11 windowing system / wayland depending on DE
xserver.enable = true;
# Enable CUPS to print documents.
printing.enable = true;
2023-09-10 14:12:01 +02:00
2023-09-11 19:16:26 +02:00
# Enable the OpenSSH daemon.
openssh = {
enable = true;
settings = {
PermitRootLogin = "no";
PasswordAuthentication = false;
KbdInteractiveAuthentication = false;
};
};
2023-09-09 15:44:15 +02:00
};
# Enable sound with pipewire.
sound.enable = true;
hardware.pulseaudio.enable = false;
security.rtkit.enable = true;
services.pipewire = {
enable = true;
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
};
programs = {
2023-09-24 12:39:28 +02:00
git.package = pkgs.gitFull;
2023-09-09 15:44:15 +02:00
steam = {
enable = true;
remotePlay.openFirewall = true; # Open ports in the firewall for Steam Remote Play
dedicatedServer.openFirewall = true; # Open ports in the firewall for Source Dedicated Server
};
};
# unblock kde connect / gsconnect
2023-09-11 19:16:26 +02:00
networking = {
networkmanager.enable = true;
firewall.enable = true;
firewall = {
allowedTCPPortRanges = [
{
# KDE Connect
from = 1714;
to = 1764;
}
];
allowedUDPPortRanges = [
{
# KDE Connect
from = 1714;
to = 1764;
}
];
};
};
2023-09-17 14:03:37 +02:00
systemd = {
# save some boot time because nothing actually requires network connectivity
services.NetworkManager-wait-online.enable = false;
extraConfig = ''
DefaultTimeoutStopSec=12s
'';
};
2023-09-11 19:16:26 +02:00
environment = {
pathsToLink = ["/share/zsh"];
systemPackages = with pkgs; [
lm_sensors
2023-09-09 15:44:15 +02:00
];
};
2023-09-11 21:00:02 +02:00
nixpkgs.config.permittedInsecurePackages = [
"electron-12.2.3"
];
2023-09-17 16:54:18 +02:00
fonts = {
2023-09-17 16:56:11 +02:00
fontconfig.defaultFonts.monospace = ["FiraCode Nerd Font"];
2023-09-17 16:54:18 +02:00
fonts = with pkgs; [
(nerdfonts.override {fonts = ["FiraCode"];})
];
};
2023-09-09 15:44:15 +02:00
};
}