mirror of
https://github.com/librephoenix/nixos-config
synced 2025-01-19 07:05:51 +05:30
121 lines
3.9 KiB
Nix
121 lines
3.9 KiB
Nix
# 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’).
|
||
|
||
{ pkgs, pkgs-staging-next, lib, systemSettings, userSettings, ... }:
|
||
{
|
||
imports =
|
||
[ ../../system/hardware-configuration.nix
|
||
../../system/hardware/systemd.nix # systemd config
|
||
../../system/hardware/kernel.nix # Kernel config
|
||
../../system/hardware/power.nix # Power management
|
||
../../system/hardware/time.nix # Network time sync
|
||
../../system/hardware/opengl.nix
|
||
../../system/hardware/printing.nix
|
||
../../system/hardware/bluetooth.nix
|
||
(./. + "../../../system/wm"+("/"+userSettings.wm)+".nix") # My window manager
|
||
#../../system/app/flatpak.nix
|
||
../../system/app/virtualization.nix
|
||
( import ../../system/app/docker.nix {storageDriver = null; inherit pkgs userSettings lib;} )
|
||
../../system/security/doas.nix
|
||
../../system/security/gpg.nix
|
||
../../system/security/blocklist.nix
|
||
../../system/security/firewall.nix
|
||
../../system/security/firejail.nix
|
||
../../system/security/openvpn.nix
|
||
../../system/security/automount.nix
|
||
../../system/style/stylix.nix
|
||
];
|
||
|
||
# xz trojan https://github.com/NixOS/nixpkgs/issues/300055
|
||
system.replaceRuntimeDependencies = [
|
||
{
|
||
original = pkgs.xz;
|
||
replacement = pkgs-staging-next.xz;
|
||
}
|
||
];
|
||
|
||
# Fix nix path
|
||
nix.nixPath = [ "nixpkgs=/nix/var/nix/profiles/per-user/root/channels/nixos"
|
||
"nixos-config=$HOME/dotfiles/system/configuration.nix"
|
||
"/nix/var/nix/profiles/per-user/root/channels"
|
||
];
|
||
|
||
# Ensure nix flakes are enabled
|
||
nix.package = pkgs.nixFlakes;
|
||
nix.extraOptions = ''
|
||
experimental-features = nix-command flakes
|
||
'';
|
||
|
||
# I'm sorry Stallman-taichou
|
||
nixpkgs.config.allowUnfree = true;
|
||
|
||
# Kernel modules
|
||
boot.kernelModules = [ "i2c-dev" "i2c-piix4" "cpufreq_powersave" ];
|
||
|
||
# Bootloader
|
||
# Use systemd-boot if uefi, default to grub otherwise
|
||
boot.loader.systemd-boot.enable = if (systemSettings.bootMode == "uefi") then true else false;
|
||
boot.loader.efi.canTouchEfiVariables = if (systemSettings.bootMode == "uefi") then true else false;
|
||
boot.loader.efi.efiSysMountPoint = systemSettings.bootMountPath; # does nothing if running bios rather than uefi
|
||
boot.loader.grub.enable = if (systemSettings.bootMode == "uefi") then false else true;
|
||
boot.loader.grub.device = systemSettings.grubDevice; # does nothing if running uefi rather than bios
|
||
|
||
# Networking
|
||
networking.hostName = systemSettings.hostname; # Define your hostname.
|
||
networking.networkmanager.enable = true; # Use networkmanager
|
||
|
||
# Timezone and locale
|
||
time.timeZone = systemSettings.timezone; # time zone
|
||
i18n.defaultLocale = systemSettings.locale;
|
||
i18n.extraLocaleSettings = {
|
||
LC_ADDRESS = systemSettings.locale;
|
||
LC_IDENTIFICATION = systemSettings.locale;
|
||
LC_MEASUREMENT = systemSettings.locale;
|
||
LC_MONETARY = systemSettings.locale;
|
||
LC_NAME = systemSettings.locale;
|
||
LC_NUMERIC = systemSettings.locale;
|
||
LC_PAPER = systemSettings.locale;
|
||
LC_TELEPHONE = systemSettings.locale;
|
||
LC_TIME = systemSettings.locale;
|
||
};
|
||
|
||
# User account
|
||
users.users.${userSettings.username} = {
|
||
isNormalUser = true;
|
||
description = userSettings.name;
|
||
extraGroups = [ "networkmanager" "wheel" "input" "dialout" ];
|
||
packages = [];
|
||
uid = 1000;
|
||
};
|
||
|
||
# System packages
|
||
environment.systemPackages = with pkgs; [
|
||
vim
|
||
wget
|
||
zsh
|
||
git
|
||
cryptsetup
|
||
home-manager
|
||
];
|
||
|
||
# I use zsh btw
|
||
environment.shells = with pkgs; [ zsh ];
|
||
users.defaultUserShell = pkgs.zsh;
|
||
programs.zsh.enable = true;
|
||
|
||
fonts.fontDir.enable = true;
|
||
|
||
xdg.portal = {
|
||
enable = true;
|
||
extraPortals = [
|
||
pkgs.xdg-desktop-portal
|
||
pkgs.xdg-desktop-portal-gtk
|
||
];
|
||
};
|
||
|
||
# It is ok to leave this unchanged for compatibility purposes
|
||
system.stateVersion = "22.11";
|
||
|
||
}
|