nixos/configuration.nix
Alex A. Naanou f898453e0e added intel video drivers...
Signed-off-by: Alex A. Naanou <alex.nanou@gmail.com>
2024-03-30 18:48:48 +03:00

442 lines
13 KiB
Nix
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#
# TODO:
# - setdisplay gamma (gnome-gamma-tool)
# - second language keyboard layout
# - language switching in Gnome (keyboard)
# - hibernation -- DONE
# - suspend -- DONE
# - split into logical components (OS, hardware, ...)
# - tablet-mode
# - sensors
# - latex -- DONE
#
#
# 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, ... }:
## LaTeX...
#let tex = pkg.texlive.combine {
# inherit (pkgs.texlive) scheme-basic
# kvoptions calc xargs ifthen iftex pgffor xint xinttools listofitems xkeyval
# etoolbox changepage pdfcomment eso-pic environ numprint trimclip xcolor
# pagecolor colorspace graphicx adjustbox textpos fancyvrb flowfram rotating
# fancyhdr pdfpages geometry;
# #(setq org-latex-compiler "lualatex")
# #(setq org-preview-latex-default-process 'dvisvgm)
#};
#in
{
nix.settings.experimental-features = [
"nix-command"
"flakes"
];
imports = [
# Include the results of the hardware scan.
./hardware-configuration.nix
];
# Allow unfree packages
nixpkgs.config.allowUnfree = true;
# intel video drivers...
# XXX move to hardware...
nixpkgs.config.packageOverrides = pkgs: {
intel-vaapi-driver = pkgs.intel-vaapi-driver.override { enableHybridCodec = true; };
};
hardware.opengl = {
enable = true;
extraPackages = with pkgs; [
intel-media-driver # LIBVA_DRIVER_NAME=iHD
intel-vaapi-driver # LIBVA_DRIVER_NAME=i965 (older but works better for Firefox/Chromium)
vaapiVdpau
libvdpau-va-gl
];
};
environment.sessionVariables = { LIBVA_DRIVER_NAME = "iHD"; }; # Force intel-media-driver
# Bootloader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
# XXX this is the same swap partition as fedora...
boot.resumeDevice = "/dev/disk/by-uuid/6ac0c126-f701-43a5-8576-09cc76be1409";
#boot.kernelParams = [ "systemd.unified_cgroup_hierarchy=0" "resume_offset=13465600" ];
swapDevices = [
# {
# device = "/var/lib/swapfile";
# size = 8*1024;
# }
{ device = "/dev/disk/by-uuid/6ac0c126-f701-43a5-8576-09cc76be1409"; }
];
boot.kernelPackages = pkgs.linuxPackages_latest;
# fix an issue with the touchpad/touchpoint not working after suspend...
# XXX move to hardware-specific-file...
boot.blacklistedKernelModules = [
"i2c_i801"
];
#powerManagement.resumeCommands = ''
# ${pkgs.kmod}/bin/modprobe -r i2c_i801
# ${pkgs.kmod}/bin/modprobe i2c_i801
#'';
# ThinkPad keyboard auto highlight...
#services.tp-auto-kbbl.enable = true;
networking.hostName = "yoga-nix";
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
# Configure network proxy if necessary
# networking.proxy.default = "http://user:password@proxy:port/";
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
# Enable networking
networking.networkmanager.enable = true;
# Set your time zone.
time.timeZone = "Europe/Moscow";
# Select internationalisation properties.
i18n.defaultLocale = "en_US.UTF-8";
#i18n.supportedLocales = [
# "en_US.UTF-8"
# "ru_RU.UTF-8"
#];
i18n.extraLocaleSettings = {
LC_ADDRESS = "ru_RU.UTF-8";
LC_IDENTIFICATION = "ru_RU.UTF-8";
LC_MEASUREMENT = "en_GB.UTF-8";
LC_MONETARY = "ru_RU.UTF-8";
LC_NAME = "ru_RU.UTF-8";
LC_NUMERIC = "en_GB.UTF-8";
LC_PAPER = "ru_RU.UTF-8";
LC_TELEPHONE = "ru_RU.UTF-8";
LC_TIME = "en_GB.UTF-8";
};
# Enable the X11 windowing system.
services.xserver.enable = true;
# Configure keymap in X11
services.xserver = {
layout = "us,ru";
xkbOptions = "grp:alt_shift_toggle";
};
services.xserver.excludePackages = [
pkgs.xterm
];
# Enable the GNOME Desktop Environment.
services.xserver.displayManager.gdm.enable = true;
services.xserver.desktopManager.gnome.enable = true;
# set keyboard layouts and switching...
services.xserver.desktopManager.gnome.extraGSettingsOverrides = ''
[org.gnome.desktop.input-sources]
sources=[('xkb', 'us'),('xkb', 'ru')]
per-window=true
[org.gnome.desktop.wm.keybindings]
switch-input-source=['<Alt>Shift_L']
switch-input-source-backward=['<Shift>Alt_L']
'';
environment.gnome.excludePackages = [
pkgs.gnome-tour
];
# Enable CUPS to print documents.
services.printing.enable = true;
# Enable sound with pipewire.
sound.enable = true;
hardware.pulseaudio.enable = false;
security.rtkit.enable = true;
services.pipewire = {
enable = true;
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
# If you want to use JACK applications, uncomment this
#jack.enable = true;
# use the example session manager (no others are packaged yet so this is enabled by default,
# no need to redefine it in your config for now)
#media-session.enable = true;
};
services.colord.enable = true;
services.flatpak.enable = true;
# Laptop configuration...
services.logind.lidSwitch = "lock";
services.fwupd.enable = true;
services.openssh.enable = true;
services.keyd = {
enable = true;
keyboards = {
default = {
ids = ["*"];
settings = {
main = {
# Modern ThinkPad's printscrn to menu key...
sysrq = "overload(prtsc, compose)";
rightshift = "overload(rightshift, rightshift)";
rightalt = "overload(rightalt, rightalt)";
};
prtsc = {
# Gnome: screenshot...
rightshift = "sysrq";
# Gnome: minimize/maximize...
up = "M-up";
down = "M-down";
# Gnome: next/prev workspace...
left = "M-A-left";
right = "M-A-right";
};
"rightshift:S" = {
# Gnome: screenshot...
sysrq = "sysrq";
};
"rightalt:A" = {
# Gnome: move window...
left = "macro(A-f7 20ms left left enter)";
right = "macro(A-f7 20ms right right enter)";
up = "macro(A-f7 20ms up up enter)";
down = "macro(A-f7 20ms down down enter)";
};
};
};
};
};
services.syncthing = {
enable = true;
user = "f_lynx";
configDir = "/home/f_lynx/.config/syncthing/";
dataDir = "/home/f_lynx/Sync/";
};
# Tor
# see: https://nixos.wiki/wiki/Tor
services.tor = {
enable = true;
client.enable = true;
settings = {
UseBridges = true;
# obfs4...
ClientTransportPlugin = "obfs4 exec ${pkgs.obfs4}/bin/lyrebird";
Bridge = [
"obfs4 85.131.118.200:9674 A972B2E5384EAAA50D31E1A874CDD34D3DA6DE58 cert=MQJsFBUmP7SpLQwJwLzd+eELqTQ3ryHHXwDjy4yNlRq20i1B/fMiX+Po5pkixdCG100aWw iat-mode=0"
];
## snowflake... (XXX fails)
#ClientTransportPlugin = "snowflake exec ${pkgs.snowflake}/bin/snowflake-client -url https://snowflake-broker.torproject.net.global.prod.fastly.net/ -front cdn.sstatic.net -ice stun:stun.l.google.com:19302,stun:stun.voip.blackberry.com:3478,stun:stun.altar.com.pl:3478,stun:stun.antisip.com:3478,stun:stun.bluesip.net:3478,stun:stun.dus.net:3478,stun:stun.epygi.com:3478,stun:stun.sonetel.com:3478,stun:stun.sonetel.net:3478,stun:stun.stunprotocol.org:3478,stun:stun.uls.co.za:3478,stun:stun.voipgate.com:3478,stun:stun.voys.nl:3478";
#ClientTransportPlugin = "snowflake exec ${pkgs.snowflake}/bin/snowflake-client";
#Bridge = [
# "snowflake 192.0.2.4:80 8838024498816A039FCBBAB14E6F40A0843051FA fingerprint=8838024498816A039FCBBAB14E6F40A0843051FA url=https://1098762253.rsc.cdn77.org/ fronts=www.cdn77.com,www.phpmyadmin.net ice=stun:stun.l.google.com:19302,stun:stun.antisip.com:3478,stun:stun.bluesip.net:3478,stun:stun.dus.net:3478,stun:stun.epygi.com:3478,stun:stun.sonetel.net:3478,stun:stun.uls.co.za:3478,stun:stun.voipgate.com:3478,stun:stun.voys.nl:3478 utls-imitate=hellorandomizedalpn"
# "snowflake 192.0.2.4:80 8838024498816A039FCBBAB14E6F40A0843051FA fingerprint=8838024498816A039FCBBAB14E6F40A0843051FA url=https://1098762253.rsc.cdn77.org/ fronts=www.cdn77.com,www.phpmyadmin.net ice=stun:stun.l.google.com:19302,stun:stun.antisip.com:3478,stun:stun.bluesip.net:3478,stun:stun.dus.net:3478,stun:stun.epygi.com:3478,stun:stun.sonetel.net:3478,stun:stun.uls.co.za:3478,stun:stun.voipgate.com:3478,stun:stun.voys.nl:3478 utls-imitate=hellorandomizedalpn"
#];
};
};
# 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.f_lynx = {
isNormalUser = true;
description = "Alex A. Naanou";
extraGroups = [ "networkmanager" "wheel" ];
packages = with pkgs; [
];
};
environment.localBinInPath = true;
environment.variables.EDITOR = "vim";
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
vim-full
micro
vifm mc far2l
ranger
psmisc
#tdrop
tmux
tree
btop htop #gtop
iotop iftop
ncdu du-dust
gparted
#gdisk
testdisk
jdupes
wget
tor
syncthingtray
#shadowsocks-rust
#shadowsocks-v2ray-plugin
ungoogled-chromium
tor-browser
zip unzip
tldr
bat
# LaTeX
(texlive.combine {
inherit (texlive) scheme-medium
# missing:
# calc graphicx ifthen pgffor rotating trimclip xinttools
kvoptions xargs ifthenx iftex xint listofitems xkeyval
etoolbox changepage pdfcomment eso-pic environ numprint xcolor
pagecolor colorspace graphics adjustbox textpos fancyvrb flowfram
fancyhdr pdfpages geometry
hardwrap catchfile
# doc...
titlesec hypdoc doctools needspace xstring listings imakeidx
latexmk;
#(setq org-latex-compiler "lualatex")
#(setq org-preview-latex-default-process 'dvisvgm)
})
# fonts...
nerdfonts
# GUI
keepassxc
ulauncher
kitty
#logseq
# XXX this does not work on default gnome...
wl-gammactl
nextcloud-client
# dev
gnumake
nodejs
electron
go
python3
#python311Packages.pygobject3
#sbcl
# Gnome stuff...
gnome.gnome-tweaks
gnome.dconf-editor
gnomeExtensions.advanced-alttab-window-switcher
gnomeExtensions.command-menu
gnomeExtensions.search-light
gnomeExtensions.quick-settings-tweaker
#gnomeExtensions.quake-mode
gnomeExtensions.quake-terminal
gnomeExtensions.gsconnect
gnomeExtensions.dash-to-panel
gnomeExtensions.blur-my-shell
gnomeExtensions.unmess
gnomeExtensions.custom-accent-colors
#gnomeExtensions.tray-icons-reloaded
gnomeExtensions.appindicator
gnomeExtensions.customize-ibus
gnomeExtensions.date-menu-formatter
gnomeExtensions.lock-keys
gnomeExtensions.clipboard-indicator
gnomeExtensions.hibernate-status-button
gnomeExtensions.caffeine
gnomeExtensions.grand-theft-focus
#gnomeExtensions.astra-monitor
# does not seem to work...
#gnomeExtensions.syncthing-indicator
gnome-firmware-updater
gnome.gedit
# media...
vlc
mpv
yt-dlp
cmus
media-downloader
ffmpeg
ffmpegthumbnailer
#blender
#krita
#texlive.combined.scheme-full
];
programs.geary.enable = false;
programs.git.enable = true;
programs.dconf.enable = true;
programs.firefox.enable = true;
# XXX not sure who wants electron...
nixpkgs.config.permittedInsecurePackages = [
"electron-25.9.0"
];
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.mtr.enable = true;
# programs.gnupg.agent = {
# enable = true;
# enableSSHSupport = true;
# };
# ulauncher...
# XXX can't get ulauncher to be centered and focus on launch...
#systemd.user.services.ulauncher = {
# enable = true;
# description = "Start Ulauncher";
# script = ''
# ${pkgs.coreutils-full}/bin/sleep 2
# ${pkgs.ulauncher}/bin/ulauncher --hide-window
# '';
# documentation = [ "https://github.com/Ulauncher/Ulauncher/blob/f0905b9a9cabb342f9c29d0e9efd3ba4d0fa456e/contrib/systemd/ulauncher.service" ];
# # XXX this does not work for some reason...
# #wantedBy = [ "graphical.target" ];
# wantedBy = [ "graphical-session.target" ];
# after = [ "display-manager.service" ];
#};
# Open ports in the firewall.
# networking.firewall.allowedTCPPorts = [ ... ];
# networking.firewall.allowedUDPPorts = [ ... ];
# Or disable the firewall altogether.
# networking.firewall.enable = false;
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions
# on your system were taken. Its perfectly fine and recommended to leave
# this value at the release version of the first install of this system.
# Before changing this value read the documentation for this option
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
system.stateVersion = "23.05"; # Did you read the comment?
}