nixos_config/nixos/modules/base.nix

192 lines
5.3 KiB
Nix
Raw Normal View History

2026-03-10 21:50:51 +01:00
{ config, pkgs, lib, repoLocalPath, ... }:
{
2025-12-07 12:36:40 +01:00
boot = {
kernelPackages = lib.mkDefault pkgs.linuxPackages_latest;
kernel.sysctl = {
"net.ipv4.ip_unprivileged_port_start" = 0;
};
2026-03-10 21:50:51 +01:00
initrd = {
network = {
2026-02-01 17:33:45 +01:00
ssh.shell = pkgs.bash;
2026-02-01 17:34:19 +01:00
};
};
2025-08-02 10:49:11 +02:00
};
2026-03-10 21:50:51 +01:00
2026-03-10 10:31:16 +01:00
security.sudo-rs.enable = true;
2025-07-23 19:46:26 +02:00
system.stateVersion = "24.05";
2026-03-10 21:50:51 +01:00
2025-07-29 11:25:40 +02:00
system.autoUpgrade = {
enable = true;
persistent = true;
2026-03-10 21:50:51 +01:00
flake = repoLocalPath;
2025-07-29 11:25:40 +02:00
flags = [
2026-01-30 16:41:25 +01:00
"--print-build-logs"
"--no-write-lock-file"
2025-07-29 11:25:40 +02:00
];
dates = "daily";
2026-03-10 21:50:51 +01:00
};
2025-07-29 11:25:40 +02:00
nix = {
settings = {
experimental-features = [ "nix-command" "flakes" ];
auto-optimise-store = true;
trusted-users = [ "root" "alisceon" ];
2026-03-10 21:50:51 +01:00
};
2025-07-29 11:25:40 +02:00
gc = {
automatic = true;
persistent = true;
dates = "daily";
2025-08-08 14:43:40 +02:00
options = "--delete-older-than 7d";
2026-03-10 21:50:51 +01:00
};
2025-07-29 11:25:40 +02:00
registry = {
templates.to = {
type = "git";
url = "git+ssh://git@git.malice.zone/alisceon/devenv_templates.git";
2026-03-10 21:50:51 +01:00
};
2025-08-08 21:43:53 +02:00
nixpkgs.to = {
type = "github";
owner = "NixOS";
repo = "nixpkgs";
ref = "nixos-unstable";
2026-03-10 21:50:51 +01:00
};
2025-08-08 21:43:53 +02:00
nixpkgs-stable.to = {
type = "github";
owner = "NixOS";
repo = "nixpkgs";
ref = "nixos-25.05";
2026-03-10 21:50:51 +01:00
};
};
};
2025-07-23 19:46:19 +02:00
2025-07-23 19:46:26 +02:00
console.keyMap = "sv-latin1";
2025-07-23 19:46:19 +02:00
networking.networkmanager.enable = true;
time.timeZone = "Europe/Stockholm";
i18n.defaultLocale = "en_US.UTF-8";
i18n.extraLocaleSettings = {
LC_ADDRESS = "sv_SE.UTF-8";
LC_IDENTIFICATION = "sv_SE.UTF-8";
LC_MEASUREMENT = "sv_SE.UTF-8";
LC_MONETARY = "sv_SE.UTF-8";
LC_NAME = "sv_SE.UTF-8";
LC_NUMERIC = "sv_SE.UTF-8";
LC_PAPER = "sv_SE.UTF-8";
LC_TELEPHONE = "sv_SE.UTF-8";
LC_TIME = "sv_SE.UTF-8";
};
2025-07-29 11:25:40 +02:00
environment = {
systemPackages = with pkgs; [
2026-02-03 17:12:17 +01:00
libressl
2025-07-29 11:25:40 +02:00
git
wget
curl
2026-03-10 21:50:51 +01:00
btop
ripgrep
fd
nh
jq
2025-08-25 10:01:53 +02:00
ncdu
pciutils
usbutils
tree
2026-03-10 21:50:51 +01:00
fzf
2025-11-09 20:26:03 +01:00
psmisc
pv
2026-01-08 18:05:08 +01:00
file
2026-02-03 17:12:17 +01:00
nix-tree
2026-02-05 11:49:37 +01:00
unzip
2026-03-10 21:50:51 +01:00
lsd
2025-07-29 11:25:40 +02:00
bash
2025-08-08 21:43:53 +02:00
nushell
fish
powershell
2025-08-25 10:39:22 +02:00
python3
2025-09-08 13:30:20 +02:00
python3Packages.python-lsp-server
2026-03-10 21:50:51 +01:00
podman
];
2025-09-04 15:05:45 +02:00
2026-03-10 21:50:51 +01:00
shells = with pkgs; [
2025-08-08 21:43:53 +02:00
bash
nushell
fish
powershell
2025-09-03 23:26:51 +02:00
xonsh
2025-08-14 12:27:04 +02:00
];
2026-03-10 21:50:51 +01:00
2026-02-03 17:12:17 +01:00
etc."current-system-packages".text =
2026-03-10 21:50:51 +01:00
let
packages = builtins.map (p: "${p.name}:\t${p}") config.environment.systemPackages;
sortedUnique = builtins.sort builtins.lessThan (pkgs.lib.lists.unique packages);
in
pkgs.lib.strings.concatLines sortedUnique;
};
2025-07-23 19:46:19 +02:00
2025-09-24 18:23:45 +02:00
virtualisation = {
2026-03-06 15:09:04 +01:00
libvirtd = {
enable = true;
2026-03-10 21:50:51 +01:00
qemu.swtpm.enable = true;
2026-03-06 15:09:04 +01:00
};
2025-09-24 18:23:45 +02:00
containers.enable = true;
2026-03-10 21:50:51 +01:00
docker.enable = true;
2025-09-24 18:23:45 +02:00
podman = {
enable = true;
2026-05-07 22:28:52 +02:00
dockerCompat = false;
2025-09-24 18:23:45 +02:00
defaultNetwork.settings.dns_enabled = true;
2026-03-10 21:50:51 +01:00
};
2025-09-24 18:23:45 +02:00
oci-containers.backend = "podman";
2026-03-10 21:50:51 +01:00
};
2025-07-23 19:46:19 +02:00
2026-03-06 15:09:04 +01:00
users = {
defaultUserShell = pkgs.bash;
2026-03-10 21:50:51 +01:00
groups.docker = { };
2026-03-06 15:09:04 +01:00
users.alisceon = {
isNormalUser = true;
2026-03-10 21:50:51 +01:00
extraGroups = [ "wheel" "networkmanager" "podman" "docker" "libvirtd" ];
2026-03-06 15:09:04 +01:00
shell = pkgs.xonsh;
openssh.authorizedKeys.keys = [
"ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBPN1Cd2UlHo03Jqgi5Yb4io/3gh/X4wCb8LcmKlpAovQa271CKDBtYOUKn+Fts03g6dBMfaWMty6VGPMGDMONmc= alisceon@electra"
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQCvRYyYjN8z0yoPrHtaTQXY0iEtPl79K6/uXVceuS+31JGjRnqJjuDYg6KxAykGSfhercNdAJ2BTYJRGpMsW0Xn7+iq07TItcjJjERm7rjQZko4vauS62NdnV6BEG+6ktasb9CcepzwoRkLEXQOad3XbLbo0V2sj6uI5Rgq2Cfh6f9x1E1DJ87o6Ngkm+vQzdv4NYeya/O4vuoAw6BNhp4vyr9k+0K+TRLjflYPUwtb8U/agoYI5RoLZMa6eBKdPbLVYyahpMlYjHwr90H4c9veHliILcDSA8h6upcXSDwZiCPyu6cI4zRbzGQVg84iLmIs5ocMWsnuDQbqn5iM3BTV37atnTPI3O2C9WBxuOaGpk4C338V0CAfTo6GG/OSaFzfLBFE29nY6uXcCPH7KiDpig0naVWlpHZhED5OQRoSXBeyu4BgadV6eZ43HOcdbOAqbLcB1nvkKPi52Vj+JqwS8zIjQpipX22Trx2u4ike99ijeK6/XeoTnEAcUS0fcYQ0FDqqfLmr/HuxkEQ2NZF0sFFqVGUlpVJMFblNOH4L8A2kApnsrmlxnlVE+r0tTnnnK5tfCpyou/LPDM+4TzGw2nV2cwsZKbGaHvMM/qIvVva90mTcYfuDvGB10eQ2P9tN1TIjseONVLDVKNjNGzDBFY4RMeMJOWWQy0aBh0FP5Q== user@hannah.afk"
];
2026-03-10 21:50:51 +01:00
};
};
2025-08-25 10:01:53 +02:00
2025-09-03 23:26:51 +02:00
programs = {
command-not-found.enable = true;
2025-09-04 15:13:04 +02:00
fzf.fuzzyCompletion = true;
2025-09-03 23:26:51 +02:00
xonsh = {
enable = true;
2025-09-04 15:05:45 +02:00
extraPackages = ps: with ps; [
pyperclip
2025-09-04 09:30:33 +02:00
xonsh.xontribs.xonsh-direnv
2025-09-04 15:05:45 +02:00
pkgs.nur.repos.xonsh-xontribs.xontrib-fish-completer
pkgs.nur.repos.xonsh-xontribs.xontrib-abbrevs
pkgs.nur.repos.xonsh-xontribs.xontrib-clp
pkgs.nur.repos.xonsh-xontribs.xontrib-bashisms
2026-03-10 21:50:51 +01:00
(
ps.buildPythonPackage
rec {
name = "xontrib-fzf-completions";
version = "v0.0.2";
format = "pyproject";
2025-09-04 15:05:45 +02:00
nativeBuildInputs = [ ps.setuptools ps.setuptools-scm ps.wheel ];
2026-03-10 21:50:51 +01:00
propagatedBuildInputs = [ ps.xonsh ];
src = pkgs.fetchFromGitHub {
owner = "doronz88";
repo = "${name}";
rev = "${version}";
sha256 = "sha256-1z5xHX4Psevn8686QkwIzv/LOJ5IMJc2nQ5Hg/2svTc=";
};
meta = {
homepage = "https://github.com/doronz88/xontrib-fzf-completions";
description = "fuzzy completions for xonsh";
license = pkgs.lib.licenses.mit;
maintainers = [ ];
};
}
)
];
config = builtins.readFile ../../home/conf/xonsh/xonshrc;
};
};
}