mirror of
https://github.com/librephoenix/nixos-config
synced 2025-01-19 07:05:51 +05:30
151 lines
4.9 KiB
Nix
151 lines
4.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, 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
|
||
];
|
||
|
||
# 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
|
||
'';
|
||
nixpkgs.overlays = [
|
||
(
|
||
final: prev: {
|
||
logseq = prev.logseq.overrideAttrs (oldAttrs: {
|
||
postFixup = ''
|
||
makeWrapper ${prev.electron_27}/bin/electron $out/bin/${oldAttrs.pname} \
|
||
--set "LOCAL_GIT_DIRECTORY" ${prev.git} \
|
||
--add-flags $out/share/${oldAttrs.pname}/resources/app \
|
||
--add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations}}" \
|
||
--prefix LD_LIBRARY_PATH : "${prev.lib.makeLibraryPath [ prev.stdenv.cc.cc.lib ]}"
|
||
'';
|
||
});
|
||
}
|
||
)
|
||
];
|
||
|
||
|
||
# logseq
|
||
nixpkgs.config.permittedInsecurePackages = [
|
||
"electron-27.3.11"
|
||
];
|
||
|
||
# wheel group gets trusted access to nix daemon
|
||
nix.settings.trusted-users = [ "@wheel" ];
|
||
|
||
# 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" "video" "render" ];
|
||
packages = [];
|
||
uid = 1000;
|
||
};
|
||
|
||
# System packages
|
||
environment.systemPackages = with pkgs; [
|
||
vim
|
||
logseq
|
||
wget
|
||
zsh
|
||
git
|
||
cryptsetup
|
||
home-manager
|
||
wpa_supplicant
|
||
(pkgs.writeScriptBin "comma" ''
|
||
if [ "$#" = 0 ]; then
|
||
echo "usage: comma PKGNAME... [EXECUTABLE]";
|
||
elif [ "$#" = 1 ]; then
|
||
nix-shell -p $1 --run $1;
|
||
elif [ "$#" = 2 ]; then
|
||
nix-shell -p $1 --run $2;
|
||
else
|
||
echo "error: too many arguments";
|
||
echo "usage: comma PKGNAME... [EXECUTABLE]";
|
||
fi
|
||
'')
|
||
];
|
||
|
||
# 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";
|
||
|
||
}
|