114 lines
2.6 KiB
Nix
114 lines
2.6 KiB
Nix
|
{ config, pkgs, ... }:
|
|||
|
|
|||
|
{
|
|||
|
imports = [ ./hardware-configuration.nix ];
|
|||
|
|
|||
|
nixpkgs.config.allowUnfree = true;
|
|||
|
networking.hostName = "gAluminum";
|
|||
|
|
|||
|
time.timeZone = "Europe/London";
|
|||
|
|
|||
|
i18n.defaultLocale = "en_US.UTF-8";
|
|||
|
console = {
|
|||
|
font = "Lat2-Terminus16";
|
|||
|
keyMap = "us";
|
|||
|
};
|
|||
|
|
|||
|
# Xserver
|
|||
|
services.xserver.enable = true;
|
|||
|
services.xserver.displayManager.gdm.enable = true;
|
|||
|
services.xserver.desktopManager.gnome.enable = true;
|
|||
|
|
|||
|
# Configure keymap in X11
|
|||
|
services.xserver.layout = "us";
|
|||
|
services.xserver.xkbOptions = "eurosign:e";
|
|||
|
|
|||
|
# Enable CUPS to print documents.
|
|||
|
services.printing.enable = true;
|
|||
|
|
|||
|
# Enable sound.
|
|||
|
sound.enable = true;
|
|||
|
hardware.pulseaudio.enable = true;
|
|||
|
|
|||
|
# Enable touchpad support (enabled default in most desktopManager).
|
|||
|
services.xserver.libinput.enable = true;
|
|||
|
|
|||
|
# Define a user account. Don't forget to set a password with ‘passwd’.
|
|||
|
users.users.giulio = {
|
|||
|
description = "Giulio De Pasquale";
|
|||
|
isNormalUser = true;
|
|||
|
shell = pkgs.zsh;
|
|||
|
extraGroups = [ "wheel" "docker" "networkmanager" ];
|
|||
|
};
|
|||
|
programs.zsh.enableCompletion = true;
|
|||
|
programs.zsh.enableBashCompletion = true;
|
|||
|
services.dbus.packages = with pkgs; [ gnome3.dconf ];
|
|||
|
services.udev.packages = with pkgs; [ gnome3.gnome-settings-daemon ];
|
|||
|
environment.systemPackages = with pkgs; [
|
|||
|
wget
|
|||
|
git
|
|||
|
pciutils
|
|||
|
curl
|
|||
|
virtualbox
|
|||
|
cmake
|
|||
|
ninja
|
|||
|
gdb
|
|||
|
htop
|
|||
|
glances
|
|||
|
tcpdump
|
|||
|
restic
|
|||
|
gnomeExtensions.appindicator
|
|||
|
binutils
|
|||
|
efibootmgr
|
|||
|
neovim
|
|||
|
home-manager
|
|||
|
];
|
|||
|
|
|||
|
fonts.fonts = with pkgs; [cascadia-code];
|
|||
|
|
|||
|
system.stateVersion = "21.05"; # Did you read the comment?
|
|||
|
|
|||
|
security.pam.services.gdm.enableGnomeKeyring = true;
|
|||
|
|
|||
|
boot.loader.efi.canTouchEfiVariables = true;
|
|||
|
boot.loader.efi.efiSysMountPoint = "/boot/efi";
|
|||
|
|
|||
|
boot.loader.systemd-boot.enable = true;
|
|||
|
boot.initrd.luks.devices = {
|
|||
|
root = {
|
|||
|
device = "/dev/disk/by-uuid/c2bac3a6-0999-4e1d-a676-bf4bcafee2d4";
|
|||
|
preLVM = true;
|
|||
|
allowDiscards = true;
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
networking.wg-quick.interfaces = {
|
|||
|
giupi = {
|
|||
|
address = ["10.3.0.2/32"];
|
|||
|
privateKeyFile = "/etc/wireguard/giupi.key";
|
|||
|
dns = ["10.3.0.1"];
|
|||
|
peers = [
|
|||
|
{
|
|||
|
publicKey = "I4glUMvIGjjhvQMKhwGc8copPl2t9Us/YYRjT0BKuiw=";
|
|||
|
allowedIPs = ["0.0.0.0/0"];
|
|||
|
endpoint = "giugl.io:1194";
|
|||
|
persistentKeepalive = 25;
|
|||
|
}
|
|||
|
];
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
fileSystems."/tmp" = {
|
|||
|
device = "tmpfs";
|
|||
|
fsType = "tmpfs";
|
|||
|
options = ["size=2G"];
|
|||
|
};
|
|||
|
|
|||
|
fileSystems."/home/giulio/Downloads" = {
|
|||
|
device = "tmpfs";
|
|||
|
fsType = "tmpfs";
|
|||
|
options = ["size=3G"];
|
|||
|
};
|
|||
|
}
|
|||
|
|