Compare commits
	
		
			1 Commits
		
	
	
		
			nix-topolo
			...
			gitea-navb
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						
						
							
						
						7f8c306d9a
	
				 | 
					
					
						
@@ -10,8 +10,6 @@
 | 
			
		||||
 | 
			
		||||
    ./services/acme.nix
 | 
			
		||||
    ./services/auto-upgrade.nix
 | 
			
		||||
    ./services/dbus.nix
 | 
			
		||||
    ./services/fwupd.nix
 | 
			
		||||
    ./services/irqbalance.nix
 | 
			
		||||
    ./services/logrotate.nix
 | 
			
		||||
    ./services/nginx.nix
 | 
			
		||||
@@ -19,12 +17,9 @@
 | 
			
		||||
    ./services/postfix.nix
 | 
			
		||||
    ./services/smartd.nix
 | 
			
		||||
    ./services/thermald.nix
 | 
			
		||||
    ./services/userborn.nix
 | 
			
		||||
    ./services/userdbd.nix
 | 
			
		||||
  ];
 | 
			
		||||
 | 
			
		||||
  boot.tmp.cleanOnBoot = lib.mkDefault true;
 | 
			
		||||
  boot.kernelPackages = lib.mkDefault pkgs.linuxPackages_latest;
 | 
			
		||||
 | 
			
		||||
  time.timeZone = "Europe/Oslo";
 | 
			
		||||
 | 
			
		||||
@@ -52,8 +47,6 @@
 | 
			
		||||
 | 
			
		||||
  programs.zsh.enable = true;
 | 
			
		||||
 | 
			
		||||
  security.lockKernelModules = true;
 | 
			
		||||
  security.protectKernelImage = true;
 | 
			
		||||
  security.sudo.execWheelOnly = true;
 | 
			
		||||
  security.sudo.extraConfig = ''
 | 
			
		||||
    Defaults lecture = never
 | 
			
		||||
 
 | 
			
		||||
@@ -5,10 +5,10 @@
 | 
			
		||||
      automatic = true;
 | 
			
		||||
      options = "--delete-older-than 2d";
 | 
			
		||||
    };
 | 
			
		||||
    optimise.automatic = true;
 | 
			
		||||
 | 
			
		||||
    settings = {
 | 
			
		||||
      allow-dirty = true;
 | 
			
		||||
      auto-optimise-store = true;
 | 
			
		||||
      builders-use-substitutes = true;
 | 
			
		||||
      experimental-features = [ "nix-command" "flakes" ];
 | 
			
		||||
      log-lines = 50;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +0,0 @@
 | 
			
		||||
{ ... }:
 | 
			
		||||
{
 | 
			
		||||
  services.dbus = {
 | 
			
		||||
    enable = true;
 | 
			
		||||
    implementation = "broker";
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
@@ -1,4 +0,0 @@
 | 
			
		||||
{ ... }:
 | 
			
		||||
{
 | 
			
		||||
  services.fwupd.enable = true;
 | 
			
		||||
}
 | 
			
		||||
@@ -1,4 +0,0 @@
 | 
			
		||||
{ ... }:
 | 
			
		||||
{
 | 
			
		||||
  services.userborn.enable = true;
 | 
			
		||||
}
 | 
			
		||||
@@ -1,4 +0,0 @@
 | 
			
		||||
{ ... }:
 | 
			
		||||
{
 | 
			
		||||
  services.userdbd.enable = true;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										206
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										206
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							@@ -1,26 +1,5 @@
 | 
			
		||||
{
 | 
			
		||||
  "nodes": {
 | 
			
		||||
    "devshell": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
          "nix-topology",
 | 
			
		||||
          "nixpkgs"
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1728330715,
 | 
			
		||||
        "narHash": "sha256-xRJ2nPOXb//u1jaBnDP56M7v5ldavjbtR6lfGqSvcKg=",
 | 
			
		||||
        "owner": "numtide",
 | 
			
		||||
        "repo": "devshell",
 | 
			
		||||
        "rev": "dd6b80932022cea34a019e2bb32f6fa9e494dfef",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "numtide",
 | 
			
		||||
        "repo": "devshell",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "disko": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
@@ -28,11 +7,11 @@
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1741786315,
 | 
			
		||||
        "narHash": "sha256-VT65AE2syHVj6v/DGB496bqBnu1PXrrzwlw07/Zpllc=",
 | 
			
		||||
        "lastModified": 1740485968,
 | 
			
		||||
        "narHash": "sha256-WK+PZHbfDjLyveXAxpnrfagiFgZWaTJglewBWniTn2Y=",
 | 
			
		||||
        "owner": "nix-community",
 | 
			
		||||
        "repo": "disko",
 | 
			
		||||
        "rev": "0d8c6ad4a43906d14abd5c60e0ffe7b587b213de",
 | 
			
		||||
        "rev": "19c1140419c4f1cdf88ad4c1cfb6605597628940",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
@@ -41,40 +20,6 @@
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "flake-compat": {
 | 
			
		||||
      "flake": false,
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1696426674,
 | 
			
		||||
        "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=",
 | 
			
		||||
        "owner": "edolstra",
 | 
			
		||||
        "repo": "flake-compat",
 | 
			
		||||
        "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "edolstra",
 | 
			
		||||
        "repo": "flake-compat",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "flake-utils": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "systems": "systems"
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1726560853,
 | 
			
		||||
        "narHash": "sha256-X6rJYSESBVr3hBoH0WbKE5KvhPU5bloyZ2L4K60/fPQ=",
 | 
			
		||||
        "owner": "numtide",
 | 
			
		||||
        "repo": "flake-utils",
 | 
			
		||||
        "rev": "c1dfcf08411b08f6b8615f7d8971a2bfa81d5e8a",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "numtide",
 | 
			
		||||
        "repo": "flake-utils",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "gergle": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
@@ -84,40 +29,17 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1736621371,
 | 
			
		||||
        "narHash": "sha256-45UIQSQA7R5iU4YWvilo7mQbhY1Liql9bHBvYa3qRI0=",
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "ref": "refs/heads/main",
 | 
			
		||||
        "rev": "3729796c1213fe76e568ac28f1df8de4e596950b",
 | 
			
		||||
        "revCount": 20,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Grzegorz/gergle.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Grzegorz/gergle.git"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "gitignore": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
          "nix-topology",
 | 
			
		||||
          "pre-commit-hooks",
 | 
			
		||||
          "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"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "greg-ng": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
@@ -128,14 +50,13 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1736545379,
 | 
			
		||||
        "narHash": "sha256-PeTTmGumdOX3rd6OKI7QMCrZovCDkrckZbcHr+znxWA=",
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "ref": "refs/heads/main",
 | 
			
		||||
        "rev": "74f5316121776db2769385927ec0d0c2cc2b23e4",
 | 
			
		||||
        "revCount": 42,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Grzegorz/greg-ng.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Grzegorz/greg-ng.git"
 | 
			
		||||
      }
 | 
			
		||||
@@ -149,7 +70,7 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1736178795,
 | 
			
		||||
        "narHash": "sha256-mPdi8cgvIDYcgG3FRG7A4BOIMu2Jef96TPMnV00uXlM=",
 | 
			
		||||
        "ref": "master",
 | 
			
		||||
        "ref": "refs/heads/master",
 | 
			
		||||
        "rev": "fde738910de1fd8293535a6382c2f0c2749dd7c1",
 | 
			
		||||
        "revCount": 79,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
@@ -167,16 +88,16 @@
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1735857245,
 | 
			
		||||
        "narHash": "sha256-AKLLPrgXTxgzll3DqVUMa4QlPlRN3QceutgFBmEf8Nk=",
 | 
			
		||||
        "lastModified": 1727410897,
 | 
			
		||||
        "narHash": "sha256-tWsyxvf421ieWUJYgjV7m1eTdr2ZkO3vId7vmtvfFpQ=",
 | 
			
		||||
        "owner": "dali99",
 | 
			
		||||
        "repo": "nixos-matrix-modules",
 | 
			
		||||
        "rev": "da9dc0479ffe22362793c87dc089035facf6ec4d",
 | 
			
		||||
        "rev": "ff787d410cba17882cd7b6e2e22cc88d4064193c",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "dali99",
 | 
			
		||||
        "ref": "0.7.0",
 | 
			
		||||
        "ref": "v0.6.1",
 | 
			
		||||
        "repo": "nixos-matrix-modules",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
@@ -185,15 +106,15 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1725277886,
 | 
			
		||||
        "narHash": "sha256-Fw4VbbE3EfypQWSgPDFfvVH47BHeg3ptsO715NlUM8Q=",
 | 
			
		||||
        "ref": "master",
 | 
			
		||||
        "ref": "refs/heads/master",
 | 
			
		||||
        "rev": "1b4087bd3322a2e2ba84271c8fcc013e6b641a58",
 | 
			
		||||
        "revCount": 2,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/minecraft-kartverket.git"
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Drift/minecraft-data.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/minecraft-kartverket.git"
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Drift/minecraft-data.git"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "nix-gitea-themes": {
 | 
			
		||||
@@ -205,48 +126,24 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1736531400,
 | 
			
		||||
        "narHash": "sha256-+X/HVI1AwoPcud28wI35XRrc1kDgkYdDUGABJBAkxDI=",
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "ref": "refs/heads/main",
 | 
			
		||||
        "rev": "e4dafd06b3d7e9e6e07617766e9c3743134571b7",
 | 
			
		||||
        "revCount": 7,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/oysteikt/nix-gitea-themes.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/oysteikt/nix-gitea-themes.git"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "nix-topology": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "devshell": "devshell",
 | 
			
		||||
        "flake-utils": "flake-utils",
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
          "nixpkgs"
 | 
			
		||||
        ],
 | 
			
		||||
        "pre-commit-hooks": "pre-commit-hooks"
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1738246091,
 | 
			
		||||
        "narHash": "sha256-2+KkZsRO+XlOFbXbRgMZbRtlqn5MBNYj4HNmZ/2Tojg=",
 | 
			
		||||
        "owner": "oddlama",
 | 
			
		||||
        "repo": "nix-topology",
 | 
			
		||||
        "rev": "5526269fa3eedf4f4bc00c0bf7a03db31d24b029",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "oddlama",
 | 
			
		||||
        "repo": "nix-topology",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "nixpkgs": {
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1741969460,
 | 
			
		||||
        "narHash": "sha256-SCNxTTBfMJV7XuTcLUfdAd6cgCGsazzi+DoPrceQrZ0=",
 | 
			
		||||
        "lastModified": 1740782485,
 | 
			
		||||
        "narHash": "sha256-GkDJDqHYlPKZFdyxzZHtljxNRsosKB1GCrblqlvLFgo=",
 | 
			
		||||
        "owner": "NixOS",
 | 
			
		||||
        "repo": "nixpkgs",
 | 
			
		||||
        "rev": "68612419aa6c9fd5b178b81e6fabbdf46d300ea4",
 | 
			
		||||
        "rev": "dd5c2540983641bbaabdfc665931592d4c9989e8",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
@@ -258,11 +155,11 @@
 | 
			
		||||
    },
 | 
			
		||||
    "nixpkgs-unstable": {
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1742051767,
 | 
			
		||||
        "narHash": "sha256-JpyjnalnIqJ7cvP8HzaoJN9/i2bDx83dToodHHjGuNg=",
 | 
			
		||||
        "lastModified": 1740848276,
 | 
			
		||||
        "narHash": "sha256-bYeI3FEs824X+MJYksKboNlmglehzplqzn+XvcojWMc=",
 | 
			
		||||
        "owner": "NixOS",
 | 
			
		||||
        "repo": "nixpkgs",
 | 
			
		||||
        "rev": "ec886d10b507760c90ed01e2eac7f0679d0a47ae",
 | 
			
		||||
        "rev": "e9b0ff70ddc61c42548501b0fafb86bb49cca858",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
@@ -272,33 +169,6 @@
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "pre-commit-hooks": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "flake-compat": "flake-compat",
 | 
			
		||||
        "gitignore": "gitignore",
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
          "nix-topology",
 | 
			
		||||
          "nixpkgs"
 | 
			
		||||
        ],
 | 
			
		||||
        "nixpkgs-stable": [
 | 
			
		||||
          "nix-topology",
 | 
			
		||||
          "nixpkgs"
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1730797577,
 | 
			
		||||
        "narHash": "sha256-SrID5yVpyUfknUTGWgYkTyvdr9J1LxUym4om3SVGPkg=",
 | 
			
		||||
        "owner": "cachix",
 | 
			
		||||
        "repo": "pre-commit-hooks.nix",
 | 
			
		||||
        "rev": "1864030ed24a2b8b4e4d386a5eeaf0c5369e50a9",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "cachix",
 | 
			
		||||
        "repo": "pre-commit-hooks.nix",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "pvv-calendar-bot": {
 | 
			
		||||
      "inputs": {
 | 
			
		||||
        "nixpkgs": [
 | 
			
		||||
@@ -308,14 +178,13 @@
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1723850344,
 | 
			
		||||
        "narHash": "sha256-aT37O9l9eclWEnqxASVNBL1dKwDHZUOqdbA4VO9DJvw=",
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "ref": "refs/heads/main",
 | 
			
		||||
        "rev": "38b66677ab8c01aee10cd59e745af9ce3ea88092",
 | 
			
		||||
        "revCount": 19,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/calendar-bot.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/calendar-bot.git"
 | 
			
		||||
      }
 | 
			
		||||
@@ -327,16 +196,15 @@
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1741738148,
 | 
			
		||||
        "narHash": "sha256-cJo6nbcJEOjkazkZ194NDnlsZe0W0wpxeUh2/886uC8=",
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "rev": "c1802e7cf27c7cf8b4890354c982a4eef5b11593",
 | 
			
		||||
        "revCount": 486,
 | 
			
		||||
        "lastModified": 1737151758,
 | 
			
		||||
        "narHash": "sha256-yZBsefIarFUEhFRj+rCGMp9Zvag3MCafqV/JfGVRVwc=",
 | 
			
		||||
        "ref": "refs/heads/master",
 | 
			
		||||
        "rev": "a4ebe6ded0c8c124561a41cb329ff30891914b5e",
 | 
			
		||||
        "revCount": 475,
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/nettsiden.git"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "ref": "main",
 | 
			
		||||
        "type": "git",
 | 
			
		||||
        "url": "https://git.pvv.ntnu.no/Projects/nettsiden.git"
 | 
			
		||||
      }
 | 
			
		||||
@@ -350,7 +218,6 @@
 | 
			
		||||
        "matrix-next": "matrix-next",
 | 
			
		||||
        "minecraft-data": "minecraft-data",
 | 
			
		||||
        "nix-gitea-themes": "nix-gitea-themes",
 | 
			
		||||
        "nix-topology": "nix-topology",
 | 
			
		||||
        "nixpkgs": "nixpkgs",
 | 
			
		||||
        "nixpkgs-unstable": "nixpkgs-unstable",
 | 
			
		||||
        "pvv-calendar-bot": "pvv-calendar-bot",
 | 
			
		||||
@@ -386,11 +253,11 @@
 | 
			
		||||
        ]
 | 
			
		||||
      },
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1741861888,
 | 
			
		||||
        "narHash": "sha256-ynOgXAyToeE1UdLNfrUn/hL7MN0OpIS2BtNdLjpjPf0=",
 | 
			
		||||
        "lastModified": 1739262228,
 | 
			
		||||
        "narHash": "sha256-7JAGezJ0Dn5qIyA2+T4Dt/xQgAbhCglh6lzCekTVMeU=",
 | 
			
		||||
        "owner": "Mic92",
 | 
			
		||||
        "repo": "sops-nix",
 | 
			
		||||
        "rev": "d016ce0365b87d848a57c12ffcfdc71da7a2b55f",
 | 
			
		||||
        "rev": "07af005bb7d60c7f118d9d9f5530485da5d1e975",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
@@ -398,21 +265,6 @@
 | 
			
		||||
        "repo": "sops-nix",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "systems": {
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1681028828,
 | 
			
		||||
        "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
 | 
			
		||||
        "owner": "nix-systems",
 | 
			
		||||
        "repo": "default",
 | 
			
		||||
        "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
        "owner": "nix-systems",
 | 
			
		||||
        "repo": "default",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  "root": "root",
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										32
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								flake.nix
									
									
									
									
									
								
							@@ -11,29 +11,26 @@
 | 
			
		||||
    disko.url = "github:nix-community/disko";
 | 
			
		||||
    disko.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    nix-topology.url = "github:oddlama/nix-topology";
 | 
			
		||||
    nix-topology.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    pvv-nettsiden.url = "git+https://git.pvv.ntnu.no/Projects/nettsiden.git?ref=main";
 | 
			
		||||
    pvv-nettsiden.url = "git+https://git.pvv.ntnu.no/Projects/nettsiden.git";
 | 
			
		||||
    pvv-nettsiden.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    pvv-calendar-bot.url = "git+https://git.pvv.ntnu.no/Projects/calendar-bot.git?ref=main";
 | 
			
		||||
    pvv-calendar-bot.url = "git+https://git.pvv.ntnu.no/Projects/calendar-bot.git";
 | 
			
		||||
    pvv-calendar-bot.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    matrix-next.url = "github:dali99/nixos-matrix-modules/0.7.0";
 | 
			
		||||
    matrix-next.url = "github:dali99/nixos-matrix-modules/v0.6.1";
 | 
			
		||||
    matrix-next.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    nix-gitea-themes.url = "git+https://git.pvv.ntnu.no/oysteikt/nix-gitea-themes.git?ref=main";
 | 
			
		||||
    nix-gitea-themes.url = "git+https://git.pvv.ntnu.no/oysteikt/nix-gitea-themes.git";
 | 
			
		||||
    nix-gitea-themes.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    greg-ng.url = "git+https://git.pvv.ntnu.no/Grzegorz/greg-ng.git?ref=main";
 | 
			
		||||
    greg-ng.url = "git+https://git.pvv.ntnu.no/Grzegorz/greg-ng.git";
 | 
			
		||||
    greg-ng.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
    gergle.url = "git+https://git.pvv.ntnu.no/Grzegorz/gergle.git?ref=main";
 | 
			
		||||
    gergle.url = "git+https://git.pvv.ntnu.no/Grzegorz/gergle.git";
 | 
			
		||||
    gergle.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
    grzegorz-clients.url = "git+https://git.pvv.ntnu.no/Grzegorz/grzegorz-clients.git";
 | 
			
		||||
    grzegorz-clients.inputs.nixpkgs.follows = "nixpkgs";
 | 
			
		||||
 | 
			
		||||
    minecraft-data.url = "git+https://git.pvv.ntnu.no/Projects/minecraft-kartverket.git";
 | 
			
		||||
    minecraft-data.url = "git+https://git.pvv.ntnu.no/Drift/minecraft-data.git";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  outputs = { self, nixpkgs, nixpkgs-unstable, sops-nix, disko, ... }@inputs:
 | 
			
		||||
@@ -70,7 +67,6 @@
 | 
			
		||||
          modules = [
 | 
			
		||||
            ./hosts/${name}/configuration.nix
 | 
			
		||||
            sops-nix.nixosModules.sops
 | 
			
		||||
            inputs.nix-topology.nixosModules.default
 | 
			
		||||
          ] ++ config.modules or [];
 | 
			
		||||
 | 
			
		||||
          pkgs = import nixpkgs {
 | 
			
		||||
@@ -154,7 +150,6 @@
 | 
			
		||||
    nixosModules = {
 | 
			
		||||
      snakeoil-certs = ./modules/snakeoil-certs.nix;
 | 
			
		||||
      snappymail = ./modules/snappymail.nix;
 | 
			
		||||
      robots-txt = ./modules/robots-txt.nix;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    devShells = forAllSystems (system: {
 | 
			
		||||
@@ -182,18 +177,5 @@
 | 
			
		||||
      // lib.genAttrs allMachines
 | 
			
		||||
        (machine: self.nixosConfigurations.${machine}.config.system.build.toplevel);
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    topology.x86_64-linux = import inputs.nix-topology {
 | 
			
		||||
      pkgs = import nixpkgs {
 | 
			
		||||
        system = "x86_64-linux";
 | 
			
		||||
        overlays = [inputs.nix-topology.overlays.default];
 | 
			
		||||
      }; # Only this package set must include nix-topology.overlays.default
 | 
			
		||||
      modules = [
 | 
			
		||||
        # Your own file to define global topology. Works in principle like a nixos module but uses different options.
 | 
			
		||||
        ./topology.nix
 | 
			
		||||
        # Inline module to inform topology of your existing NixOS hosts.
 | 
			
		||||
        { nixosConfigurations = self.nixosConfigurations; }
 | 
			
		||||
      ];
 | 
			
		||||
    };
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,52 +0,0 @@
 | 
			
		||||
{ config, pkgs, lib, fp, ... }:
 | 
			
		||||
let
 | 
			
		||||
  cfg = config.services.gitea;
 | 
			
		||||
in
 | 
			
		||||
{
 | 
			
		||||
  services.gitea-themes.monokai = pkgs.gitea-theme-monokai;
 | 
			
		||||
 | 
			
		||||
  systemd.services.gitea-customization = lib.mkIf cfg.enable {
 | 
			
		||||
    description = "Install extra customization in gitea's CUSTOM_DIR";
 | 
			
		||||
    wantedBy = [ "gitea.service" ];
 | 
			
		||||
    requiredBy = [ "gitea.service" ];
 | 
			
		||||
 | 
			
		||||
    serviceConfig =  {
 | 
			
		||||
      Type = "oneshot";
 | 
			
		||||
      User = cfg.user;
 | 
			
		||||
      Group = cfg.group;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    script = let
 | 
			
		||||
      logo-svg = fp /assets/logo_blue_regular.svg;
 | 
			
		||||
      logo-png = fp /assets/logo_blue_regular.png;
 | 
			
		||||
      extraLinks = pkgs.writeText "gitea-extra-links.tmpl" ''
 | 
			
		||||
        <a class="item" href="https://www.pvv.ntnu.no/">PVV</a>
 | 
			
		||||
        <a class="item" href="https://wiki.pvv.ntnu.no/">Wiki</a>
 | 
			
		||||
        <a class="item" href="https://git.pvv.ntnu.no/Drift/-/projects/4">Tokyo Drift Issues</a>
 | 
			
		||||
      '';
 | 
			
		||||
 | 
			
		||||
      project-labels = (pkgs.formats.yaml { }).generate "gitea-project-labels.yaml" {
 | 
			
		||||
        labels = lib.importJSON ./labels/projects.json;
 | 
			
		||||
      };
 | 
			
		||||
 | 
			
		||||
      customTemplates = pkgs.runCommandLocal "gitea-templates" {
 | 
			
		||||
        nativeBuildInputs = with pkgs; [
 | 
			
		||||
          coreutils
 | 
			
		||||
          gnused
 | 
			
		||||
        ];
 | 
			
		||||
      } ''
 | 
			
		||||
        # Bigger icons
 | 
			
		||||
        install -Dm444 "${cfg.package.src}/templates/repo/icon.tmpl" "$out/repo/icon.tmpl"
 | 
			
		||||
        sed -i -e 's/24/48/g' "$out/repo/icon.tmpl"
 | 
			
		||||
      '';
 | 
			
		||||
    in ''
 | 
			
		||||
      install -Dm444 ${logo-svg} ${cfg.customDir}/public/assets/img/logo.svg
 | 
			
		||||
      install -Dm444 ${logo-png} ${cfg.customDir}/public/assets/img/logo.png
 | 
			
		||||
      install -Dm444 ${./loading.apng} ${cfg.customDir}/public/assets/img/loading.png
 | 
			
		||||
      install -Dm444 ${extraLinks} ${cfg.customDir}/templates/custom/extra_links.tmpl
 | 
			
		||||
      install -Dm444 ${project-labels} ${cfg.customDir}/options/label/project-labels.yaml
 | 
			
		||||
 | 
			
		||||
      "${lib.getExe pkgs.rsync}" -a "${customTemplates}/" ${cfg.customDir}/templates/
 | 
			
		||||
    '';
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
@@ -1,11 +1,10 @@
 | 
			
		||||
{ config, values, lib, unstablePkgs, ... }:
 | 
			
		||||
{ config, values, fp, pkgs, lib, ... }:
 | 
			
		||||
let
 | 
			
		||||
  cfg = config.services.gitea;
 | 
			
		||||
  domain = "git.pvv.ntnu.no";
 | 
			
		||||
  sshPort  = 2222;
 | 
			
		||||
in {
 | 
			
		||||
  imports = [
 | 
			
		||||
    ./customization.nix
 | 
			
		||||
    ./gpg.nix
 | 
			
		||||
    ./import-users
 | 
			
		||||
    ./web-secret-provider
 | 
			
		||||
@@ -26,8 +25,6 @@ in {
 | 
			
		||||
    enable = true;
 | 
			
		||||
    appName = "PVV Git";
 | 
			
		||||
 | 
			
		||||
    package = unstablePkgs.gitea;
 | 
			
		||||
 | 
			
		||||
    database = {
 | 
			
		||||
      type = "postgres";
 | 
			
		||||
      host = "postgres.pvv.ntnu.no";
 | 
			
		||||
@@ -133,11 +130,6 @@ in {
 | 
			
		||||
      };
 | 
			
		||||
      "ui.meta".DESCRIPTION = "Bokstavelig talt programvareverkstedet";
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    dump = {
 | 
			
		||||
      enable = true;
 | 
			
		||||
      type = "tar.gz";
 | 
			
		||||
    };
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  environment.systemPackages = [ cfg.package ];
 | 
			
		||||
@@ -164,4 +156,41 @@ in {
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  networking.firewall.allowedTCPPorts = [ sshPort ];
 | 
			
		||||
 | 
			
		||||
  # Extra customization
 | 
			
		||||
 | 
			
		||||
  services.gitea-themes.monokai = pkgs.gitea-theme-monokai;
 | 
			
		||||
 | 
			
		||||
  systemd.services.install-gitea-customization = {
 | 
			
		||||
    description = "Install extra customization in gitea's CUSTOM_DIR";
 | 
			
		||||
    wantedBy = [ "gitea.service" ];
 | 
			
		||||
    requiredBy = [ "gitea.service" ];
 | 
			
		||||
 | 
			
		||||
    serviceConfig =  {
 | 
			
		||||
      Type = "oneshot";
 | 
			
		||||
      User = cfg.user;
 | 
			
		||||
      Group = cfg.group;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    script = let
 | 
			
		||||
      logo-svg = fp /assets/logo_blue_regular.svg;
 | 
			
		||||
      logo-png = fp /assets/logo_blue_regular.png;
 | 
			
		||||
      extraLinks = pkgs.writeText "gitea-extra-links.tmpl" ''
 | 
			
		||||
        <a class="item" href="https://www.pvv.ntnu.no/">PVV</a>
 | 
			
		||||
        <a class="item" href="https://wiki.pvv.ntnu.no/">Wiki</a>
 | 
			
		||||
        <a class="item" href="https://git.pvv.ntnu.no/Drift/-/projects/4">Tokyo Drift Issues</a>
 | 
			
		||||
        <a class="item" href="https://wiki.pvv.ntnu.no/wiki/Tjenester/Kodelager">Howto</a>
 | 
			
		||||
      '';
 | 
			
		||||
 | 
			
		||||
      project-labels = (pkgs.formats.yaml { }).generate "gitea-project-labels.yaml" {
 | 
			
		||||
        labels = lib.importJSON ./labels/projects.json;
 | 
			
		||||
      };
 | 
			
		||||
    in ''
 | 
			
		||||
      install -Dm444 ${logo-svg} ${cfg.customDir}/public/assets/img/logo.svg
 | 
			
		||||
      install -Dm444 ${logo-png} ${cfg.customDir}/public/assets/img/logo.png
 | 
			
		||||
      install -Dm444 ${./loading.apng} ${cfg.customDir}/public/assets/img/loading.png
 | 
			
		||||
      install -Dm444 ${extraLinks} ${cfg.customDir}/templates/custom/extra_links.tmpl
 | 
			
		||||
      install -Dm444 ${project-labels} ${cfg.customDir}/options/label/project-labels.yaml
 | 
			
		||||
    '';
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -2,10 +2,4 @@
 | 
			
		||||
 | 
			
		||||
{
 | 
			
		||||
  nix.settings.trusted-users = [ "@nix-builder-users" ];
 | 
			
		||||
  nix.daemonCPUSchedPolicy = "batch";
 | 
			
		||||
 | 
			
		||||
  boot.binfmt.emulatedSystems = [
 | 
			
		||||
    "aarch64-linux"
 | 
			
		||||
    "armv7l-linux"
 | 
			
		||||
  ];
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,116 +0,0 @@
 | 
			
		||||
{ config, pkgs, lib, ... }:
 | 
			
		||||
let
 | 
			
		||||
  cfg = config.environment.robots-txt;
 | 
			
		||||
 | 
			
		||||
  robots-txt-format = {
 | 
			
		||||
    type = let
 | 
			
		||||
      coercedStrToNonEmptyListOfStr = lib.types.coercedTo lib.types.str lib.singleton (lib.types.nonEmptyListOf lib.types.str);
 | 
			
		||||
    in lib.types.listOf (lib.types.submodule {
 | 
			
		||||
      freeformType = lib.types.attrsOf coercedStrToNonEmptyListOfStr;
 | 
			
		||||
      options = {
 | 
			
		||||
        pre_comment = lib.mkOption {
 | 
			
		||||
          description = "Comment to add before the rule";
 | 
			
		||||
          type = lib.types.lines;
 | 
			
		||||
          default = "";
 | 
			
		||||
        };
 | 
			
		||||
        post_comment = lib.mkOption {
 | 
			
		||||
          description = "Comment to add after the rule";
 | 
			
		||||
          type = lib.types.lines;
 | 
			
		||||
          default = "";
 | 
			
		||||
        };
 | 
			
		||||
      };
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    generate = name: value: let
 | 
			
		||||
      makeComment = comment: lib.pipe comment [
 | 
			
		||||
        (lib.splitString "\n")
 | 
			
		||||
        (lib.map (line: if line == "" then "#" else "# ${line}"))
 | 
			
		||||
        (lib.concatStringsSep "\n")
 | 
			
		||||
      ];
 | 
			
		||||
 | 
			
		||||
      ruleToString = rule: let
 | 
			
		||||
        user_agent = rule.User-agent or [];
 | 
			
		||||
        pre_comment = rule.pre_comment;
 | 
			
		||||
        post_comment = rule.post_comment;
 | 
			
		||||
        rest = builtins.removeAttrs rule [ "User-agent" "pre_comment" "post_comment" ];
 | 
			
		||||
      in lib.concatStringsSep "\n" (lib.filter (x: x != null) [
 | 
			
		||||
        (if (pre_comment != "") then makeComment pre_comment else null)
 | 
			
		||||
        (let
 | 
			
		||||
          user-agents = lib.concatMapStringsSep "\n" (value: "User-agent: ${value}") user_agent;
 | 
			
		||||
        in
 | 
			
		||||
          if user_agent == [] then null else user-agents
 | 
			
		||||
        )
 | 
			
		||||
        (lib.pipe rest [
 | 
			
		||||
          (lib.mapAttrsToList (ruleName: map (value: "${ruleName}: ${value}")))
 | 
			
		||||
          lib.concatLists
 | 
			
		||||
          (lib.concatStringsSep "\n")
 | 
			
		||||
        ])
 | 
			
		||||
        (if (post_comment != "") then makeComment post_comment else null)
 | 
			
		||||
      ]);
 | 
			
		||||
 | 
			
		||||
      content = lib.concatMapStringsSep "\n\n" ruleToString value;
 | 
			
		||||
    in pkgs.writeText name content;
 | 
			
		||||
  };
 | 
			
		||||
in
 | 
			
		||||
{
 | 
			
		||||
  options.environment.robots-txt = lib.mkOption {
 | 
			
		||||
    default = { };
 | 
			
		||||
    description = ''
 | 
			
		||||
      Different instances of robots.txt to use with web services.
 | 
			
		||||
    '';
 | 
			
		||||
    type = lib.types.attrsOf (lib.types.submodule ({ name, ... }: {
 | 
			
		||||
      options = {
 | 
			
		||||
        enable = lib.mkEnableOption "this instance of robots.txt" // {
 | 
			
		||||
          default = true;
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        path = lib.mkOption {
 | 
			
		||||
          description = "The resulting path of the dir containing the robots.txt file";
 | 
			
		||||
          type = lib.types.path;
 | 
			
		||||
          readOnly = true;
 | 
			
		||||
          default = "/etc/robots-txt/${name}";
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        rules = lib.mkOption {
 | 
			
		||||
          description = "Rules to include in robots.txt";
 | 
			
		||||
          default = [ ];
 | 
			
		||||
          example = [
 | 
			
		||||
            { User-agent = "Googlebot"; Disallow = "/no-googlebot"; }
 | 
			
		||||
            { User-agent = "Bingbot"; Disallow = [ "/no-bingbot" "/no-bingbot2" ]; }
 | 
			
		||||
          ];
 | 
			
		||||
          type = robots-txt-format.type;
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        virtualHost = lib.mkOption {
 | 
			
		||||
          description = "An nginx virtual host to add the robots.txt to";
 | 
			
		||||
          type = lib.types.nullOr lib.types.str;
 | 
			
		||||
          default = null;
 | 
			
		||||
        };
 | 
			
		||||
      };
 | 
			
		||||
    }));
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  config = {
 | 
			
		||||
    environment.etc = lib.mapAttrs' (name: value: {
 | 
			
		||||
      name = "robots-txt/${name}/robots.txt";
 | 
			
		||||
      value.source = robots-txt-format.generate name value.rules;
 | 
			
		||||
    }) cfg;
 | 
			
		||||
 | 
			
		||||
    services.nginx.virtualHosts = lib.pipe cfg [
 | 
			
		||||
      (lib.filterAttrs (_: value: value.virtualHost != null))
 | 
			
		||||
      (lib.mapAttrs' (name: value: {
 | 
			
		||||
        name = value.virtualHost;
 | 
			
		||||
        value = {
 | 
			
		||||
          locations = {
 | 
			
		||||
            "= /robots.txt" = {
 | 
			
		||||
              extraConfig = ''
 | 
			
		||||
                add_header Content-Type text/plain;
 | 
			
		||||
              '';
 | 
			
		||||
              root = cfg.${name}.path;
 | 
			
		||||
            };
 | 
			
		||||
          };
 | 
			
		||||
        };
 | 
			
		||||
      }))
 | 
			
		||||
    ];
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										20
									
								
								shell.nix
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								shell.nix
									
									
									
									
									
								
							@@ -11,14 +11,14 @@ pkgs.mkShellNoCC {
 | 
			
		||||
    editorconfig-checker
 | 
			
		||||
  ];
 | 
			
		||||
 | 
			
		||||
  env = {
 | 
			
		||||
    OS_AUTH_URL = "https://api.stack.it.ntnu.no:5000";
 | 
			
		||||
    OS_PROJECT_ID = "b78432a088954cdc850976db13cfd61c";
 | 
			
		||||
    OS_PROJECT_NAME = "STUDORG_Programvareverkstedet";
 | 
			
		||||
    OS_USER_DOMAIN_NAME = "NTNU";
 | 
			
		||||
    OS_PROJECT_DOMAIN_ID = "d3f99bcdaf974685ad0c74c2e5d259db";
 | 
			
		||||
    OS_REGION_NAME = "NTNU-IT";
 | 
			
		||||
    OS_INTERFACE = "public";
 | 
			
		||||
    OS_IDENTITY_API_VERSION = "3";
 | 
			
		||||
  };
 | 
			
		||||
  shellHook = ''
 | 
			
		||||
    export OS_AUTH_URL=https://api.stack.it.ntnu.no:5000
 | 
			
		||||
    export OS_PROJECT_ID=b78432a088954cdc850976db13cfd61c
 | 
			
		||||
    export OS_PROJECT_NAME="STUDORG_Programvareverkstedet"
 | 
			
		||||
    export OS_USER_DOMAIN_NAME="NTNU"
 | 
			
		||||
    export OS_PROJECT_DOMAIN_ID="d3f99bcdaf974685ad0c74c2e5d259db"
 | 
			
		||||
    export OS_REGION_NAME="NTNU-IT"
 | 
			
		||||
    export OS_INTERFACE=public
 | 
			
		||||
    export OS_IDENTITY_API_VERSION=3
 | 
			
		||||
  '';
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										120
									
								
								topology.nix
									
									
									
									
									
								
							
							
						
						
									
										120
									
								
								topology.nix
									
									
									
									
									
								
							@@ -1,120 +0,0 @@
 | 
			
		||||
{ config, ... }:
 | 
			
		||||
let
 | 
			
		||||
  inherit
 | 
			
		||||
    (config.lib.topology)
 | 
			
		||||
    mkInternet
 | 
			
		||||
    mkRouter
 | 
			
		||||
    mkSwitch
 | 
			
		||||
    mkDevice
 | 
			
		||||
    mkConnection
 | 
			
		||||
    mkConnectionRev;
 | 
			
		||||
  values = import ./values.nix;
 | 
			
		||||
in {
 | 
			
		||||
 | 
			
		||||
### Networks
 | 
			
		||||
 | 
			
		||||
  networks.pvv = {
 | 
			
		||||
    name = "PVV Network";
 | 
			
		||||
    cidrv4 = values.ipv4-space;
 | 
			
		||||
    cidrv6 = values.ipv6-space;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  networks.site-vpn = {
 | 
			
		||||
    name = "OpenVPN Site to Site";
 | 
			
		||||
    style = {
 | 
			
		||||
      primaryColor = "#9dd68d";
 | 
			
		||||
      secondaryColor = null;
 | 
			
		||||
      pattern = "dashed";
 | 
			
		||||
    };
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  networks.ntnu = {
 | 
			
		||||
    name = "NTNU";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.internet = mkInternet {
 | 
			
		||||
    connections = mkConnection "ntnu" "wan1";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.ntnu = mkRouter "NTNU" {
 | 
			
		||||
    interfaceGroups = [ ["wan1"] ["eth1" "eth2" "eth3"] ];
 | 
			
		||||
    connections.eth1 = mkConnection "ntnu-pvv-router" "wan1";
 | 
			
		||||
    connections.eth2 = mkConnection "ntnu-veggen" "wan1";
 | 
			
		||||
    connections.eth3 = mkConnection "stackit" "*";
 | 
			
		||||
    interfaces.eth1.network = "ntnu";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
### Brus
 | 
			
		||||
 | 
			
		||||
  nodes.ntnu-pvv-router = mkRouter "NTNU PVV Gateway" {
 | 
			
		||||
    interfaceGroups = [ ["wan1"] ["eth1"] ];
 | 
			
		||||
    connections.eth1 = mkConnection "brus-switch" "eth1";
 | 
			
		||||
    interfaces.eth1.network = "pvv";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.brus-switch = mkSwitch "Brus Switch" {
 | 
			
		||||
    interfaceGroups = [ ["eth1" "eth2" "eth3" "eth4" "eth5" "eth6" "eth7"] ];
 | 
			
		||||
    connections.eth2 = mkConnection "bekkalokk" "enp2s0";
 | 
			
		||||
    connections.eth3 = mkConnection "bicep" "enp6s0f0";
 | 
			
		||||
    # connections.eth4 = mkConnection "buskerud" "enp3s0f0";
 | 
			
		||||
    connections.eth5 = mkConnection "knutsen" "eth1";
 | 
			
		||||
    connections.eth7 = mkConnection "joshua" "eth1";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.knutsen = mkRouter "knutsen" {
 | 
			
		||||
    interfaceGroups = [ ["eth1"] ["eth2"] ["vpn1"] ];
 | 
			
		||||
    connections.eth2 = mkConnectionRev "brus-switch" "eth6";
 | 
			
		||||
    # connections.vpn1 = mkConnection "ludvigsen" "vpn1";
 | 
			
		||||
    interfaces.vpn1.network = "site-vpn";
 | 
			
		||||
    interfaces.vpn1.virtual = true;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.joshua = mkDevice "joshua" {
 | 
			
		||||
    interfaceGroups = [ ["eth1"] ];
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.shark = {
 | 
			
		||||
    guestType = "proxmox";
 | 
			
		||||
    parent = config.nodes.joshua.id;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### PVV
 | 
			
		||||
 | 
			
		||||
  nodes.ntnu-veggen = mkRouter "NTNU-Veggen" {
 | 
			
		||||
    interfaceGroups = [ ["wan1"] ["eth1"] ];
 | 
			
		||||
    connections.eth1 = mkConnection "ludvigsen" "eth1";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.ludvigsen = mkRouter "ludvigsen" {
 | 
			
		||||
    interfaceGroups = [ ["eth1"] ["eth2"] ["vpn1"] ];
 | 
			
		||||
    connections.eth2 = mkConnection "pvv-switch" "eth1";
 | 
			
		||||
    interfaces.vpn1.network = "site-vpn";
 | 
			
		||||
    interfaces.vpn1.virtual = true;
 | 
			
		||||
    interfaces.eth1.network = "ntnu";
 | 
			
		||||
    interfaces.eth2.network = "pvv";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.pvv-switch = mkSwitch "PVV Switch (Terminalrommet)" {
 | 
			
		||||
    interfaceGroups = [ ["eth1" "eth2" "eth3"] ];
 | 
			
		||||
    connections.eth2 = mkConnection "brzeczyszczykiewicz" "eno1";
 | 
			
		||||
    connections.eth3 = mkConnection "georg" "eno1";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### Openstack
 | 
			
		||||
 | 
			
		||||
  nodes.stackit = mkDevice "stackit" {
 | 
			
		||||
    interfaceGroups = [ ["*"] ];
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  nodes.ildkule = {
 | 
			
		||||
    guestType = "openstack";
 | 
			
		||||
    parent = config.nodes.stackit.id;
 | 
			
		||||
  };
 | 
			
		||||
  nodes.bob = {
 | 
			
		||||
    guestType = "openstack";
 | 
			
		||||
    parent = config.nodes.stackit.id;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user