# 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 = [ # Include the results of the hardware scan. ./audio.nix ./hardware-configuration.nix ]; # Use the GRUB 2 boot loader. boot.loader.grub.enable = true; boot.loader.grub.version = 2; # boot.loader.grub.efiSupport = true; # boot.loader.grub.efiInstallAsRemovable = true; # boot.loader.efi.efiSysMountPoint = "/boot/efi"; # Define on which hard drive you want to install Grub. boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only networking.hostName = "fedoranvar"; # Define your hostname. networking.networkmanager.enable = true; # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. # Set your time zone. # time.timeZone = "Europe/Amsterdam"; # The global useDHCP flag is deprecated, therefore explicitly set to false here. # Per-interface useDHCP will be mandatory in the future, so this generated config # replicates the default behaviour. networking.useDHCP = false; # networking.interfaces.enp0s25.useDHCP = true; # networking.interfaces.wlp3s0.useDHCP = true; # Configure network proxy if necessary # networking.proxy.default = "http://user:password@proxy:port/"; # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; # Select internationalisation properties. i18n.defaultLocale = "en_US.UTF-8"; console = { font = "${pkgs.terminus_font}/share/consolefonts/ter-u28n.psf.gz"; keyMap = "us"; }; # Enable the X11 windowing system. services.udev.packages = [ pkgs.android-udev-rules ]; services.xserver = { layout = "us,ru"; xkbOptions = "caps:swapescape"; # dpi = 100; enable = true; displayManager.startx.enable = true; windowManager.awesome = { enable = true; luaModules = with pkgs.luaPackages; [ luarocks luadbi-mysql ]; }; }; # Enable CUPS to print documents. # services.printing.enable = true; # Enable sound. sound.enable = true; hardware.bluetooth.enable = true; hardware.opengl.driSupport = true; virtualisation.docker.enable = true; services.blueman.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.fedor = { shell = pkgs.zsh; isNormalUser = true; extraGroups = [ "audio" "mpd" "wheel" "docker" "adbusers" ]; # Enable ‘sudo’ for the user. }; security.sudo.wheelNeedsPassword = false; # List packages installed in system profile. To search, run: # $ nix search wget nixpkgs.config.allowUnfree = true; environment.systemPackages = with pkgs; let unstable = import (fetchTarball https://nixos.org/channels/nixos-unstable/nixexprs.tar.xz) # reuse the current configuration { config = config.nixpkgs.config; }; my-python-packages = python-packages: with python-packages; [ pip ]; my-python-with-packages = python3.withPackages my-python-packages; in [ pulsemixer pulseaudio blueman my-python-with-packages unstable.xplr unstable.gpg-tui cargo pinentry gtk3 lxappearance tdesktop hsetroot fd ripgrep gnumake vim gcc networkmanager awesome zsh docker docker-compose arandr dash neovim docui dunst delta postgresql_10 ncmpcpp mpd mpv youtube-dl sxiv zathura brave alacritty git xclip openvpn xsel copyq flameshot tmux stow wget shellcheck go nodejs yarn ninja keepassxc sshpass sshfs pijul bottom udiskie exa gnupg xorg.xf86inputevdev xorg.xorgserver xorg.xf86inputsynaptics xorg.xf86inputlibinput xorg.xf86videointel ]; nixpkgs.overlays = [ ( import ( builtins.fetchTarball { url = https://github.com/nix-community/neovim-nightly-overlay/archive/master.tar.gz; } ) ) ]; # Some programs need SUID wrappers, can be configured further or are # started in user sessions. # programs.mtr.enable = true; programs.adb.enable = true; programs.gnupg.agent = { enable = true; enableSSHSupport = true; }; programs.zsh.enable = true; # List services that you want to enable: # Enable the OpenSSH daemon. # services.openssh.enable = true; # 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. It‘s 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 = "21.05"; # Did you read the comment? }