liminalOS/modules/linux/core/default.nix

195 lines
5.4 KiB
Nix
Raw Normal View History

2024-08-24 03:52:55 -07:00
{
inputs,
pkgs,
2024-11-04 11:57:01 -08:00
config,
2024-12-23 02:09:41 -08:00
lib,
...
2024-09-02 18:16:22 -07:00
}:
2024-12-23 02:09:41 -08:00
let
cfg = config.liminalOS.system.core;
in
2024-09-02 18:16:22 -07:00
{
2024-12-23 02:09:41 -08:00
options.liminalOS.system.core = {
enable = lib.mkOption {
type = lib.types.bool;
default = config.liminalOS.enable;
description = ''
Whether to enable core liminalOS system utilities and configurations (such as security policies, Nix options, etc)
'';
};
replaceSudoWithDoas = lib.mkOption {
type = lib.types.bool;
default = cfg.enable;
description = ''
Whether to replace sudo with doas, the Dedicated OpenBSD Application Subexecutor. Doas is the preferred liminalOS setuid program.
'';
};
waylandFixes = lib.mkOption {
type = lib.types.bool;
default = cfg.enable;
description = ''
Whether to enable some Wayland fixes, like setting NIXOS_OZONE_WL to hint Electron apps to use the Wayland windowing system.
'';
};
nixSaneDefaults = lib.mkOption {
type = lib.types.bool;
default = cfg.enable;
description = ''
Whether to set sane defaults for Nix, such as optimization and automatic garbage collection.
'';
};
useNh = lib.mkOption {
type = lib.types.bool;
default = cfg.nixSaneDefaults;
description = ''
Whether to enable the `nh` cli (yet another Nix helper), a reimplementation of some core NixOS utilities like nix-collect-garbage and nixos-rebuild. If enabled, automatic garbage collection will use `nh` instead of `nix-collect-garbage` and will be able to garbage collect `result` symlinks.
'';
};
suppressWarnings = lib.mkEnableOption "suppress warnings";
networking = {
enable = lib.mkOption {
type = lib.types.bool;
default = true;
description = ''Whether to set up and enable networking daemons.'';
};
backend = lib.mkOption {
type = lib.types.enum [
"wpa_supplicant"
"iwd"
];
default = "wpa_supplicant";
description = ''
Which backend to use for networking. Default is wpa_supplicant with NetworkManager as a frontend. With iwd, iwctl is the frontend.
'';
};
};
bluetooth.enable = lib.mkOption {
type = lib.types.bool;
default = true;
description = ''
Whether to enable bluetooth and blueman.
'';
};
};
2024-12-23 02:09:41 -08:00
config = lib.mkIf cfg.enable {
environment.systemPackages =
with pkgs;
[
wget
git
curl
]
++ [
inputs.viminal.packages.${pkgs.system}.default
];
2024-12-23 02:09:41 -08:00
environment.variables = {
EDITOR = "nvim";
};
2024-08-24 03:52:55 -07:00
2024-12-23 02:09:41 -08:00
# tells electron apps to use Wayland
environment.sessionVariables = lib.mkIf cfg.waylandFixes {
NIXOS_OZONE_WL = "1";
};
2024-09-05 19:20:37 -07:00
2024-12-23 02:09:41 -08:00
security = {
sudo.enable = !cfg.replaceSudoWithDoas;
2024-12-23 02:09:41 -08:00
doas = lib.mkIf cfg.replaceSudoWithDoas {
enable = true;
extraRules = [
{
users = [ "youwen" ];
keepEnv = true;
persist = true;
}
];
};
2024-11-10 20:29:37 -08:00
2024-12-23 02:09:41 -08:00
rtkit.enable = true;
2024-11-10 20:29:37 -08:00
};
2024-12-23 02:09:41 -08:00
services.gnome.gnome-keyring.enable = true;
2024-11-04 11:57:01 -08:00
2024-12-23 02:09:41 -08:00
nix = lib.mkIf cfg.nixSaneDefaults {
gc = lib.mkIf (!cfg.useNh) {
automatic = true;
dates = "weekly";
options = "--delete-older-than 14d";
};
2024-09-29 01:51:24 -07:00
2024-12-23 02:09:41 -08:00
optimise.automatic = true;
# Free up to 1GiB when there is less than 100MiB left
extraOptions = ''
min-free = ${toString (100 * 1024 * 1024)}
max-free = ${toString (1024 * 1024 * 1024)}
'';
settings = {
experimental-features = [
"nix-command"
"flakes"
];
substituters = [
"https://cache.nixos.org"
];
trusted-public-keys = [
"hydra.nixos.org-1:CNHJZBh9K4tP3EKF6FkkgeVYsS3ohTl+oS0Qa8bezVs="
];
};
channel.enable = false;
};
programs.nh = lib.mkIf cfg.useNh {
enable = true;
clean = lib.mkIf cfg.nixSaneDefaults {
enable = true;
extraArgs = "--keep-since 4d --keep 3";
};
flake = config.liminalOS.flakeLocation;
2024-12-23 02:09:41 -08:00
};
2024-12-02 23:00:00 -08:00
2024-12-23 02:09:41 -08:00
boot.tmp.cleanOnBoot = true;
hardware.enableRedistributableFirmware = true;
networking.networkmanager.enable = lib.mkIf (
cfg.networking.enable && cfg.networking.backend == "wpa_supplicant"
) true;
systemd.services.NetworkManager-wait-online.enable = lib.mkIf (
cfg.networking.enable && cfg.networking.backend == "wpa_supplicant"
) false;
networking.wireless.iwd = lib.mkIf (cfg.networking.enable && cfg.networking.backend == "iwd") {
enable = true;
settings.General.EnableNetworkConfiguration = true;
};
programs.gnupg.agent = {
enable = true;
enableSSHSupport = true;
};
programs.dconf.enable = true;
hardware.bluetooth = lib.mkIf cfg.bluetooth.enable {
enable = true;
powerOnBoot = true;
};
services.blueman.enable = lib.mkIf cfg.bluetooth.enable true;
2024-12-23 02:09:41 -08:00
warnings =
if !cfg.suppressWarnings && cfg.useNh && config.liminalOS.flakeLocation == "" then
2024-12-23 02:09:41 -08:00
[
''The `nh` CLI is enabled but `liminalOS.flakeLocation` is not set. It is recommended that you set this option to the absolute file path of your configuration flake so that `nh` can work without specifying the flake path every time. You can disable this warning by setting `liminalOS.system.core.suppressWarnings`.''
2024-12-23 02:09:41 -08:00
]
else
[ ];
};
2024-08-24 03:52:55 -07:00
}