mirror of
https://github.com/gensokyo-zone/infrastructure.git
synced 2026-02-09 12:29:19 -08:00
feat: internal bridge
This commit is contained in:
parent
5f36636902
commit
1d1dc64ef5
4 changed files with 78 additions and 0 deletions
48
nixos/reisen-ct/internal.nix
Normal file
48
nixos/reisen-ct/internal.nix
Normal file
|
|
@ -0,0 +1,48 @@
|
|||
{
|
||||
config,
|
||||
lib,
|
||||
...
|
||||
}: let
|
||||
inherit (lib.options) mkOption mkEnableOption;
|
||||
inherit (lib.modules) mkIf mkMerge mkDefault mkOptionDefault;
|
||||
inherit (lib.trivial) toHexString;
|
||||
cfg = config.access.internal;
|
||||
offset = 32;
|
||||
in {
|
||||
options.access = with lib.types; {
|
||||
internal = {
|
||||
enable = mkEnableOption "eth9";
|
||||
macAddress = mkOption {
|
||||
type = nullOr str;
|
||||
default = null;
|
||||
};
|
||||
vmid = mkOption {
|
||||
type = int;
|
||||
};
|
||||
address4 = mkOption {
|
||||
type = str;
|
||||
};
|
||||
address6 = mkOption {
|
||||
type = str;
|
||||
};
|
||||
};
|
||||
};
|
||||
config.access.internal = {
|
||||
address4 = mkOptionDefault "10.9.1.${toString (cfg.vmid - offset)}";
|
||||
address6 = mkOptionDefault "fd0c::${toHexString (cfg.vmid - offset)}";
|
||||
};
|
||||
config.systemd.network.networks.eth9 = mkIf cfg.enable {
|
||||
mdns.enable = false;
|
||||
name = mkDefault "eth9";
|
||||
matchConfig = {
|
||||
MACAddress = mkIf (cfg.macAddress != null) (mkOptionDefault cfg.macAddress);
|
||||
Type = mkOptionDefault "ether";
|
||||
};
|
||||
linkConfig.RequiredForOnline = mkOptionDefault false;
|
||||
address = mkMerge [
|
||||
["${cfg.address4}/24"]
|
||||
(mkIf config.networking.enableIPv6 [ "${cfg.address6}/64" ])
|
||||
];
|
||||
DHCP = "no";
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue