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

151 lines
3.5 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-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;
extraGroups = [ "wheel" "docker" ]; # Enable sudo for the user.
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
# xserver = {
# enable = true;
# displayManager = {
# #defaultSession = "none+bspwm";
# lightdm.greeters.mini = {
# enable = true;
# #user = "tstarr";
# #extraConfig = ''
# # [greeter]
# # show-password-label = false
# # invalid-password-text = Access Denied
# # show-input-cursor = true
# # password-alignment = left
# # [greeter-theme]
# # font-size = 1em
# # background-image = ""
# #'';
# };
# };
# };
#};
xserver.enable = true;
xserver.displayManager.sddm.enable = true;
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-05 11:38:27 -07:00
vfio.enable = false;
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-07-11 21:17:48 -07:00
system.stateVersion = "23.05"; # Did you read the comment?
2023-07-10 17:52:34 -07:00
}