2023-06-07 20:40:27 +02:00
|
|
|
args@{ pkgs, config, lib, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
secret = import ../../secret/hosts/argon.nix;
|
|
|
|
ssh-keys = import ../shared/ssh-keys.nix;
|
|
|
|
in
|
|
|
|
{
|
|
|
|
imports = [
|
|
|
|
../../hardware/hosts/argon.nix
|
|
|
|
../../agenix/hosts/argon/config.nix
|
|
|
|
../shared/show-update-changelog.nix
|
|
|
|
../nixos/raspberry.nix
|
|
|
|
../nixos/ssh.nix
|
2024-01-21 22:55:44 +01:00
|
|
|
../nixos/eternal-terminal.nix
|
2023-06-07 20:40:27 +02:00
|
|
|
|
|
|
|
../nixos/git.nix
|
|
|
|
|
|
|
|
../nixos/acme-argon.nix
|
|
|
|
../nixos/nginx.nix
|
2023-09-04 12:45:06 +02:00
|
|
|
../nixos/nginx-argon.nix
|
2023-06-07 20:40:27 +02:00
|
|
|
|
|
|
|
../nixos/attic.nix
|
|
|
|
|
2024-01-29 10:25:53 +01:00
|
|
|
../nixos/chrony.nix
|
|
|
|
|
2024-07-27 23:49:54 +02:00
|
|
|
(import ../nixos/controld.nix (args // { podmanDNS = false; }))
|
|
|
|
|
2024-02-15 18:21:21 +01:00
|
|
|
(import ../nixos/forgejo-runner.nix (args // { inherit secret; name = "argon"; tag = "ubuntu-latest-arm64"; nixTag = "arm64"; }))
|
2023-09-14 19:39:10 +02:00
|
|
|
|
2024-08-09 20:24:24 +02:00
|
|
|
../nixos/mosquitto.nix
|
|
|
|
|
2024-07-18 23:07:07 +02:00
|
|
|
../nixos/tailscale-router.nix
|
2024-05-25 15:47:17 +02:00
|
|
|
../nixos/tailscale-nodns.nix
|
2023-06-07 20:40:27 +02:00
|
|
|
|
2023-08-21 01:08:23 +02:00
|
|
|
../nixos/unbound.nix
|
|
|
|
|
2023-06-17 17:40:05 +02:00
|
|
|
../nixos/uptime-kuma.nix
|
|
|
|
|
2023-06-07 20:40:27 +02:00
|
|
|
../nixos/weewx-proxy.nix
|
2024-09-17 09:02:38 +02:00
|
|
|
../nixos/temper.nix
|
2023-06-10 20:48:07 +02:00
|
|
|
|
|
|
|
../nixos/container.nix
|
2023-06-07 20:40:27 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
system.stateVersion = "22.11";
|
|
|
|
|
|
|
|
nix = {
|
|
|
|
settings = {
|
2024-07-05 22:33:27 +02:00
|
|
|
experimental-features = [ "nix-command" "flakes" ];
|
2023-06-07 20:40:27 +02:00
|
|
|
|
2024-07-05 22:33:27 +02:00
|
|
|
log-lines = 25;
|
|
|
|
auto-optimise-store = true;
|
|
|
|
keep-derivations = true;
|
|
|
|
keep-outputs = true;
|
|
|
|
|
|
|
|
extra-substituters = [
|
|
|
|
"https://attic.cache.daniel.sx/nifoc-systems?priority=30"
|
|
|
|
"https://attic.cache.daniel.sx/nifoc-ci?priority=35"
|
|
|
|
"https://nix-community.cachix.org?priority=50"
|
|
|
|
"https://cache.garnix.io?priority=60"
|
2024-07-24 09:54:07 +02:00
|
|
|
"https://cache.lix.systems?priority=70"
|
2023-06-07 20:40:27 +02:00
|
|
|
];
|
|
|
|
|
2024-07-05 22:33:27 +02:00
|
|
|
extra-trusted-public-keys = [
|
2023-06-07 20:40:27 +02:00
|
|
|
"nifoc-systems:eDDqVP5BFR6/1KvXbF9oUL8JahDdmbrsYtxlQ57LOTU="
|
2023-09-14 19:39:10 +02:00
|
|
|
"nifoc-ci:JpD9zqVQi8JuS7B8htPDOQZh08rhInMnGFS9RVhiuwk="
|
2023-06-07 20:40:27 +02:00
|
|
|
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
|
2024-07-03 14:40:31 +02:00
|
|
|
"cache.garnix.io:CTFPyKSLcx5RMJKfLo5EEPUObbA78b0YQ2DTCJXqr9g="
|
2024-07-24 09:54:07 +02:00
|
|
|
"cache.lix.systems:aBnZUw8zA7H35Cz2RyKFVs3H4PlGTLawyY5KRbvJR8o="
|
2023-06-07 20:40:27 +02:00
|
|
|
];
|
2023-10-25 23:31:32 +02:00
|
|
|
|
|
|
|
trusted-users = [
|
|
|
|
"root"
|
|
|
|
"nix-remote-builder"
|
|
|
|
];
|
2024-07-05 22:33:27 +02:00
|
|
|
|
|
|
|
connect-timeout = 5;
|
2023-06-07 20:40:27 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
gc = {
|
|
|
|
automatic = true;
|
|
|
|
dates = "weekly";
|
|
|
|
options = "--delete-older-than 14d";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.etc."nix/netrc".source = ../../secret/shared/nix-netrc;
|
|
|
|
|
|
|
|
boot = {
|
|
|
|
loader = {
|
|
|
|
grub.enable = false;
|
|
|
|
generic-extlinux-compatible.enable = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
tmp.cleanOnBoot = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
networking = {
|
|
|
|
hostName = "argon";
|
|
|
|
useNetworkd = true;
|
|
|
|
};
|
|
|
|
|
2023-06-10 20:48:07 +02:00
|
|
|
environment.etc."resolv.conf".text = lib.mkForce ''
|
|
|
|
nameserver 127.0.0.1
|
|
|
|
nameserver 10.0.0.110
|
|
|
|
options edns0 trust-ad
|
|
|
|
search .
|
|
|
|
'';
|
|
|
|
|
|
|
|
services.resolved.extraConfig = ''
|
|
|
|
DNSStubListener=no
|
|
|
|
'';
|
|
|
|
|
2023-06-07 20:40:27 +02:00
|
|
|
systemd.network = {
|
|
|
|
enable = true;
|
|
|
|
|
|
|
|
netdevs = {
|
|
|
|
"20-vlan10" = {
|
|
|
|
netdevConfig = {
|
|
|
|
Kind = "vlan";
|
|
|
|
Name = "vlan51";
|
|
|
|
};
|
|
|
|
vlanConfig.Id = 51;
|
|
|
|
};
|
|
|
|
|
|
|
|
"20-vlan20" = {
|
|
|
|
netdevConfig = {
|
|
|
|
Kind = "vlan";
|
|
|
|
Name = "vlan777";
|
|
|
|
};
|
|
|
|
vlanConfig.Id = 777;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
networks = {
|
|
|
|
"10-lan" = {
|
|
|
|
matchConfig.Name = "end0";
|
|
|
|
vlan = [ "vlan51" "vlan777" ];
|
|
|
|
networkConfig = {
|
|
|
|
DHCP = "yes";
|
|
|
|
IPv6AcceptRA = true;
|
|
|
|
IPv6PrivacyExtensions = true;
|
|
|
|
};
|
|
|
|
linkConfig.RequiredForOnline = "routable";
|
|
|
|
|
|
|
|
ntp = [
|
|
|
|
"ptbtime1.ptb.de"
|
|
|
|
"ptbtime2.ptb.de"
|
|
|
|
"ptbtime3.ptb.de"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
"20-iot" = {
|
|
|
|
matchConfig.Name = "vlan51";
|
|
|
|
networkConfig = {
|
|
|
|
DHCP = "no";
|
|
|
|
IPv6AcceptRA = false;
|
|
|
|
};
|
|
|
|
address = [ "10.0.51.5/24" ];
|
|
|
|
linkConfig.RequiredForOnline = "routable";
|
|
|
|
};
|
|
|
|
|
|
|
|
"30-modem" = {
|
|
|
|
matchConfig.Name = "vlan777";
|
|
|
|
networkConfig = {
|
|
|
|
DHCP = "no";
|
|
|
|
IPv6AcceptRA = false;
|
|
|
|
};
|
|
|
|
address = [ "192.168.1.5/24" ];
|
|
|
|
linkConfig.RequiredForOnline = "routable";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
wait-online.extraArgs = [
|
|
|
|
"--interface=end0"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
services.journald.extraConfig = ''
|
|
|
|
SystemMaxUse=512M
|
2023-10-11 14:41:14 +02:00
|
|
|
MaxRetentionSec=30day
|
2023-06-07 20:40:27 +02:00
|
|
|
'';
|
|
|
|
|
2023-11-12 22:40:40 +01:00
|
|
|
security.sudo.enable = true;
|
|
|
|
|
2023-06-07 20:40:27 +02:00
|
|
|
documentation = {
|
|
|
|
nixos.enable = false;
|
|
|
|
doc.enable = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
services.hardware.argonone.enable = true;
|
2023-10-25 23:31:32 +02:00
|
|
|
|
2024-09-06 10:54:21 +02:00
|
|
|
power.ups = {
|
|
|
|
enable = true;
|
|
|
|
mode = "standalone";
|
|
|
|
openFirewall = true;
|
|
|
|
|
|
|
|
ups.primary = {
|
|
|
|
description = "APC Back-UPS BX - BX950U-GR";
|
|
|
|
driver = "usbhid-ups";
|
|
|
|
port = "auto";
|
|
|
|
};
|
|
|
|
|
|
|
|
users.upsmon = {
|
|
|
|
passwordFile = config.age.secrets.ups-primary-password.path;
|
|
|
|
upsmon = "primary";
|
|
|
|
};
|
|
|
|
|
|
|
|
upsd.listen = [
|
|
|
|
{ address = "127.0.0.1"; }
|
|
|
|
{ address = "10.0.0.5"; }
|
|
|
|
];
|
|
|
|
|
|
|
|
upsmon.monitor.primary.user = "upsmon";
|
|
|
|
};
|
|
|
|
|
2023-10-25 23:31:32 +02:00
|
|
|
programs = {
|
|
|
|
zsh.enable = true;
|
|
|
|
htop.enable = true;
|
|
|
|
};
|
2023-06-07 20:40:27 +02:00
|
|
|
|
|
|
|
users.users = {
|
|
|
|
root = {
|
|
|
|
openssh.authorizedKeys.keys = [ ssh-keys.LAN ];
|
|
|
|
};
|
|
|
|
|
|
|
|
daniel = {
|
2023-09-16 13:08:38 +02:00
|
|
|
hashedPasswordFile = config.age.secrets.user-daniel-password.path;
|
2023-06-07 20:40:27 +02:00
|
|
|
isNormalUser = true;
|
|
|
|
home = "/home/daniel";
|
|
|
|
description = "Daniel";
|
|
|
|
extraGroups = [ "wheel" ];
|
2024-12-24 01:41:50 +01:00
|
|
|
shell = pkgs.zsh;
|
2024-01-21 22:55:44 +01:00
|
|
|
openssh.authorizedKeys.keys = [ ssh-keys.LAN ssh-keys.DanielsPhone ];
|
2023-06-07 20:40:27 +02:00
|
|
|
};
|
2023-10-25 23:31:32 +02:00
|
|
|
|
|
|
|
nix-remote-builder = {
|
|
|
|
isNormalUser = true;
|
|
|
|
home = "/home/nix-remote-builder";
|
|
|
|
description = "Nix Remote Builder";
|
|
|
|
shell = pkgs.zsh;
|
|
|
|
openssh.authorizedKeys.keys = [ ssh-keys.NixRemoteBuilder ];
|
|
|
|
};
|
2023-06-07 20:40:27 +02:00
|
|
|
};
|
|
|
|
}
|