Compare commits
3 commits
bdf7180a13
...
1f8d44514d
Author | SHA1 | Date | |
---|---|---|---|
Patrick | 1f8d44514d | ||
Patrick | 606829afb0 | ||
Patrick | 29b100e13e |
|
@ -5,7 +5,9 @@
|
|||
...
|
||||
}:
|
||||
let
|
||||
onlyHost = lib.mkIf (!config.boot.isContainer);
|
||||
onlyHost = lib.mkIf (
|
||||
!config.boot.isContainer && !(config ? microvm.guest && config.microvm.guest.enable)
|
||||
);
|
||||
prune =
|
||||
folder:
|
||||
pkgs.writers.writePython3Bin "impermanence-prune" { } ''
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
{ config, lib, ... }:
|
||||
{
|
||||
age.generators.argon2id =
|
||||
{
|
||||
|
@ -17,5 +18,9 @@
|
|||
| ${pkgs.libargon2}/bin/argon2 "$(${pkgs.openssl}/bin/openssl rand -base64 16)" -id -e \
|
||||
|| die "Failure while generating argon2id hash"
|
||||
'';
|
||||
|
||||
secrets.secretFiles =
|
||||
let
|
||||
local = config.node.secretsDir + "/secrets.nix.age";
|
||||
in
|
||||
lib.optionalAttrs (config.node.name != null && lib.pathExists local) { inherit local; };
|
||||
}
|
||||
|
|
|
@ -72,10 +72,4 @@
|
|||
environment.ldso32 = null;
|
||||
|
||||
powerManagement.cpuFreqGovernor = lib.mkDefault "powersave";
|
||||
|
||||
secrets.secretFiles =
|
||||
let
|
||||
local = config.node.secretsDir + "/secrets.nix.age";
|
||||
in
|
||||
lib.optionalAttrs (config.node.name != null && lib.pathExists local) { inherit local; };
|
||||
}
|
||||
|
|
|
@ -36,9 +36,9 @@
|
|||
];
|
||||
};
|
||||
user_rules = [
|
||||
"||homematic.${globals.domains.web}^$dnsrewrite=${lib.net.cidr.host 30 globals.net.vlans.home.cidrv4}"
|
||||
"||testberry.${globals.domains.web}^$dnsrewrite=${lib.net.cidr.host 31 globals.net.vlans.home.cidrv4}"
|
||||
"||${globals.services.samba.domain}^$dnsrewrite=${lib.net.cidr.host globals.services.samba.ip globals.net.vlans.home.cidrv4}"
|
||||
"||homematic.internal^$dnsrewrite=${lib.net.cidr.host 30 globals.net.vlans.devices.cidrv4}"
|
||||
"||testberry.internal^$dnsrewrite=${lib.net.cidr.host 31 globals.net.vlans.devices.cidrv4}"
|
||||
"||smb.internal^$dnsrewrite=${lib.net.cidr.host globals.services.samba.ip globals.net.vlans.home.cidrv4}"
|
||||
"||${globals.domains.web}^$dnsrewrite=${lib.net.cidr.host 1 globals.net.vlans.services.cidrv4}"
|
||||
"||fritz.box^$dnsrewrite=${lib.net.cidr.host 1 "10.99.2.0/24"}"
|
||||
];
|
||||
|
|
|
@ -119,7 +119,7 @@ in
|
|||
# clients hardcode the host and share names.
|
||||
"disable netbios" = "yes";
|
||||
# Allow access to local network
|
||||
"hosts allow" = "10. localhost";
|
||||
"hosts allow" = "10.99.10. localhost";
|
||||
|
||||
"guest account" = "nobody";
|
||||
"map to guest" = "bad user";
|
||||
|
@ -169,11 +169,17 @@ in
|
|||
hasBunker = true;
|
||||
hasPaperless = true;
|
||||
} { })
|
||||
(mkShare {
|
||||
name = "printer";
|
||||
user = "printer";
|
||||
group = "printer";
|
||||
} { })
|
||||
(mkShare
|
||||
{
|
||||
name = "printer";
|
||||
user = "printer";
|
||||
group = "printer";
|
||||
}
|
||||
{
|
||||
# Also allow printer access
|
||||
"hosts allow" = "10.99.10. ${lib.net.cidr.host 32 globals.net.vlans.home.cidrv4} localhost";
|
||||
}
|
||||
)
|
||||
(mkShare {
|
||||
name = "family-data";
|
||||
user = "family";
|
||||
|
|
|
@ -83,12 +83,25 @@ mkMerge [
|
|||
protocol = "udp";
|
||||
})
|
||||
{
|
||||
networking.nftables.chains.prerouting.mdns-forward = {
|
||||
after = [ "hook" ];
|
||||
rules = [
|
||||
# "iifname lan-home ip daddr 224.0.0.251 ip saddr set ${net.cidr.host 1 globals.net.vlans.services.cidrv4} dup to 224.0.0.251 device lan-services notrack"
|
||||
# "iifname lan-services ip daddr 224.0.0.251 ip saddr set ${net.cidr.host 1 globals.net.vlans.home.cidrv4} dup to 224.0.0.251 device lan-home notrack"
|
||||
];
|
||||
};
|
||||
networking.nftables.ruleset = ''
|
||||
table ip mdns {
|
||||
chain prerouting {
|
||||
type filter hook prerouting priority mangle; policy accept;
|
||||
|
||||
iifname {lan-home, lan-services} ip daddr 224.0.0.251 meta mark 0xa5f3 jump mdns-saddr
|
||||
iifname {lan-home, lan-services} ip daddr 224.0.0.251 meta mark != 0xa5f3 jump mdns
|
||||
}
|
||||
chain mdns {
|
||||
meta mark set 0xa5f3
|
||||
iifname lan-services dup to 224.0.0.251 device lan-home
|
||||
iifname lan-home dup to 224.0.0.251 device lan-services
|
||||
}
|
||||
chain mdns-saddr {
|
||||
# repeat mDNS from IoT to main
|
||||
iifname lan-services ip saddr set 10.99.20.1
|
||||
iifname lan-home ip saddr set 10.99.10.1
|
||||
}
|
||||
}
|
||||
'';
|
||||
}
|
||||
]
|
||||
|
|
|
@ -11,13 +11,6 @@ let
|
|||
flip
|
||||
mapAttrsToList
|
||||
;
|
||||
vlans = {
|
||||
home = 10;
|
||||
services = 20;
|
||||
devices = 30;
|
||||
iot = 40;
|
||||
guests = 50;
|
||||
};
|
||||
in
|
||||
{
|
||||
environment.persistence."/persist".directories = [
|
||||
|
@ -38,10 +31,12 @@ in
|
|||
valid-lifetime = 86400;
|
||||
renew-timer = 3600;
|
||||
interfaces-config = {
|
||||
interfaces = flip mapAttrsToList vlans (x: _: "lan-${x}");
|
||||
interfaces = flip mapAttrsToList globals.net.vlans (x: _: "lan-${x}");
|
||||
};
|
||||
subnet4 = flip mapAttrsToList vlans (
|
||||
name: id: rec {
|
||||
subnet4 = flip mapAttrsToList globals.net.vlans (
|
||||
name:
|
||||
{ id, cidrv4, ... }:
|
||||
rec {
|
||||
inherit id;
|
||||
interface = "lan-${name}";
|
||||
subnet = "10.99.${toString id}.0/24";
|
||||
|
@ -71,13 +66,18 @@ in
|
|||
hw-address = "d8:3a:dd:dc:b6:6a";
|
||||
ip-address = net.cidr.host 31 subnet;
|
||||
}
|
||||
{
|
||||
# drucker
|
||||
hw-address = "48:9e:bd:5c:31:ac";
|
||||
ip-address = net.cidr.host 32 subnet;
|
||||
}
|
||||
];
|
||||
}
|
||||
);
|
||||
};
|
||||
};
|
||||
|
||||
systemd.services.kea-dhcp4-server.after = flip mapAttrsToList vlans (
|
||||
systemd.services.kea-dhcp4-server.after = flip mapAttrsToList globals.net.vlans (
|
||||
name: _: "sys-subsystem-net-devices-${utils.escapeSystemdPath "lan-${name}"}.device"
|
||||
);
|
||||
}
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
config,
|
||||
lib,
|
||||
globals,
|
||||
utils,
|
||||
...
|
||||
}:
|
||||
let
|
||||
|
@ -23,9 +24,15 @@ in
|
|||
{
|
||||
fritz.interfaces = [ "vlan-fritz" ];
|
||||
wg-services.interfaces = [ "services" ];
|
||||
printer.ipv4Addresses = [
|
||||
(lib.net.cidr.host 32 globals.net.vlans.device.cidrv4)
|
||||
];
|
||||
adguard.ipv4Addresses = [
|
||||
(lib.net.cidr.host globals.services.adguardhome.ip globals.net.vlans.services.cidrv4)
|
||||
];
|
||||
samba.ipv4Addresses = [
|
||||
(lib.net.cidr.host globals.services.samba.ip globals.net.vlans.home.cidrv4)
|
||||
];
|
||||
}
|
||||
(genAttrs (attrNames globals.net.vlans) (name: {
|
||||
interfaces = [ "lan-${name}" ];
|
||||
|
@ -136,10 +143,20 @@ in
|
|||
snippets.nnf-ssh.enable = lib.mkForce false;
|
||||
rules = {
|
||||
mdns = {
|
||||
from = [ "home" ];
|
||||
from = [
|
||||
"home"
|
||||
"services"
|
||||
];
|
||||
to = [ "local" ];
|
||||
allowedUDPPorts = [ 5353 ];
|
||||
};
|
||||
printer-smb = {
|
||||
from = [
|
||||
"printer"
|
||||
];
|
||||
to = [ "smb" ];
|
||||
allowedUDPPorts = [ 445 ];
|
||||
};
|
||||
ssh = {
|
||||
from = [
|
||||
"fritz"
|
||||
|
@ -153,7 +170,9 @@ in
|
|||
"home"
|
||||
];
|
||||
to = [
|
||||
"iot"
|
||||
"services"
|
||||
"devices"
|
||||
"fritz"
|
||||
];
|
||||
late = true;
|
||||
|
@ -261,4 +280,7 @@ in
|
|||
};
|
||||
};
|
||||
};
|
||||
systemd.services.nftables.after = flip mapAttrsToList globals.net.vlans (
|
||||
name: _: "sys-subsystem-net-devices-${utils.escapeSystemdPath "lan-${name}"}.device"
|
||||
);
|
||||
}
|
||||
|
|
1
hosts/nucnix/secrets/hostapd/host.pub
Normal file
1
hosts/nucnix/secrets/hostapd/host.pub
Normal file
|
@ -0,0 +1 @@
|
|||
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAOR54uUS7TdVFs8SmKEThJcwNqQhLhqIfkTneoPSNJe
|
17
hosts/nucnix/secrets/hostapd/secrets.nix.age
Normal file
17
hosts/nucnix/secrets/hostapd/secrets.nix.age
Normal file
|
@ -0,0 +1,17 @@
|
|||
age-encryption.org/v1
|
||||
-> X25519 q8aZVIpO27A7gSGGepzDYQINfV9BT5Vdlck4Ywl/tw4
|
||||
f7OZDaBI1nGbWVKz7c/fCTjl5avQMZwweKuGsMZaHmw
|
||||
-> piv-p256 ZFgiIw AzIXNOToQeNgxBaPr2Ay8PNbWci5KXsOO0hPzntcr9jh
|
||||
A45KdFFCcHss+yp9o1lMeyGAquweqAAYdN3rebTOV+k
|
||||
-> piv-p256 XTQkUA Ams4qG3cUEr5JuhwJVl0I9vNvUBSwmeGlO4y1RjW+HM0
|
||||
09tBHurIIUJrwXfJEDnTpZppseJSxF/Rrzp81tLiEaI
|
||||
-> piv-p256 ZFgiIw Ar7T0wlAqoYOPxtm8lZnWRCctOFQ3MpmPhZpzz4dm+0i
|
||||
8vfGeTyhxjU28KeCmOl59IOhxgSEK/invMRBj5y8wvE
|
||||
-> piv-p256 5vmPtQ Am6sq2Wde4bMWzMTw6+o+yhkM2ZSkpBbbLGVA3RIAylz
|
||||
6y8WNKVZiMOuyolKGJjGj+Fc9hqkHw362LtYaGhl274
|
||||
-> 5nt&Ew>-grease V;8yod
|
||||
bApmEO5jhTtDghPr4gisoTKEuhrFOdKxAuNH4iqUufY3dNfojeB/5IjctLLe5VG7
|
||||
vWl2CF8Tyw
|
||||
--- hpy8mTYDQSOQCLhIcQ+5mHcdqRQkvWOIDQHLltWTJD0
|
||||
…2¿äUðzT§_ÜË´‹^<5E>
|
||||
¾¦}’…XZg°›éV‚Ô§ñ%áé?Mèt]vøœ:Ý;ÆwÚ˜*…XOë÷Ë‚ÔU}þþd¤Ù<C2A4>ºxKîáA¨§%<25>†6
|
Binary file not shown.
|
@ -2,7 +2,7 @@
|
|||
{
|
||||
hm.home.smb =
|
||||
let
|
||||
address = "smb.${config.secrets.secrets.global.domains.web}";
|
||||
address = "smb.internal";
|
||||
credentials = config.age.secrets.smb-creds.path;
|
||||
in
|
||||
[
|
||||
|
|
Loading…
Reference in a new issue