deb8796cc5
Tailscale is warning about this in `nix-build` via `trace`. Change-Id: Ia44100f5a3cd12fbf9fd10dbf40bef10805aff12 Reviewed-on: https://cl.tvl.fyi/c/depot/+/5749 Tested-by: BuildkiteCI Reviewed-by: wpcarro <wpcarro@gmail.com> Autosubmit: wpcarro <wpcarro@gmail.com>
158 lines
3.7 KiB
Nix
158 lines
3.7 KiB
Nix
{ depot, pkgs, lib, ... }:
|
|
{ ... }:
|
|
|
|
let
|
|
inherit (depot.users) wpcarro;
|
|
|
|
wpcarrosEmacs = wpcarro.emacs.nixos {
|
|
load = [ ./tarasco.el ];
|
|
};
|
|
|
|
quasselClient = pkgs.quassel.override {
|
|
client = true;
|
|
enableDaemon = false;
|
|
monolithic = false;
|
|
};
|
|
in
|
|
{
|
|
imports = [ ./hardware.nix ];
|
|
|
|
# Use the TVL binary cache
|
|
tvl.cache.enable = true;
|
|
|
|
boot = {
|
|
loader.systemd-boot.enable = true;
|
|
loader.efi.canTouchEfiVariables = true;
|
|
|
|
# Support IP forwarding to use this device as a Tailscale exit node.
|
|
kernel.sysctl."net.ipv4.ip_forward" = true;
|
|
kernel.sysctl."net.ipv6.conf.all.forwarding" = true;
|
|
kernelModules = [
|
|
"kvm-intel"
|
|
];
|
|
|
|
# Can verify these settings with:
|
|
# $ lsmod
|
|
# ...or:
|
|
# $ cat /etc/modprobe.d/nixos.conf
|
|
blacklistedKernelModules = [
|
|
# Disabling this buggy network driver (and preferring ethernet) to prevent
|
|
# my machine from becoming unresponsive.
|
|
# TODO(wpcarro): Consider replacing this module with this fork (if NixOS
|
|
# isn't already): https://github.com/tomaspinho/rtl8821ce
|
|
"rtw88_8821ce"
|
|
];
|
|
|
|
initrd.availableKernelModules = [ "xhci_pci" "ehci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" ];
|
|
initrd.kernelModules = [ ];
|
|
extraModulePackages = [ ];
|
|
};
|
|
|
|
|
|
time.timeZone = "America/Los_Angeles";
|
|
|
|
networking = {
|
|
useDHCP = false;
|
|
hostName = "tarasco";
|
|
networkmanager.enable = true;
|
|
interfaces.enp1s0.useDHCP = true;
|
|
interfaces.enp3s0.useDHCP = true;
|
|
firewall.checkReversePath = "loose";
|
|
# Disabling wifi because the Realtek network card drivers crash. For more
|
|
# context, see the boot.blacklistedKernelModules configuration.
|
|
# interfaces.wlp2s0.useDHCP = true;
|
|
};
|
|
|
|
services = wpcarro.common.services // {
|
|
# Check the amount of available memory and free swap a few times per second
|
|
# and kill the largest process if both are below 10%.
|
|
earlyoom.enable = true;
|
|
|
|
tailscale.enable = true;
|
|
|
|
openssh.enable = true;
|
|
|
|
xserver = {
|
|
enable = true;
|
|
layout = "us";
|
|
xkbOptions = "caps:escape";
|
|
displayManager = {
|
|
# Give EXWM permission to control the session (from tazjin's setup).
|
|
sessionCommands = "${pkgs.xorg.xhost}/bin/xhost +SI:localhost:$USER";
|
|
lightdm.enable = true;
|
|
};
|
|
windowManager.session = lib.singleton {
|
|
name = "exwm";
|
|
start = "${wpcarrosEmacs}/bin/wpcarros-emacs";
|
|
};
|
|
};
|
|
};
|
|
|
|
# Enable sound.
|
|
sound.enable = true;
|
|
hardware.pulseaudio.enable = true;
|
|
|
|
users.mutableUsers = true;
|
|
users.users.root.openssh.authorizedKeys.keys = [
|
|
wpcarro.keys.nathan
|
|
wpcarro.keys.ava
|
|
];
|
|
users.users.wpcarro = {
|
|
isNormalUser = true;
|
|
extraGroups = [
|
|
"networkmanager"
|
|
"wheel"
|
|
"docker"
|
|
];
|
|
shell = pkgs.fish;
|
|
openssh.authorizedKeys.keys = [
|
|
wpcarro.keys.nathan
|
|
wpcarro.keys.ava
|
|
];
|
|
};
|
|
users.extraGroups.vboxusers.members = [ "wpcarro" ];
|
|
|
|
security.sudo.wheelNeedsPassword = false;
|
|
|
|
fonts = {
|
|
fonts = with pkgs; [
|
|
jetbrains-mono
|
|
];
|
|
|
|
fontconfig = {
|
|
defaultFonts = {
|
|
monospace = [ "JetBrains Mono" ];
|
|
};
|
|
};
|
|
};
|
|
|
|
programs = wpcarro.common.programs // {
|
|
mosh.enable = true;
|
|
};
|
|
|
|
virtualisation.docker.enable = true;
|
|
virtualisation.virtualbox.host.enable = true;
|
|
|
|
environment.variables = {
|
|
EDITOR = "emacsclient";
|
|
ALTERNATE_EDITOR = "emacs -q -nw";
|
|
VISUAL = "emacsclient";
|
|
};
|
|
|
|
environment.systemPackages =
|
|
wpcarro.common.shell-utils ++
|
|
(with pkgs; [
|
|
alacritty
|
|
firefox
|
|
google-chrome
|
|
httpie
|
|
pavucontrol
|
|
quasselClient
|
|
remmina
|
|
tdesktop
|
|
wpcarrosEmacs
|
|
xsecurelock
|
|
]);
|
|
|
|
system.stateVersion = "21.11";
|
|
}
|