nixos-config/systems/ASUS-G46VW/configuration.nix

220 lines
5.2 KiB
Nix
Raw Normal View History

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;
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?
}