dotfiles/provision/nixos/hosts/kestrel/configuration.nix

129 lines
2.9 KiB
Nix
Raw Normal View History

2023-07-10 17:52:34 -07:00
{ config, pkgs, user, lib, ... }:
{
nix = {
package = pkgs.nixFlakes;
extraOptions = "experimental-features = nix-command flakes";
settings.auto-optimise-store = true;
gc = {
automatic = true;
dates = "weekly";
options = "--delete-older-than 7d";
};
};
# Add non-free packages
nixpkgs.config.allowUnfree = true;
nixpkgs.overlays = import ../../lib/overlays.nix;
# Use zen kernel
boot.kernelPackages = pkgs.linuxPackages_zen;
# Hardware options
hardware.bluetooth.enable = true;
hardware.sensor.iio.enable = true;
hardware.opengl.enable = true;
hardware.opengl.driSupport = true;
hardware.opengl.driSupport32Bit = true;
# Use the systemd-boot EFI boot loader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
# Set networking options
networking.hostName = "kestrel";
networking.networkmanager.enable = true;
2023-07-23 14:34:39 -07:00
networking.firewall.checkReversePath = "loose";
2023-08-21 21:05:02 -07:00
networking.firewall.enable = false;
2023-07-10 17:52:34 -07:00
# Set your time zone.
time.timeZone = "America/Los_Angeles";
i18n.defaultLocale = "en_US.UTF-8";
# Enable sound.
sound.enable = true;
hardware.pulseaudio.enable = true;
hardware.pulseaudio.support32Bit = true;
# Add fonts
fonts.fonts = with pkgs; [
nerdfonts
];
2023-07-11 21:17:48 -07:00
# Enable virtualisation
2023-07-10 17:52:34 -07:00
virtualisation.docker.enable = true;
virtualisation.docker.storageDriver = "btrfs";
2023-07-11 21:17:48 -07:00
# Enable zsh
2023-07-10 17:52:34 -07:00
programs.zsh.enable = true;
2023-07-11 21:17:48 -07:00
# Define user account.
2023-07-10 17:52:34 -07:00
users.users.${user} = {
isNormalUser = true;
2023-08-21 21:05:02 -07:00
extraGroups = [ "wheel" "docker" "libvirtd" ]; # Enable sudo for the user.
2023-07-10 17:52:34 -07:00
shell = pkgs.zsh;
};
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
vim
git
killall
pciutils
syncthing
pinentry-curses
trash-cli
unzip
2023-07-11 21:17:48 -07:00
nnn
2023-08-04 21:15:34 -07:00
advcpmv
2023-07-10 17:52:34 -07:00
];
# Enable user services
services = {
gvfs.enable = true; # USB automount
blueman.enable = true;
printing.enable = true;
printing.drivers = [ pkgs.hplip ];
avahi.enable = true;
avahi.nssmdns = true;
syncthing = {
enable = true;
2023-07-11 21:17:48 -07:00
user = "${user}";
dataDir = "/home/${user}/sync";
configDir = "/home/${user}/.config/syncthing";
2023-07-10 17:52:34 -07:00
};
};
2023-08-05 11:38:27 -07:00
# Enable the OpenSSH daemon.
services.openssh.enable = true;
services.pcscd.enable = true;
programs.gnupg.agent = {
enable = true;
pinentryFlavor = "curses";
enableSSHSupport = true;
};
2023-07-10 17:52:34 -07:00
# Enable modules
imports = [ ../../modules ];
modules = {
services = {
2023-07-25 15:23:07 -07:00
samba-client.enable = true;
2023-08-21 21:05:02 -07:00
virt-manager.enable = true;
2023-07-10 17:52:34 -07:00
};
devel = {
tooling.enable = true;
python.enable = true;
engineering.enable = true;
};
gaming = {
steam.enable = true;
};
desktop = {
sway.enable = true;
};
};
2023-09-02 11:06:41 -07:00
2023-07-11 21:17:48 -07:00
system.stateVersion = "23.05"; # Did you read the comment?
2023-07-10 17:52:34 -07:00
}