33 Commits

Author SHA1 Message Date
d9937916bb temp 2025-12-07 20:52:45 -08:00
4c7142dcda make lanzaboote optional 2025-12-07 20:47:34 -08:00
923f3f0ffc temp 2025-12-06 18:11:15 -08:00
578f18bc2d WIP: add secure boot 2025-12-06 16:52:27 -08:00
91727dd2df home: git: fix aliases 2025-12-06 16:46:18 -08:00
4e08c64ce5 home: plasma: persist baloofile index excludes, highlight changed system settings 2025-12-06 16:46:17 -08:00
d61c23f8e7 laptop: disable fprint for login 2025-12-06 16:46:15 -08:00
07d3706a14 router: dns: add n8n 2025-11-25 14:52:47 -08:00
1f647856ab updates: nixpkgs, home-manager, plasma-manager, secrix 2025-11-25 00:50:43 -08:00
05a20f830f updates: linux 6.17, nixpkgs, home-manager, plasma-manager 2025-11-25 00:49:51 -08:00
35bb5e411e desktop: add jellyfin-mpv-shim and mpv with plugins 2025-11-20 22:29:34 -08:00
5353ad048c desktop: add C and Ruby 2025-11-08 17:01:28 -08:00
9bb5b596b7 router: dns: add minecruft 2025-11-08 17:00:21 -08:00
ce9bcb785a updates: nixpkgs, home-manager, plasma-manager 2025-10-11 16:03:29 -07:00
178626a193 router: add port forward for minecruft server 2025-10-11 15:09:30 -07:00
3074b81b45 router: add port forward for amnezia vpn 2025-10-11 15:09:15 -07:00
e7ebaf371b router: update cloudflare api key 2025-09-21 19:57:06 -07:00
bd44812337 updates: nixpkgs, home-manager, plasma-manager 2025-09-18 12:39:52 -07:00
d7ee1f6434 desktop: add zed package version server and racket 2025-09-18 12:39:51 -07:00
8880ac8158 updates: linux 6.16, nixpkgs, home-manager 2025-09-18 12:39:45 -07:00
57d47def99 desktop: disable tests in git package 2025-09-18 12:39:44 -07:00
8762c5b555 updates: nixpkgs, home-manager, plasma-manager 2025-09-11 13:32:49 -07:00
eee8fd5ece updates: nixpkgs, home-manager, secrix 2025-07-30 14:28:21 -07:00
e09bca0feb desktop: add NetworkManager plugin for OpenVPN 2025-07-22 17:44:40 -07:00
f9b152cd52 updates: nixpkgs, home-manager, nixos-generators 2025-07-09 12:14:54 -07:00
2de9229027 router: add caddy proxy to homeassistant vm 2025-06-25 00:31:44 -07:00
00bc6f8de3 router: dns: add adguard exception for grafana telemetry domain 2025-06-25 00:30:36 -07:00
21a058f5ea router: refactor caddy config to use wildcard cert 2025-06-25 00:28:09 -07:00
574ba8a951 pc: move nix store to separate zfs dataset 2025-06-24 00:00:09 -07:00
15dc8dd7c4 updates: nixpkgs, home-manager 2025-06-22 22:38:19 -07:00
2bd88d7a93 users: cazzzer: add dialout group for microcontroller stuff 2025-06-09 19:23:07 -07:00
5ec716919d router: add host configurations for test routers 2025-06-09 19:20:01 -07:00
47c9cff8f5 router: move most configuration into modules with options 2025-06-09 19:19:54 -07:00
19 changed files with 263 additions and 55 deletions

178
flake.lock generated
View File

@@ -1,5 +1,79 @@
{
"nodes": {
"crane": {
"locked": {
"lastModified": 1754269165,
"narHash": "sha256-0tcS8FHd4QjbCVoxN9jI+PjHgA4vc/IjkUSp+N3zy0U=",
"owner": "ipetkov",
"repo": "crane",
"rev": "444e81206df3f7d92780680e45858e31d2f07a08",
"type": "github"
},
"original": {
"owner": "ipetkov",
"repo": "crane",
"type": "github"
}
},
"flake-compat": {
"flake": false,
"locked": {
"lastModified": 1747046372,
"narHash": "sha256-CIVLLkVgvHYbgI2UpXvIIBJ12HWgX+fjA8Xf8PUmqCY=",
"owner": "edolstra",
"repo": "flake-compat",
"rev": "9100a0f413b0c601e0533d1d94ffd501ce2e7885",
"type": "github"
},
"original": {
"owner": "edolstra",
"repo": "flake-compat",
"type": "github"
}
},
"flake-parts": {
"inputs": {
"nixpkgs-lib": [
"lanzaboote",
"nixpkgs"
]
},
"locked": {
"lastModified": 1754091436,
"narHash": "sha256-XKqDMN1/Qj1DKivQvscI4vmHfDfvYR2pfuFOJiCeewM=",
"owner": "hercules-ci",
"repo": "flake-parts",
"rev": "67df8c627c2c39c41dbec76a1f201929929ab0bd",
"type": "github"
},
"original": {
"owner": "hercules-ci",
"repo": "flake-parts",
"type": "github"
}
},
"gitignore": {
"inputs": {
"nixpkgs": [
"lanzaboote",
"pre-commit-hooks-nix",
"nixpkgs"
]
},
"locked": {
"lastModified": 1709087332,
"narHash": "sha256-HG2cCnktfHsKV0s4XW83gU3F57gaTljL9KNSuG6bnQs=",
"owner": "hercules-ci",
"repo": "gitignore.nix",
"rev": "637db329424fd7e46cf4185293b9cc8c88c95394",
"type": "github"
},
"original": {
"owner": "hercules-ci",
"repo": "gitignore.nix",
"type": "github"
}
},
"home-manager": {
"inputs": {
"nixpkgs": [
@@ -7,11 +81,11 @@
]
},
"locked": {
"lastModified": 1749178927,
"narHash": "sha256-bXcEx1aZUNm5hMLVJeuofcOrZyOiapzvQ7K36HYK3YQ=",
"lastModified": 1764034279,
"narHash": "sha256-hZH6EHQYFifVg0bmSBYT8Art5BWhXBXE307uPLnexY0=",
"owner": "nix-community",
"repo": "home-manager",
"rev": "91287a0e9d42570754487b7e38c6697e15a9aab2",
"rev": "381f4f8a3a5f773cb80d2b7eb8f8d733b8861434",
"type": "github"
},
"original": {
@@ -20,6 +94,32 @@
"type": "github"
}
},
"lanzaboote": {
"inputs": {
"crane": "crane",
"flake-compat": "flake-compat",
"flake-parts": "flake-parts",
"nixpkgs": [
"nixpkgs"
],
"pre-commit-hooks-nix": "pre-commit-hooks-nix",
"rust-overlay": "rust-overlay"
},
"locked": {
"lastModified": 1762205063,
"narHash": "sha256-If6vQ+KvtKs3ARBO9G3l+4wFSCYtRBrwX1z+I+B61wQ=",
"owner": "nix-community",
"repo": "lanzaboote",
"rev": "88b8a563ff5704f4e8d8e5118fb911fa2110ca05",
"type": "github"
},
"original": {
"owner": "nix-community",
"ref": "v0.4.3",
"repo": "lanzaboote",
"type": "github"
}
},
"nixlib": {
"locked": {
"lastModified": 1736643958,
@@ -43,11 +143,11 @@
]
},
"locked": {
"lastModified": 1747663185,
"narHash": "sha256-Obh50J+O9jhUM/FgXtI3he/QRNiV9+J53+l+RlKSaAk=",
"lastModified": 1751903740,
"narHash": "sha256-PeSkNMvkpEvts+9DjFiop1iT2JuBpyknmBUs0Un0a4I=",
"owner": "nix-community",
"repo": "nixos-generators",
"rev": "ee07ba0d36c38e9915c55d2ac5a8fb0f05f2afcc",
"rev": "032decf9db65efed428afd2fa39d80f7089085eb",
"type": "github"
},
"original": {
@@ -58,11 +158,11 @@
},
"nixpkgs": {
"locked": {
"lastModified": 1748929857,
"narHash": "sha256-lcZQ8RhsmhsK8u7LIFsJhsLh/pzR9yZ8yqpTzyGdj+Q=",
"lastModified": 1763835633,
"narHash": "sha256-HzxeGVID5MChuCPESuC0dlQL1/scDKu+MmzoVBJxulM=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "c2a03962b8e24e669fb37b7df10e7c79531ff1a4",
"rev": "050e09e091117c3d7328c7b2b7b577492c43c134",
"type": "github"
},
"original": {
@@ -82,11 +182,11 @@
]
},
"locked": {
"lastModified": 1748196248,
"narHash": "sha256-1iHjsH6/5UOerJEoZKE+Gx1BgAoge/YcnUsOA4wQ/BU=",
"lastModified": 1763909441,
"narHash": "sha256-56LwV51TX/FhgX+5LCG6akQ5KrOWuKgcJa+eUsRMxsc=",
"owner": "nix-community",
"repo": "plasma-manager",
"rev": "b7697abe89967839b273a863a3805345ea54ab56",
"rev": "b24ed4b272256dfc1cc2291f89a9821d5f9e14b4",
"type": "github"
},
"original": {
@@ -95,15 +195,63 @@
"type": "github"
}
},
"pre-commit-hooks-nix": {
"inputs": {
"flake-compat": [
"lanzaboote",
"flake-compat"
],
"gitignore": "gitignore",
"nixpkgs": [
"lanzaboote",
"nixpkgs"
]
},
"locked": {
"lastModified": 1750779888,
"narHash": "sha256-wibppH3g/E2lxU43ZQHC5yA/7kIKLGxVEnsnVK1BtRg=",
"owner": "cachix",
"repo": "pre-commit-hooks.nix",
"rev": "16ec914f6fb6f599ce988427d9d94efddf25fe6d",
"type": "github"
},
"original": {
"owner": "cachix",
"repo": "pre-commit-hooks.nix",
"type": "github"
}
},
"root": {
"inputs": {
"home-manager": "home-manager",
"lanzaboote": "lanzaboote",
"nixos-generators": "nixos-generators",
"nixpkgs": "nixpkgs",
"plasma-manager": "plasma-manager",
"secrix": "secrix"
}
},
"rust-overlay": {
"inputs": {
"nixpkgs": [
"lanzaboote",
"nixpkgs"
]
},
"locked": {
"lastModified": 1761791894,
"narHash": "sha256-myRIDh+PxaREz+z9LzbqBJF+SnTFJwkthKDX9zMyddY=",
"owner": "oxalica",
"repo": "rust-overlay",
"rev": "59c45eb69d9222a4362673141e00ff77842cd219",
"type": "github"
},
"original": {
"owner": "oxalica",
"repo": "rust-overlay",
"type": "github"
}
},
"secrix": {
"inputs": {
"nixpkgs": [
@@ -111,11 +259,11 @@
]
},
"locked": {
"lastModified": 1746643487,
"narHash": "sha256-dcB/DArJObCvqE/ZEdQSDW2BZMeDyF83Se5KPfJvz60=",
"lastModified": 1763929380,
"narHash": "sha256-Yc7gZME/lcHoJH6bMPCG7CyjKWhOLJPqLI8MXtyKPHo=",
"owner": "Platonic-Systems",
"repo": "secrix",
"rev": "4c64203fa5b377953b1fb6d5388187df8b60c6d5",
"rev": "c6e3ca7af47c329dcf442a3d017ae171eee5612f",
"type": "github"
},
"original": {

View File

@@ -22,16 +22,20 @@
url = "github:Platonic-Systems/secrix";
inputs.nixpkgs.follows = "nixpkgs";
};
lanzaboote = {
url = "github:nix-community/lanzaboote/v0.4.3";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, home-manager, plasma-manager, nixos-generators, secrix }:
outputs = { self, nixpkgs, home-manager, plasma-manager, nixos-generators, secrix, lanzaboote }:
let
hmModule = file: {
imports = [ home-manager.nixosModules.home-manager ];
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.sharedModules = [ plasma-manager.homeManagerModules.plasma-manager ];
home-manager.sharedModules = [ plasma-manager.homeModules.plasma-manager ];
home-manager.users.cazzzer = import file;
# Optionally, use home-manager.extraSpecialArgs to pass
@@ -43,6 +47,7 @@
modules = [
secrix.nixosModules.default
./modules
./modules/router
./hosts/common.nix
hostFile
./users/cazzzer
@@ -69,6 +74,7 @@
Yura-TPX13 = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
lanzaboote.nixosModules.lanzaboote
./modules
./hosts/common.nix
./hosts/common-desktop.nix

View File

@@ -8,21 +8,23 @@ in
programs.git = {
enable = true;
userName = name;
userEmail = email;
signing = {
key = signingKey;
signByDefault = true;
format = "ssh";
};
aliases = {
co = "checkout";
s = "switch";
};
settings = {
user = {
name = name;
email = email;
};
alias = {
co = "checkout";
s = "switch";
};
extraConfig = {
url = {
"https://gitea.cazzzer.com/" = {
insteadOf = "caztea:";

View File

@@ -55,6 +55,8 @@
activities-icons."809dc779-bf5b-49e6-8e3f-cbe283cb05b6" = "keyboard";
activities-icons."b34a506d-ac4f-4797-8c08-6ef45bc49341" = "preferences-desktop-gaming";
};
baloofilerc.General."exclude folders".persistent = true;
systemsettingsrc.systemsettings_sidebar_mode.HighlightNonDefaultSettings=true;
};
};

View File

@@ -18,6 +18,11 @@
fsType = "zfs";
};
fileSystems."/nix" =
{ device = "zroot/data/nix";
fsType = "zfs";
};
fileSystems."/boot" =
{ device = "/dev/disk/by-uuid/970C-6A15";
fsType = "vfat";

View File

@@ -11,10 +11,17 @@
"sysrq_always_enabled=1"
];
boot.lanzaboote = {
enable = true;
pkiBundle = "/var/lib/sbctl";
};
networking.hostName = "Yura-TPX13"; # Define your hostname.
networking.hostId = "8425e349"; # Required for ZFS.
services.fprintd.enable = true;
security.pam.services.login.fprintAuth = false;
# Install firefox.
programs.firefox.enable = true;

View File

@@ -7,14 +7,11 @@
"sysrq_always_enabled=1"
];
boot.kernelPackages = pkgs.linuxKernel.packages.linux_6_14;
boot.kernelPackages = pkgs.linuxKernel.packages.linux_6_17;
boot.loader = {
efi.canTouchEfiVariables = true;
timeout = 3;
systemd-boot = {
enable = true;
configurationLimit = 5;
};
systemd-boot.enable = !config.boot.lanzaboote.enable;
};
# https://nixos.wiki/wiki/Accelerated_Video_Playback
@@ -24,6 +21,9 @@
# Enable networking
networking.networkmanager.enable = true;
networking.networkmanager.plugins = [
pkgs.networkmanager-openvpn
];
# Enable the X11 windowing system.
# You can disable this if you're only using the Wayland session.
@@ -58,7 +58,7 @@
programs.git.enable = true;
programs.git.lfs.enable = true;
# https://nixos.wiki/wiki/Git
programs.git.package = pkgs.git.override { withLibsecret = true; };
programs.git.package = pkgs.git.override { withLibsecret = true; doInstallCheck = false; };
programs.lazygit.enable = true;
programs.neovim.enable = true;
programs.wireshark.enable = true;
@@ -79,7 +79,7 @@
fantasque-sans-mono
nerd-fonts.fantasque-sans-mono
noto-fonts
noto-fonts-emoji
noto-fonts-color-emoji
noto-fonts-cjk-sans
noto-fonts-cjk-serif
jetbrains-mono
@@ -107,6 +107,7 @@
jq
ldns
mediainfo
powertop
rbw
restic
resticprofile
@@ -120,14 +121,20 @@
bitwarden-desktop
darkman
host-spawn # for flatpaks
jellyfin-mpv-shim
kdePackages.filelight
kdePackages.flatpak-kcm
kdePackages.kate
kdePackages.yakuake
mpv
(mpv.override {
scripts = with pkgs.mpvScripts; [
mpris
videoclip
];
})
nextcloud-client
lxqt.pavucontrol-qt
pinentry
pinentry-all
tela-circle-icon-theme
virt-viewer
waypipe
@@ -141,7 +148,12 @@
android-studio
rustup
zed-editor
package-version-server # for zed
] ++ [
# C
gcc
valgrind
# Python
python3
poetry
@@ -163,5 +175,11 @@
# Gleam
gleam
beamMinimal26Packages.erlang
# Racket
racket
# Ruby
ruby
];
}

View File

@@ -1,6 +1,5 @@
{
imports = [
../../modules/router
../hw-vm.nix
];

View File

@@ -1,6 +1,5 @@
{
imports = [
../../modules/router
../hw-vm.nix
];

View File

@@ -1,6 +1,5 @@
{
imports = [
../../modules/router
./hardware-configuration.nix
./private.nix
];

View File

@@ -45,7 +45,7 @@ in {
enable = true;
type = "fcitx5";
fcitx5.waylandFrontend = true;
fcitx5.plasma6Support = true;
# fcitx5.plasma6Support = true;
fcitx5.addons = [ pkgs.fcitx5-mozc ];
};
};

View File

@@ -76,6 +76,7 @@ in
starship
tealdeer
transcrypt
wakeonlan
waypipe
whois
wireguard-tools

View File

@@ -28,6 +28,8 @@ let
"|woodpecker."
"||pgrok."
"|sync."
"|minecruft."
"|n8n."
];
in
{
@@ -80,11 +82,14 @@ in
"|etappi.${sysdomain}^$dnsrewrite=${ifs.lan.p4}.12"
"|etappi.${sysdomain}^$dnsrewrite=${ifs.lan.ulaPrefix}::12:1"
"|hass.${domain}^$dnsrewrite=${ifs.lan.ulaAddr}"
# Lab DNS rewrites
"||lab.${domain}^$dnsrewrite=etappi.${sysdomain}"
# Allowed exceptions
"@@||googleads.g.doubleclick.net"
"@@||stats.grafana.org"
]
# Alpina DNS rewrites
++ map (host: "${host}${domain}^$dnsrewrite=debbi.${sysdomain}") alpinaDomains;

View File

@@ -56,6 +56,12 @@ in
udp . 45608 : ${vars.extra.opnsense.addr4} . 45608,
udp . 35848 : ${vars.extra.opnsense.addr4} . 35848,
udp . 48425 : ${vars.extra.opnsense.addr4} . 48425,
# Amnezia VPN server
udp . 37138 : ${vars.extra.amnezia.addr4} . 37138,
# Minecruft server
tcp . 25565 : ${vars.extra.minecruft.addr4} . 25565,
udp . 25565 : ${vars.extra.minecruft.addr4} . 25565,
udp . 24454 : ${vars.extra.minecruft.addr4} . 24454,
}
}

View File

@@ -58,27 +58,36 @@ in
enable = true;
package = pkgs.caddy.withPlugins {
plugins = [ "github.com/caddy-dns/cloudflare@v0.2.1" ];
hash = "sha256-Gsuo+ripJSgKSYOM9/yl6Kt/6BFCA6BuTDvPdteinAI=";
hash = "sha256-aRMg7R0dBAy+LJeGCMPg6HKppM6NPX2NPwtc0CeSQLg=";
};
virtualHosts."grouter.${domain}".extraConfig = ''
virtualHosts."*.${domain}".extraConfig = ''
encode
tls {
dns cloudflare {env.CF_API_KEY}
resolvers 1.1.1.1
}
@grafana path /grafana /grafana/*
handle @grafana {
reverse_proxy localhost:${toString config.services.grafana.settings.server.http_port}
}
redir /adghome /adghome/
handle_path /adghome/* {
reverse_proxy localhost:${toString config.services.adguardhome.port}
basic_auth {
Bob $2a$14$HsWmmzQTN68K3vwiRAfiUuqIjKoXEXaj9TOLUtG2mO1vFpdovmyBy
@grouter host grouter.${domain}
handle @grouter {
@grafana path /grafana /grafana/*
handle @grafana {
reverse_proxy localhost:${toString config.services.grafana.settings.server.http_port}
}
redir /adghome /adghome/
handle_path /adghome/* {
reverse_proxy localhost:${toString config.services.adguardhome.port}
basic_auth {
Bob $2a$14$HsWmmzQTN68K3vwiRAfiUuqIjKoXEXaj9TOLUtG2mO1vFpdovmyBy
}
}
handle /* {
reverse_proxy localhost:${toString config.services.glance.settings.server.port}
}
}
handle /* {
reverse_proxy localhost:${toString config.services.glance.settings.server.port}
@hass host hass.${domain}
handle @hass {
reverse_proxy homeassistant.4.lab.l.cazzzer.com:8123
}
'';
};

View File

@@ -135,5 +135,7 @@ rec {
}
];
};
amnezia.addr4 = "${ifs.lan10.p4}.31";
minecruft.addr4 = "${ifs.lan.p4}.11";
};
}

View File

@@ -28,7 +28,7 @@ in {
inherit
(pkgs)
noto-fonts
noto-fonts-emoji
noto-fonts-color-emoji
noto-fonts-cjk-sans
noto-fonts-cjk-serif
;

View File

@@ -5,7 +5,7 @@
isNormalUser = true;
description = "Yura";
group = "cazzzer";
extraGroups = [ "wheel" ]
extraGroups = [ "wheel" "dialout" ]
++ lib.optionals config.networking.networkmanager.enable [ "networkmanager" ]
++ lib.optionals config.virtualisation.docker.enable [ "docker" ]
++ lib.optionals config.programs.wireshark.enable [ "wireshark" ]