nixos/sfh: Working containers
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				CI / Check, build and cache Nix flake (push) Successful in 44m19s
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	CI / Check, build and cache Nix flake (push) Successful in 44m19s
				
			This commit is contained in:
		@@ -183,6 +183,10 @@
 | 
			
		||||
                index = 0;
 | 
			
		||||
                hostBDF = "44:00.3";
 | 
			
		||||
              };
 | 
			
		||||
              et100g0vf3 = {
 | 
			
		||||
                index = 1;
 | 
			
		||||
                hostBDF = "44:00.4";
 | 
			
		||||
              };
 | 
			
		||||
            };
 | 
			
		||||
          };
 | 
			
		||||
        };
 | 
			
		||||
 
 | 
			
		||||
@@ -24,6 +24,7 @@
 | 
			
		||||
          initrd = {
 | 
			
		||||
            availableKernelModules = [
 | 
			
		||||
              "virtio_pci" "ahci" "sr_mod" "virtio_blk"
 | 
			
		||||
              "8021q"
 | 
			
		||||
            ] ++ roceBootModules;
 | 
			
		||||
            kernelModules = [ "dm-snapshot" ];
 | 
			
		||||
            systemd = {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										5
									
								
								nixos/boxes/home/palace/vms/sfh/containers/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								nixos/boxes/home/palace/vms/sfh/containers/default.nix
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
			
		||||
{
 | 
			
		||||
  imports = [
 | 
			
		||||
    ./unifi.nix
 | 
			
		||||
  ];
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										54
									
								
								nixos/boxes/home/palace/vms/sfh/containers/unifi.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								nixos/boxes/home/palace/vms/sfh/containers/unifi.nix
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,54 @@
 | 
			
		||||
{ lib, ... }:
 | 
			
		||||
let
 | 
			
		||||
  inherit (lib.my) net;
 | 
			
		||||
  inherit (lib.my.c.home) domain prefixes vips hiMTU;
 | 
			
		||||
in
 | 
			
		||||
{
 | 
			
		||||
  nixos.systems.unifi = { config, ... }: {
 | 
			
		||||
    system = "x86_64-linux";
 | 
			
		||||
    nixpkgs = "mine";
 | 
			
		||||
    rendered = config.configuration.config.my.asContainer;
 | 
			
		||||
 | 
			
		||||
    assignments = {
 | 
			
		||||
      hi = {
 | 
			
		||||
        name = "unifi-ctr";
 | 
			
		||||
        inherit domain;
 | 
			
		||||
        mtu = hiMTU;
 | 
			
		||||
        ipv4 = {
 | 
			
		||||
          address = net.cidr.host 100 prefixes.hi.v4;
 | 
			
		||||
          mask = 22;
 | 
			
		||||
          gateway = vips.hi.v4;
 | 
			
		||||
        };
 | 
			
		||||
        ipv6 = {
 | 
			
		||||
          iid = "::5:1";
 | 
			
		||||
          address = net.cidr.host (65536*5+1) prefixes.hi.v6;
 | 
			
		||||
        };
 | 
			
		||||
      };
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    configuration = { lib, config, assignments, ... }:
 | 
			
		||||
    let
 | 
			
		||||
      inherit (lib) mkMerge mkIf mkForce;
 | 
			
		||||
      inherit (lib.my) networkdAssignment;
 | 
			
		||||
    in
 | 
			
		||||
    {
 | 
			
		||||
      config = {
 | 
			
		||||
        my = {
 | 
			
		||||
          deploy.enable = false;
 | 
			
		||||
          server.enable = true;
 | 
			
		||||
 | 
			
		||||
          secrets = {
 | 
			
		||||
            key = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKdgcziQki/RH7E+NH2bYnzSVKaJ27905Yo5TcOjSh/U";
 | 
			
		||||
            files = { };
 | 
			
		||||
          };
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        systemd = {
 | 
			
		||||
          network.networks."80-container-host0" = networkdAssignment "host0" assignments.hi;
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        services = { };
 | 
			
		||||
      };
 | 
			
		||||
    };
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
@@ -1,14 +1,16 @@
 | 
			
		||||
{ lib, ... }:
 | 
			
		||||
let
 | 
			
		||||
  inherit (lib.my) net;
 | 
			
		||||
  inherit (lib.my.c) pubDomain;
 | 
			
		||||
  inherit (lib.my.c.home) domain prefixes vips hiMTU roceBootModules;
 | 
			
		||||
in
 | 
			
		||||
{
 | 
			
		||||
  imports = [ ./containers ];
 | 
			
		||||
 | 
			
		||||
  config.nixos.systems.sfh = {
 | 
			
		||||
    system = "x86_64-linux";
 | 
			
		||||
    nixpkgs = "mine";
 | 
			
		||||
    home-manager = "mine";
 | 
			
		||||
 | 
			
		||||
    assignments = {
 | 
			
		||||
      hi = {
 | 
			
		||||
        inherit domain;
 | 
			
		||||
@@ -27,8 +29,9 @@ in
 | 
			
		||||
 | 
			
		||||
    configuration = { lib, modulesPath, pkgs, config, assignments, allAssignments, ... }:
 | 
			
		||||
    let
 | 
			
		||||
      inherit (lib) mkMerge;
 | 
			
		||||
      inherit (lib) mapAttrs mkMerge;
 | 
			
		||||
      inherit (lib.my) networkdAssignment;
 | 
			
		||||
      inherit (lib.my.c) networkd;
 | 
			
		||||
      inherit (lib.my.c.home) domain;
 | 
			
		||||
    in
 | 
			
		||||
    {
 | 
			
		||||
@@ -92,13 +95,30 @@ in
 | 
			
		||||
                MTUBytes = toString lib.my.c.home.hiMTU;
 | 
			
		||||
              };
 | 
			
		||||
            };
 | 
			
		||||
            "10-lan-hi-ctrs" = {
 | 
			
		||||
              matchConfig = {
 | 
			
		||||
                Driver = "mlx5_core";
 | 
			
		||||
                PermanentMACAddress = "52:54:00:90:34:95";
 | 
			
		||||
              };
 | 
			
		||||
              linkConfig = {
 | 
			
		||||
                Name = "lan-hi-ctrs";
 | 
			
		||||
                MTUBytes = toString lib.my.c.home.hiMTU;
 | 
			
		||||
              };
 | 
			
		||||
            };
 | 
			
		||||
          };
 | 
			
		||||
 | 
			
		||||
          networks."30-lan-hi" = mkMerge [
 | 
			
		||||
            (networkdAssignment "lan-hi" assignments.hi)
 | 
			
		||||
            # So we don't drop the IP we use to connect to NVMe-oF!
 | 
			
		||||
            { networkConfig.KeepConfiguration = "static"; }
 | 
			
		||||
          ];
 | 
			
		||||
          networks = {
 | 
			
		||||
            "30-lan-hi" = mkMerge [
 | 
			
		||||
              (networkdAssignment "lan-hi" assignments.hi)
 | 
			
		||||
              # So we don't drop the IP we use to connect to NVMe-oF!
 | 
			
		||||
              { networkConfig.KeepConfiguration = "static"; }
 | 
			
		||||
            ];
 | 
			
		||||
            "30-lan-hi-ctrs" = {
 | 
			
		||||
              matchConfig.Name = "lan-hi-ctrs";
 | 
			
		||||
              linkConfig.RequiredForOnline = "no";
 | 
			
		||||
              networkConfig = networkd.noL3;
 | 
			
		||||
            };
 | 
			
		||||
          };
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        my = {
 | 
			
		||||
@@ -117,6 +137,19 @@ in
 | 
			
		||||
              address = "192.168.68.80";
 | 
			
		||||
            };
 | 
			
		||||
          };
 | 
			
		||||
 | 
			
		||||
          containers.instances =
 | 
			
		||||
          let
 | 
			
		||||
            instances = {
 | 
			
		||||
              unifi = {};
 | 
			
		||||
            };
 | 
			
		||||
          in
 | 
			
		||||
          mkMerge [
 | 
			
		||||
            instances
 | 
			
		||||
            (mapAttrs (n: i: {
 | 
			
		||||
              networking.macVLAN = "lan-hi-ctrs";
 | 
			
		||||
            }) instances)
 | 
			
		||||
          ];
 | 
			
		||||
        };
 | 
			
		||||
      };
 | 
			
		||||
    };
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user