dotfiles/nixos/configuration.nix

194 lines
5.3 KiB
Nix
Raw Normal View History

2021-08-09 12:19:21 +00:00
# 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).
{ config, pkgs, ... }:
{
imports =
[ # Include the results of the hardware scan.
/etc/nixos/hardware-configuration.nix
];
2022-01-13 13:51:13 +00:00
nixpkgs.config.allowUnfree = true;
2021-08-09 12:19:21 +00:00
# Use the systemd-boot EFI boot loader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
# networking.hostName = "nixos"; # Define your hostname.
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
# Set your time zone.
time.timeZone = "America/New_York";
# The global useDHCP flag is deprecated, therefore explicitly set to false here.
# Per-interface useDHCP will be mandatory in the future, so this generated config
# replicates the default behaviour.
networking.useDHCP = false;
networking.interfaces.enp0s31f6.useDHCP = true;
networking.interfaces.wlp3s0.useDHCP = true;
# Configure network proxy if necessary
# networking.proxy.default = "http://user:password@proxy:port/";
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
# Select internationalisation properties.
# i18n.defaultLocale = "en_US.UTF-8";
# console = {
# font = "Lat2-Terminus16";
# keyMap = "us";
# };
# Enable the X11 windowing system.
# services.xserver.enable = true;
services.xserver = {
enable = true;
desktopManager = {
xterm.enable = false;
xfce.enable = true;
};
displayManager.defaultSession = "xfce";
# Disable mouse acceleration
libinput.mouse.accelProfile = "flat";
2022-01-15 15:14:12 +00:00
libinput.mouse.accelSpeed = "3.0";
2021-08-09 12:19:21 +00:00
};
2022-01-15 15:34:56 +00:00
# Mouse config
services.ratbagd.enable = true;
2021-08-09 12:19:21 +00:00
# Configure keymap in X11
services.xserver.layout = "us";
2022-01-13 23:45:21 +00:00
services.xserver.xkbOptions = "eurosign:e,caps:swapescape";
2021-08-09 12:19:21 +00:00
# Enable CUPS to print documents.
# services.printing.enable = true;
# Enable sound.
sound.enable = true;
2022-01-13 14:45:27 +00:00
hardware.pulseaudio.enable = false;
services.pipewire = {
enable = true;
# Sound card drivers
2022-01-15 15:14:12 +00:00
alsa = {
enable = true;
support32Bit = true;
};
2022-01-13 14:45:27 +00:00
# PulseAudio emulation
pulse.enable = true;
};
2021-08-09 12:19:21 +00:00
2022-01-15 15:14:12 +00:00
/* systemd.services.pavucontrol = { */
/* wantedBy = [ "multi-user.target" ]; */
/* script = "${pkgs.pavucontrol}/bin/pavucontrol"; */
/* }; */
2022-01-13 13:51:13 +00:00
services.xserver.displayManager.setupCommands = ''
2022-01-15 15:34:56 +00:00
${pkgs.xorg.xrandr}/bin/xrandr --output DisplayPort-0 \
--mode 1920x1200 \
--pos 1920x0 \
--rotate left \
--output HDMI-0 \
--primary \
--mode 1920x1080 \
--pos 0x559 \
--rotate normal \
--output DVI-0 --off \
--output DVI-1 --off \
'';
2022-01-13 13:51:13 +00:00
2021-11-06 19:16:53 +00:00
# Install fonts
fonts.fonts = with pkgs; [
fira-code
fira-code-symbols
];
2021-08-09 12:19:21 +00:00
# Enable touchpad support (enabled default in most desktopManager).
# services.xserver.libinput.enable = true;
# Replace sudo with doas
security = {
# Remove sudo
sudo.enable = false;
# Add doas
doas = {
enable = true;
# No password required
wheelNeedsPassword = false;
# Pass environment variables from user to root
# Also requires removing password here
extraRules = [{
groups = [ "wheel" ];
noPass = true;
keepEnv = true;
}];
};
};
# Define a user account. Don't forget to set a password with passwd.
users.users.noah = {
# Not sure what this means tbh
isNormalUser = true;
# Automatically create a password to start
initialPassword = "changeme";
# Enable sudo privileges
extraGroups = [ "wheel" ];
# Use the fish shell
shell = pkgs.fish;
};
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
fish
vim
wget
curl
home-manager
just
2022-01-15 15:14:12 +00:00
libratbag
2022-01-15 15:34:56 +00:00
pavucontrol
piper
2021-08-09 12:19:21 +00:00
];
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.mtr.enable = true;
# programs.gnupg.agent = {
# enable = true;
# enableSSHSupport = true;
# };
# List services that you want to enable:
# Enable the OpenSSH daemon.
# services.openssh.enable = true;
# Open ports in the firewall.
# networking.firewall.allowedTCPPorts = [ ... ];
# networking.firewall.allowedUDPPorts = [ ... ];
# Or disable the firewall altogether.
# networking.firewall.enable = false;
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions
# on your system were taken. Its perfectly fine and recommended to leave
# this value at the release version of the first install of this system.
# Before changing this value read the documentation for this option
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
2022-01-15 15:14:12 +00:00
system.stateVersion = "21.11"; # Did you read the comment?
2021-08-09 12:19:21 +00:00
}