# 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, lib, ... }: { imports = [ ./hardware-configuration.nix ../../modules/users/defin.nix ../../modules/users/root.nix ../../modules/nixos/hyprland.nix ../../modules/nixos/asus-numpad-touchpad.nix ../../modules/nixos/bluetooth.nix ../../modules/nixos/environment.nix ../../modules/nixos/kde-connect.nix ../../modules/nixos/nix-common.nix ../../modules/nixos/services.nix ../../modules/nixos/tailscale.nix ../../modules/nixos/steam.nix # ../..modules/nixos/sway.nix ../../modules/nixos/system-packages.nix ]; # Use the systemd-boot EFI boot loader. boot = { loader = { systemd-boot.enable = true; efi.canTouchEfiVariables = true; }; kernelPackages = pkgs.linuxPackages_latest; # use latest kernel binfmt.emulatedSystems = ["aarch64-linux"]; }; hardware.onlykey.enable = true; services.udev.extraRules = '' # SUBSYSTEMS=="usb", ATTRS{idVendor}=="1d50", ATTRS{idProduct}=="60fc", OWNER:="defin", GROUP:="onlykey", RUN+="${pkgs.onlykey-cli}/bin/onlykey-cli settime" # KERNEL=="ttyACM*", ATTRS{idVendor}=="1d50", ATTRS{idProduct}=="60fc", OWNER:="defin", GROUP:="onlykey", RUN+="${pkgs.onlykey-cli}/bin/onlykey-cli settime" ''; # i2c for https://github.com/mohamed-badaoui/asus-touchpad-numpad-driver hardware.i2c.enable = true; systemd.services.asus-touchpad-numpad = { description = "Activate Numpad inside the touchpad with top right corner switch"; documentation = ["https://github.com/mohamed-badaoui/asus-touchpad-numpad-driver"]; path = [ pkgs.i2c-tools ]; script = '' cd ${pkgs.fetchFromGitHub { owner = "mohamed-badaoui"; repo = "asus-touchpad-numpad-driver"; # These needs to be updated from time to time rev = "d80980af6ef776ee6acf42c193689f207caa7968"; sha256 = "sha256-JM2wrHqJTqCIOhD/yvfbjLZEqdPRRbENv+N9uQHiipc="; }} # In the last argument here you choose your layout. ${pkgs.python3.withPackages(ps: [ ps.libevdev ])}/bin/python asus_touchpad.py m433ia ''; # Probably needed because it fails on boot seemingly because the driver # is not ready yet. Alternativly, you can use `sleep 3` or similar in the # `script`. serviceConfig = { RestartSec = "1s"; Restart = "on-failure"; }; wantedBy = [ "multi-user.target" ]; }; nix.settings = { substituters = ["https://hyprland.cachix.org"]; trusted-public-keys = ["hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="]; }; nixpkgs = { # texlive.combined.scheme-medium; # system = "x84_64-linux"; config.allowUnfree = true; }; environment.shellInit = ''export NIXPATH="/nix/var/nix/profiles/per-user/$USER/channels:nixos-config=/etc/nixos/machines/zenbook/configuration.nix"''; environment.systemPackages = with pkgs; [ acpi # for battery utils # ciscoPacketTracer8 ]; services.displayManager = { sddm = { enable = true; enableHidpi = true; wayland.enable = true; settings = { Wayland.EnableHiDPI = "true"; X11.ServerArguments = "-nolisten tcp -dpi 170"; }; }; }; networking = { firewall = { # Open ports in the firewall. # networking.firewall.allowedTCPPorts = [ ... ]; # networking.firewall.allowedUDPPorts = [ ... ]; # Or disable the firewall altogether. # enable = false; }; hostName = "zenbook"; # Pick only one of the below networking options. # wireless.enable = true; # Enables wireless support via wpa_supplicant. networkmanager.enable = true; # Easiest to use and most distros use this by default. # Configure network proxy if necessary # proxy.default = "http://user:password@proxy:port/"; # proxy.noProxy = "127.0.0.1,localhost,internal.domain"; }; # Set your time zone. time.timeZone = lib.mkDefault "US/Mountain"; services.automatic-timezoned.enable = true; # time.timeZone = "Europe/Stockholm"; # time.timeZone = "UTC"; # Select internationalisation properties. # i18n.defaultLocale = "en_US.UTF-8"; # console = { # font = "Lat2-Terminus16"; # keyMap = "us"; # useXkbConfig = true; # use xkbOptions in tty. # }; # Enable sound. # sound.enable = true; # hardware.pulseaudio.enable = true; # Some programs need SUID wrappers, can be configured further or are # started in user sessions. programs = { wireshark = { enable = true; # package = pkgs.wireshark; }; light.enable = true; mtr.enable = true; gnupg.agent = { enable = true; enableSSHSupport = true; }; adb.enable = true; }; # enable the OpenSSH daemon services.openssh.enable = true; services.udev.packages = [ # for flashing calyxos pkgs.android-udev-rules ]; # Copy the NixOS configuration file and link it from the resulting system # (/run/current-system/configuration.nix). This is useful in case you # accidentally delete configuration.nix. # system.copySystemConfiguration = true; # 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 = "23.05"; # Did you read the comment? }