nixos-config/desktop/default.nix

86 lines
2.1 KiB
Nix
Raw Normal View History

2024-03-10 00:20:39 -08:00
{
pkgs,
...
} @ args: {
imports = [
2024-03-10 00:51:46 -08:00
../base
2024-03-10 00:20:39 -08:00
./common.nix
2024-03-10 00:44:38 -08:00
./compat.nix
./i18n.nix
2024-03-10 00:20:39 -08:00
];
2024-03-10 00:44:38 -08:00
# Bootloader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
# Enable networking
networking.networkmanager.enable = true;
2024-03-10 00:20:39 -08:00
hardware.bluetooth.enable = true;
hardware.bluetooth.powerOnBoot = true;
2024-03-10 00:44:38 -08:00
# Enable the X11 windowing system.
services.xserver.enable = true;
# Enable the KDE Plasma Desktop Environment.
services.xserver.displayManager.sddm.enable = true;
services.xserver.desktopManager.plasma6.enable = true;
services.xserver.desktopManager.gnome.enable = true;
2024-03-10 00:20:39 -08:00
# Set your time zone.
time.timeZone = "America/Los_Angeles";
2024-03-10 00:44:38 -08:00
# Shells
programs.zsh.enable = true;
programs.fish.enable = true;
programs.ssh.startAgent = true;
programs.ssh.askPassword = pkgs.lib.mkForce "${pkgs.ksshaskpass.out}/bin/ksshaskpass";
2024-03-10 00:20:39 -08:00
# Enable CUPS to print documents.
services.printing.enable = true;
services.salt.minion.enable = true;
services.salt.minion.configuration = {
master = "salt.freelock.lan";
location = [ "freelock" ];
};
# 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;
# If you want to use JACK applications, uncomment this
#jack.enable = true;
# use the example session manager (no others are packaged yet so this is enabled by default,
# no need to redefine it in your config for now)
#media-session.enable = true;
};
# Enable touchpad support (enabled default in most desktopManager).
# services.xserver.libinput.enable = true;
# Define a user account. Don't forget to set a password with passwd.
users.users.john = {
isNormalUser = true;
description = "John";
extraGroups = [ "networkmanager" "wheel" "docker" ];
shell = pkgs.fish;
};
# Allow unfree packages
nixpkgs.config.allowUnfree = true;
nixpkgs.config.permittedInsecurePackages = [
"electron-25.9.0"
];
}