2018-06-09 13:23:26 +02: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 =
|
2018-09-20 12:22:05 +02:00
|
|
|
|
[
|
|
|
|
|
../common.nix
|
2018-06-09 13:23:26 +02:00
|
|
|
|
./hardware-configuration.nix
|
|
|
|
|
];
|
2018-06-09 13:29:41 +02:00
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
nixpkgs.overlays = [
|
2018-08-31 22:57:18 +02:00
|
|
|
|
(import ../../overlays/ledger-udev-rules.nix)
|
2018-06-09 13:23:26 +02:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
# Use the systemd-boot EFI boot loader.
|
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
|
|
|
boot.loader.efi.canTouchEfiVariables = true;
|
2018-09-16 16:59:48 +02:00
|
|
|
|
boot.tmpOnTmpfs = true;
|
2018-08-31 22:59:05 +02:00
|
|
|
|
boot.plymouth.enable = true;
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
2018-11-11 11:13:25 +01:00
|
|
|
|
services.tlp.enable = true;
|
|
|
|
|
services.tlp.extraConfig = ''
|
|
|
|
|
START_CHARGE_THRESH_BAT0=85
|
|
|
|
|
STOP_CHARGE_THRESH_BAT0=90
|
|
|
|
|
CPU_SCALING_GOVERNOR_ON_BAT=powersave
|
|
|
|
|
ENERGY_PERF_POLICY_ON_BAT=powersave
|
|
|
|
|
'';
|
|
|
|
|
|
2018-10-06 01:17:07 +02:00
|
|
|
|
# NVIDIA
|
|
|
|
|
services.xserver.videoDrivers = [ "nvidia" ];
|
|
|
|
|
hardware.nvidia.optimus_prime.enable = true;
|
|
|
|
|
hardware.nvidia.modesetting.enable = true;
|
|
|
|
|
hardware.nvidia.optimus_prime.nvidiaBusId = "PCI:1:0:0";
|
|
|
|
|
hardware.nvidia.optimus_prime.intelBusId = "PCI:0:2:0";
|
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
# For Steam
|
|
|
|
|
hardware.opengl.driSupport32Bit = true;
|
|
|
|
|
hardware.pulseaudio.support32Bit = true;
|
2018-10-06 01:15:48 +02:00
|
|
|
|
hardware.steam-hardware.enable = true;
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
2018-08-31 22:39:28 +02:00
|
|
|
|
hardware.u2f.enable = true;
|
|
|
|
|
|
2018-08-31 22:57:18 +02:00
|
|
|
|
services.udev.packages = with pkgs; [
|
|
|
|
|
ledger-udev-rules
|
|
|
|
|
];
|
2018-08-31 22:47:06 +02:00
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
networking.hostName = "rog-paul"; # Define your hostname.
|
|
|
|
|
networking.networkmanager.enable = true; # Enables wireless support via wpa_supplicant.
|
|
|
|
|
|
|
|
|
|
# Select internationalisation properties.
|
|
|
|
|
i18n = {
|
|
|
|
|
# consoleFont = "Lat2-Terminus16";
|
|
|
|
|
consoleKeyMap = "fr";
|
|
|
|
|
defaultLocale = "fr_FR.UTF-8";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
# List packages installed in system profile. To search by name, run:
|
|
|
|
|
# $ nix-env -qaP | grep wget
|
|
|
|
|
nixpkgs.config.allowUnfree = true;
|
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
|
filezilla
|
|
|
|
|
wineStaging
|
|
|
|
|
winetricks
|
2018-08-31 22:39:28 +02:00
|
|
|
|
qbittorrent
|
|
|
|
|
transmission-remote-gtk
|
|
|
|
|
appimage-run
|
2018-09-16 17:00:12 +02:00
|
|
|
|
bat
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
|
|
|
|
gopass
|
|
|
|
|
xclip
|
|
|
|
|
|
2018-09-16 17:00:12 +02:00
|
|
|
|
electrum
|
|
|
|
|
electron-cash
|
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
firefox
|
2018-10-27 22:49:59 +02:00
|
|
|
|
torbrowser
|
2018-06-09 13:23:26 +02:00
|
|
|
|
chromium
|
2018-06-09 13:29:41 +02:00
|
|
|
|
qutebrowser
|
|
|
|
|
|
|
|
|
|
tdesktop
|
|
|
|
|
mumble
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
|
|
|
|
kleopatra
|
|
|
|
|
gnupg
|
|
|
|
|
|
|
|
|
|
kdeplasma-addons
|
|
|
|
|
ark
|
|
|
|
|
kate
|
|
|
|
|
kmail
|
|
|
|
|
kdeconnect
|
|
|
|
|
okular
|
|
|
|
|
yakuake
|
|
|
|
|
konversation
|
|
|
|
|
gwenview
|
2018-06-09 13:29:41 +02:00
|
|
|
|
kcalc
|
|
|
|
|
spectacle
|
2018-09-16 17:00:12 +02:00
|
|
|
|
kile
|
2018-09-29 12:56:37 +02:00
|
|
|
|
(texlive.combine {
|
|
|
|
|
inherit (texlive) scheme-small titling collection-langfrench cm-super;
|
|
|
|
|
})
|
2018-09-16 17:00:12 +02:00
|
|
|
|
imagemagick
|
2018-08-31 22:39:28 +02:00
|
|
|
|
|
|
|
|
|
gnome-breeze
|
|
|
|
|
arc-theme
|
|
|
|
|
materia-theme
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
|
|
|
|
libreoffice
|
|
|
|
|
gimp
|
|
|
|
|
vlc
|
2018-06-09 13:29:41 +02:00
|
|
|
|
kodiPlain
|
2018-10-27 23:06:57 +02:00
|
|
|
|
mpv
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
2018-10-06 01:17:07 +02:00
|
|
|
|
steam
|
2018-06-09 13:23:26 +02:00
|
|
|
|
sc-controller
|
2018-08-31 22:39:28 +02:00
|
|
|
|
steam-run
|
|
|
|
|
minecraft
|
|
|
|
|
|
|
|
|
|
glxinfo
|
|
|
|
|
i7z
|
|
|
|
|
obs-studio
|
2018-06-09 13:23:26 +02:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
programs.wireshark.enable = true;
|
|
|
|
|
programs.wireshark.package = pkgs.wireshark;
|
|
|
|
|
|
|
|
|
|
# Some programs need SUID wrappers, can be configured further or are
|
|
|
|
|
# started in user sessions.
|
|
|
|
|
# programs.bash.enableCompletion = true;
|
|
|
|
|
# programs.mtr.enable = true;
|
|
|
|
|
programs.gnupg.agent = { enable = true; enableSSHSupport = true; };
|
|
|
|
|
programs.browserpass.enable = true;
|
|
|
|
|
services.pcscd.enable = true;
|
|
|
|
|
services.pcscd.plugins = [
|
|
|
|
|
(pkgs.ccid.overrideAttrs (oldAttrs: rec {
|
|
|
|
|
preBuild = ''
|
|
|
|
|
echo "0x2C97:0x0001:Ledger Token" >> ./readers/supported_readers.txt
|
|
|
|
|
'';
|
|
|
|
|
})
|
|
|
|
|
)
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
# List services that you want to enable:
|
|
|
|
|
|
|
|
|
|
# Enable the OpenSSH daemon.
|
|
|
|
|
# services.openssh.enable = true;
|
|
|
|
|
|
|
|
|
|
# Open ports in the firewall.
|
2018-06-09 13:29:41 +02:00
|
|
|
|
# networking.firewall.allowedTCPPorts = [ 8000 ];
|
|
|
|
|
# networking.firewall.allowedUDPPorts = [ ];
|
2018-06-09 13:23:26 +02:00
|
|
|
|
# Or disable the firewall altogether.
|
2018-06-09 13:29:41 +02:00
|
|
|
|
networking.firewall.enable = false;
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
2018-09-16 17:00:34 +02:00
|
|
|
|
networking.wireguard.interfaces = {
|
|
|
|
|
wg0 = {
|
|
|
|
|
ips = [ "192.168.20.2/24" ];
|
|
|
|
|
allowedIPsAsRoutes = false;
|
|
|
|
|
peers = [
|
|
|
|
|
{
|
|
|
|
|
allowedIPs = [ "0.0.0.0/0" ];
|
|
|
|
|
endpoint = "nyanlout.re:51820";
|
|
|
|
|
publicKey = "NVLJ30kNP+fK+K3oM1LAcQpvZvz1dvBD8mWNjDf5Z2k=";
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
privateKeyFile = "/var/lib/wireguard/wg0.privatekey";
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
# Enable CUPS to print documents.
|
|
|
|
|
services.printing.enable = true;
|
2018-09-16 17:00:49 +02:00
|
|
|
|
services.printing.drivers = [ pkgs.hplip ];
|
2018-06-09 13:23:26 +02:00
|
|
|
|
|
|
|
|
|
# Enable sound.
|
|
|
|
|
sound.enable = true;
|
|
|
|
|
hardware.pulseaudio.enable = true;
|
|
|
|
|
|
|
|
|
|
# Enable the X11 windowing system.
|
|
|
|
|
services.xserver.enable = true;
|
|
|
|
|
services.xserver.layout = "fr";
|
|
|
|
|
# services.xserver.xkbOptions = "eurosign:e";
|
|
|
|
|
|
|
|
|
|
# Enable touchpad support.
|
|
|
|
|
services.xserver.libinput.enable = true;
|
|
|
|
|
services.xserver.libinput.naturalScrolling = true;
|
|
|
|
|
|
|
|
|
|
# Enable the KDE Desktop Environment.
|
|
|
|
|
services.xserver.displayManager.sddm.enable = true;
|
|
|
|
|
services.xserver.desktopManager.plasma5.enable = true;
|
|
|
|
|
|
|
|
|
|
# Define a user account. Don't forget to set a password with ‘passwd’.
|
|
|
|
|
users.extraUsers.paul = {
|
|
|
|
|
isNormalUser = true;
|
|
|
|
|
uid = 1000;
|
2018-08-31 22:57:18 +02:00
|
|
|
|
extraGroups = [ "wheel" "networkmanager" "wireshark" ];
|
2018-06-09 13:23:26 +02:00
|
|
|
|
};
|
2018-06-09 13:29:41 +02:00
|
|
|
|
|
|
|
|
|
services.syncthing.enable = true;
|
|
|
|
|
services.syncthing.user = "paul";
|
|
|
|
|
services.syncthing.group = "users";
|
|
|
|
|
|
2019-01-12 13:47:41 +01:00
|
|
|
|
# Set limits for esync (SteamPlay Proton)
|
|
|
|
|
systemd.extraConfig = "DefaultLimitNOFILE=1048576";
|
|
|
|
|
|
|
|
|
|
security.pam.loginLimits = [{
|
|
|
|
|
domain = "*";
|
|
|
|
|
type = "hard";
|
|
|
|
|
item = "nofile";
|
|
|
|
|
value = "1048576";
|
|
|
|
|
}];
|
|
|
|
|
|
2018-06-09 13:23:26 +02:00
|
|
|
|
# This value determines the NixOS release with which your system is to be
|
|
|
|
|
# compatible, in order to avoid breaking some software such as database
|
|
|
|
|
# servers. You should change this only after NixOS release notes say you
|
|
|
|
|
# should.
|
|
|
|
|
system.stateVersion = "18.03"; # Did you read the comment?
|
|
|
|
|
|
|
|
|
|
}
|