188 lines
4.4 KiB
Nix
188 lines
4.4 KiB
Nix
# 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 = [
|
||
<nixos-hardware/common/cpu/amd>
|
||
<nixos-hardware/common/pc/ssd>
|
||
/etc/nixos/hardware-configuration.nix
|
||
];
|
||
|
||
boot = {
|
||
binfmt.emulatedSystems = [ "armv7l-linux" "aarch64-linux" ];
|
||
extraModulePackages = with config.boot.kernelPackages; [ v4l2loopback ];
|
||
loader = {
|
||
systemd-boot.enable = true;
|
||
efi.canTouchEfiVariables = true;
|
||
};
|
||
initrd = {
|
||
checkJournalingFS = true;
|
||
luks.devices = {
|
||
root = {
|
||
device = "/dev/nvme0n1p2";
|
||
preLVM = true;
|
||
allowDiscards = true;
|
||
};
|
||
};
|
||
};
|
||
};
|
||
|
||
console = {
|
||
font = "Lat2-Terminus16";
|
||
keyMap = "us";
|
||
};
|
||
|
||
environment = {
|
||
pathsToLink = [ "/share/zsh" ];
|
||
systemPackages = with pkgs; [
|
||
kakoune
|
||
tmux
|
||
vim
|
||
];
|
||
};
|
||
|
||
hardware = {
|
||
bluetooth.enable = true;
|
||
enableRedistributableFirmware = true;
|
||
pulseaudio.enable = false;
|
||
};
|
||
|
||
i18n.defaultLocale = "it_IT.UTF-8";
|
||
|
||
programs = {
|
||
dconf.enable = true;
|
||
gnupg.agent = {
|
||
enable = true;
|
||
enableSSHSupport = true;
|
||
};
|
||
steam = {
|
||
enable = true;
|
||
};
|
||
zsh = {
|
||
enable = true;
|
||
syntaxHighlighting.enable = true;
|
||
};
|
||
};
|
||
|
||
networking = {
|
||
hostName = "thor"; # Define your hostname.
|
||
interfaces = {
|
||
eno1.useDHCP = true;
|
||
wlp5s0.useDHCP = true;
|
||
};
|
||
networkmanager.enable = true;
|
||
useDHCP = false;
|
||
hosts = {
|
||
"*.engine.sesar.int" = [ "172.20.28.210" ];
|
||
};
|
||
};
|
||
|
||
time.timeZone = "Europe/Rome";
|
||
|
||
services = {
|
||
avahi = {
|
||
enable = true;
|
||
openFirewall = true;
|
||
nssmdns = true;
|
||
publish = {
|
||
enable = true;
|
||
addresses = true;
|
||
domain = true;
|
||
userServices = true;
|
||
workstation = true;
|
||
};
|
||
extraServiceFiles = {
|
||
ssh = "${pkgs.avahi}/etc/avahi/services/ssh.service";
|
||
};
|
||
};
|
||
clamav = { daemon.enable = true; updater.enable = true; };
|
||
dbus.packages = with pkgs; [ gnome.dconf ];
|
||
gnome.gnome-keyring.enable = true;
|
||
gvfs = { enable = true; package = pkgs.gnome3.gvfs; };
|
||
openssh = { enable = true; openFirewall = true; permitRootLogin = "no"; passwordAuthentication = false; };
|
||
pipewire = {
|
||
enable = true;
|
||
pulse.enable = true;
|
||
jack.enable = true;
|
||
alsa = {
|
||
enable = true;
|
||
support32Bit = true;
|
||
};
|
||
# media-session.enable = true;
|
||
};
|
||
power-profiles-daemon.enable = true;
|
||
smartd = { enable = true; notifications.x11.enable = true; };
|
||
snapper = {
|
||
configs =
|
||
let
|
||
common = {
|
||
extraConfig = ''
|
||
ALLOW_USERS="bertof"
|
||
TIMELINE_CREATE=yes
|
||
TIMELINE_CLEANUP=yes
|
||
'';
|
||
};
|
||
in
|
||
{
|
||
bertof_home = common // { subvolume = "/home/bertof"; };
|
||
};
|
||
};
|
||
thermald.enable = true;
|
||
xserver = {
|
||
enable = true;
|
||
desktopManager = {
|
||
# gnome.enable = true;
|
||
cinnamon.enable = true;
|
||
};
|
||
displayManager.gdm = { enable = true; wayland = false; };
|
||
layout = "us";
|
||
videoDrivers = [ "nvidia" ];
|
||
xkbOptions = "eurosign:e";
|
||
};
|
||
zerotierone = { enable = true; joinNetworks = [ "8056c2e21cf9c753" ]; };
|
||
};
|
||
|
||
security = {
|
||
rtkit.enable = true;
|
||
sudo.extraConfig = ''
|
||
Defaults pwfeedback
|
||
'';
|
||
};
|
||
|
||
sound.enable = false;
|
||
|
||
users.users.bertof = {
|
||
isNormalUser = true;
|
||
extraGroups = [ "audio" "input" "docker" "libvirtd" "network" "usb" "video" "wheel" ];
|
||
openssh.authorizedKeys.keys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIN+zsSWZFFzQKnATCAvtG+iuSm4qkZHjCtHzGa9B/71W" ];
|
||
shell = pkgs.zsh;
|
||
useDefaultShell = false;
|
||
};
|
||
|
||
virtualisation = {
|
||
docker.enable = true;
|
||
kvmgt.enable = true;
|
||
libvirtd.enable = true;
|
||
podman.enable = true;
|
||
virtualbox.host.enable = true;
|
||
};
|
||
|
||
nixpkgs.config = {
|
||
allowUnfree = true;
|
||
packageOverrides = pkgs: {
|
||
steam = pkgs.steam.override {
|
||
extraPkgs = pkgs: with pkgs; [ icu ];
|
||
};
|
||
};
|
||
};
|
||
nix = {
|
||
package = pkgs.nixFlakes;
|
||
extraOptions = lib.optionalString (config.nix.package == pkgs.nixFlakes)
|
||
"experimental-features = nix-command flakes";
|
||
gc.automatic = true;
|
||
};
|
||
|
||
system.stateVersion = "21.05"; # Did you read the comment?
|
||
}
|