# Edit this configuration file to define what should be installed on # your system. Help is available in the configuration.nix(5) man page, on # https://search.nixos.org/options and in the NixOS manual (`nixos-help`). { config, lib, pkgs, ... }: { imports = [ # Include the results of the hardware scan. ./hardware-configuration.nix ./disko-config.nix ./home.nix ./secrets.nix ]; boot.kernelPackages = pkgs.linuxPackages_6_12; # Set Wi-Fi regulatory domain. Currently always set to '00' (world), and could # lead to bad Wi-Fi performance boot.kernelParams = ["cfg80211.ieee80211_regdom=FR"]; boot.extraModulePackages = with config.boot.kernelPackages; [ v4l2loopback ]; boot.extraModprobeConfig = '' options v4l2loopback devices=1 video_nr=1 card_label="OBS Cam" exclusive_caps=1 ''; # Use the systemd-boot EFI boot loader. boot.loader.systemd-boot = { enable = true; editor = false; consoleMode = "auto"; }; boot.loader.efi.canTouchEfiVariables = true; boot.tmp.useTmpfs = true; services.btrfs = { autoScrub = { enable = true; fileSystems = ["/"]; }; }; networking.hostName = "talos"; # Define your hostname. networking.domain = "alarsyo.net"; # Pick only one of the below networking options. # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. networking.networkmanager = { enable = true; wifi.powersave = true; }; # Set your time zone. time.timeZone = "Europe/Paris"; # Configure network proxy if necessary # networking.proxy.default = "http://user:password@proxy:port/"; # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; programs = { light.enable = true; }; services = { fwupd.enable = true; openssh.enable = true; }; virtualisation = { docker.enable = true; libvirtd.enable = false; virtualbox.host = { enable = false; }; }; my.services = { tailscale = { enable = true; useRoutingFeatures = "client"; }; pipewire.enable = true; restic-backup = { enable = true; repo = "b2:talos-backup"; passwordFile = config.age.secrets."restic-backup/talos-password".path; environmentFile = config.age.secrets."restic-backup/talos-credentials".path; timerConfig = { OnCalendar = "*-*-* 13:00:00"; # laptop only gets used during the day }; paths = [ "/home/alarsyo" ]; exclude = [ "/home/alarsyo/Downloads" # Rust builds using half my storage capacity "/home/alarsyo/**/target" "/home/alarsyo/work/rust/build" # don't backup nixpkgs "/home/alarsyo/work/nixpkgs" "/home/alarsyo/go" # C build crap "*.a" "*.o" "*.so" ".direnv" # test vms "*.qcow2" "*.vbox" "*.vdi" # secrets stay offline "/home/alarsyo/**/secrets" # ignore all dotfiles as .config and .cache can become quite big "/home/alarsyo/.*" ]; }; }; my.gui.enable = true; hardware.bluetooth = { enable = true; powerOnBoot = false; settings.General.Experimental = true; }; # Configure console keymap console.keyMap = "us"; # Select internationalisation properties. i18n.defaultLocale = "en_US.UTF-8"; i18n.extraLocaleSettings = { LC_ADDRESS = "fr_FR.UTF-8"; LC_IDENTIFICATION = "fr_FR.UTF-8"; LC_MEASUREMENT = "fr_FR.UTF-8"; LC_MONETARY = "fr_FR.UTF-8"; LC_NAME = "fr_FR.UTF-8"; LC_PAPER = "fr_FR.UTF-8"; LC_TELEPHONE = "fr_FR.UTF-8"; }; # Enable the KDE Plasma Desktop Environment. services.desktopManager.plasma6.enable = true; services.power-profiles-daemon.enable = true; environment.systemPackages = [ pkgs.unstable.zed-editor pkgs.foot ]; #programs.hyprland.enable = true; programs.sway = { enable = true; wrapperFeatures.gtk = true; }; # Copy the NixOS configuration file and link it from the resulting system # (/run/current-system/configuration.nix). This is useful in case you # accidentally delete configuration.nix. # system.copySystemConfiguration = true; }