Compare commits
	
		
			20 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 31f2f445f3 | |||
| bce1f0e912 | |||
| 1caa0cc7be | |||
| 752141f97f | |||
| 23c1c17607 | |||
| 9560eab82b | |||
| 5e4ededab3 | |||
| 7fb3e29d7b | |||
| 9053dda57c | |||
| 4ab133e541 | |||
| e5b38cd2c1 | |||
| 3e156a8649 | |||
| b40cde891e | |||
| dca6862045 | |||
| 4e44da29b5 | |||
| ca9ac0e0fc | |||
| c8d29c363f | |||
| e387656be8 | |||
| 48a5f4e79e | |||
| 29c4029486 | 
							
								
								
									
										25
									
								
								.mailmap
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								.mailmap
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> <daniel.olsen99@gmail.com> | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> Daniel <danio@pvv.ntnu.no> | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> Daniel Lovbrotte Olsen <danio@pvv.ntnu.no> | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> Daniel Olsen <danio@pvv.ntnu.no> | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> danio <danio@pvv.ntnu.no> | ||||
| Daniel Løvbrøtte Olsen <danio@pvv.ntnu.no> Daniel Olsen <danio@bicep.pvv.ntnu.no> | ||||
|  | ||||
|  | ||||
| Øystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> h7x4 <h7x4@nani.wtf> | ||||
| Øystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> Øystein Tveit <oysteikt@pvv.ntnu.no> | ||||
| Øystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> oysteikt <oysteikt@pvv.ntnu.no> | ||||
| Øystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> Øystein <oysteikt@pvv.org> | ||||
| Øystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> Oystein Kristoffer Tveit <oysteikt@pvv.ntnu.no> | ||||
|  | ||||
| Felix Albrigtsen <felixalb@pvv.ntnu.no> <felix@albrigtsen.it> | ||||
| Felix Albrigtsen <felixalb@pvv.ntnu.no> <felixalbrigtsen@gmail.com> | ||||
| Felix Albrigtsen <felixalb@pvv.ntnu.no> felixalb <felixalb@pvv.ntnu.no> | ||||
|  | ||||
| Peder Bergebakken Sundt <pederbs@pvv.ntnu.no> <pbsds@hotmail.com> | ||||
|  | ||||
| Adrian Gunnar Lauterer <adriangl@pvv.ntnu.no> Adrian G L <adrian@lauterer.it> | ||||
| Adrian Gunnar Lauterer <adriangl@pvv.ntnu.no> Adrian Gunnar Lauterer <adrian@lauterer.it> | ||||
|  | ||||
| Fredrik Robertsen <frero@pvv.ntnu.no> frero <frero@pvv.ntnu.no> | ||||
| Fredrik Robertsen <frero@pvv.ntnu.no> fredrikr79 <fredrikrobertsen7@gmail.com> | ||||
| @@ -7,8 +7,10 @@ | ||||
|  | ||||
|     ./networking.nix | ||||
|     ./nix.nix | ||||
|     ./vm.nix | ||||
|  | ||||
|     ./services/acme.nix | ||||
|     ./services/uptimed.nix | ||||
|     ./services/auto-upgrade.nix | ||||
|     ./services/dbus.nix | ||||
|     ./services/fwupd.nix | ||||
| @@ -76,4 +78,3 @@ | ||||
|   # Trusted users on the nix builder machines | ||||
|   users.groups."nix-builder-users".name = "nix-builder-users"; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,16 +1,27 @@ | ||||
| { inputs, pkgs, lib, ... }: | ||||
|  | ||||
| let | ||||
|   inputUrls = lib.mapAttrs (input: value: value.url) (import "${inputs.self}/flake.nix").inputs; | ||||
| in | ||||
|  | ||||
| { | ||||
|   system.autoUpgrade = { | ||||
|     enable = true; | ||||
|     flake = "git+https://git.pvv.ntnu.no/Drift/pvv-nixos-config.git"; | ||||
|     flags = [ | ||||
|       # --update-input is deprecated since nix 2.22, and removed in lix 2.90 | ||||
|       # https://git.lix.systems/lix-project/lix/issues/400 | ||||
|       "--refresh" | ||||
|       "--override-input" "nixpkgs" "github:nixos/nixpkgs/nixos-24.11-small" | ||||
|       "--override-input" "nixpkgs-unstable" "github:nixos/nixpkgs/nixos-unstable-small" | ||||
|       "--no-write-lock-file" | ||||
|     ]; | ||||
|       # --update-input is deprecated since nix 2.22, and removed in lix 2.90 | ||||
|       # as such we instead use --override-input combined with --refresh | ||||
|       # https://git.lix.systems/lix-project/lix/issues/400 | ||||
|     ] ++ (lib.pipe inputUrls [ | ||||
|       (lib.intersectAttrs { | ||||
|         nixpkgs = { }; | ||||
|         nixpkgs-unstable = { }; | ||||
|       }) | ||||
|       (lib.mapAttrsToList (input: url: ["--override-input" input url])) | ||||
|       lib.concatLists | ||||
|     ]); | ||||
|   }; | ||||
|  | ||||
|   # workaround for https://github.com/NixOS/nix/issues/6895 | ||||
|   | ||||
							
								
								
									
										59
									
								
								base/services/uptimed.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								base/services/uptimed.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| { config, pkgs, lib, ... }: | ||||
| let | ||||
|   cfg = config.services.uptimed; | ||||
| in | ||||
| { | ||||
|   options.services.uptimed.settings = lib.mkOption { | ||||
|     description = ""; | ||||
|     default = { }; | ||||
|     type = lib.types.submodule { | ||||
|       freeformType = with lib.types; attrsOf (either str (listOf str)); | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   config = { | ||||
|     services.uptimed = { | ||||
|       enable = true; | ||||
|  | ||||
|       settings = let | ||||
|         stateDir = "/var/lib/uptimed"; | ||||
|       in { | ||||
|         PIDFILE = "${stateDir}/pid"; | ||||
|         SENDMAIL = lib.mkDefault "${pkgs.system-sendmail}/bin/sendmail -t"; | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     systemd.services.uptimed = lib.mkIf (cfg.enable) { | ||||
|       serviceConfig = let | ||||
|         uptimed = pkgs.uptimed.overrideAttrs (prev: { | ||||
|           postPatch = '' | ||||
|              substituteInPlace Makefile.am \ | ||||
|                --replace-fail '$(sysconfdir)/uptimed.conf' '/var/lib/uptimed/uptimed.conf' | ||||
|              substituteInPlace src/Makefile.am \ | ||||
|                --replace-fail '$(sysconfdir)/uptimed.conf' '/var/lib/uptimed/uptimed.conf' | ||||
|           ''; | ||||
|         }); | ||||
|  | ||||
|       in { | ||||
|         Type = "notify"; | ||||
|  | ||||
|         ExecStart = lib.mkForce "${uptimed}/sbin/uptimed -f"; | ||||
|  | ||||
|         BindReadOnlyPaths = let | ||||
|           configFile = lib.pipe cfg.settings [ | ||||
|             (lib.mapAttrsToList | ||||
|               (k: v: | ||||
|                 if builtins.isList v | ||||
|                   then lib.mapConcatStringsSep "\n" (v': "${k}=${v'}") v | ||||
|                   else "${k}=${v}") | ||||
|             ) | ||||
|             (lib.concatStringsSep "\n") | ||||
|             (pkgs.writeText "uptimed.conf") | ||||
|           ]; | ||||
|         in [ | ||||
|           "${configFile}:/var/lib/uptimed/uptimed.conf" | ||||
|         ]; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										15
									
								
								base/vm.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								base/vm.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| { lib, ... }: | ||||
|  | ||||
| # This enables | ||||
| #     lib.mkIf (!config.virtualisation.isVmVariant) { ... } | ||||
|  | ||||
| { | ||||
|   options.virtualisation.isVmVariant = lib.mkOption { | ||||
|     description = "`true` if system is build with 'nixos-rebuild build-vm'"; | ||||
|     type = lib.types.bool; | ||||
|     default = false; | ||||
|   }; | ||||
|   config.virtualisation.vmVariant = { | ||||
|     virtualisation.isVmVariant = true; | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										34
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -139,34 +139,28 @@ | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1745526780, | ||||
|         "narHash": "sha256-LXXYBmFPMQU2lTb6alKWfjgQs08BKn+txMNcgbu00hI=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "9204750b34cae1a8347ab4b5588115edfeebc6d7", | ||||
|         "type": "github" | ||||
|         "lastModified": 1748615477, | ||||
|         "narHash": "sha256-8sjG4sNIonQPK2olCGvq3/j1qtjwPaTOFU5nkz1gj2Q=", | ||||
|         "rev": "97d3ce1ceb663a24184aac92b7e9e8f5452111c1", | ||||
|         "type": "tarball", | ||||
|         "url": "https://releases.nixos.org/nixos/24.11-small/nixos-24.11.718472.97d3ce1ceb66/nixexprs.tar.xz?rev=97d3ce1ceb663a24184aac92b7e9e8f5452111c1" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-24.11-small", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|         "type": "tarball", | ||||
|         "url": "https://nixos.org/channels/nixos-24.11-small/nixexprs.tar.xz" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs-unstable": { | ||||
|       "locked": { | ||||
|         "lastModified": 1745688173, | ||||
|         "narHash": "sha256-fgvG1O5JvSSjeQx+ea0DJ3GfMbLPVhAQta/DqQ2y6jc=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "6a2957c7978b189202e03721aab901c0a9dc1e1a", | ||||
|         "type": "github" | ||||
|         "lastModified": 1748588304, | ||||
|         "narHash": "sha256-YCnUqO9k39p0oMIBndxYTbu8m0fOA/KVcq3IekXPy9c=", | ||||
|         "rev": "b8af95f4cf511c5f056b463c3a45d2b63c7cfb03", | ||||
|         "type": "tarball", | ||||
|         "url": "https://releases.nixos.org/nixos/unstable-small/nixos-25.11pre807945.b8af95f4cf51/nixexprs.tar.xz?rev=b8af95f4cf511c5f056b463c3a45d2b63c7cfb03" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-unstable-small", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|         "type": "tarball", | ||||
|         "url": "https://nixos.org/channels/nixos-unstable-small/nixexprs.tar.xz" | ||||
|       } | ||||
|     }, | ||||
|     "pvv-calendar-bot": { | ||||
|   | ||||
| @@ -2,8 +2,8 @@ | ||||
|   description = "PVV System flake"; | ||||
|  | ||||
|   inputs = { | ||||
|     nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11-small"; # remember to also update the url in base/services/auto-upgrade.nix | ||||
|     nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable-small"; | ||||
|     nixpkgs.url = "https://nixos.org/channels/nixos-24.11-small/nixexprs.tar.xz"; | ||||
|     nixpkgs-unstable.url = "https://nixos.org/channels/nixos-unstable-small/nixexprs.tar.xz"; | ||||
|  | ||||
|     sops-nix.url = "github:Mic92/sops-nix"; | ||||
|     sops-nix.inputs.nixpkgs.follows = "nixpkgs"; | ||||
|   | ||||
| @@ -17,7 +17,7 @@ in | ||||
|       zip = false; | ||||
|       keep = 10; | ||||
|       bare = true; | ||||
|       lfs = true; | ||||
|       lfs = false; | ||||
|     }; | ||||
|  | ||||
|     instances = let | ||||
| @@ -59,7 +59,7 @@ in | ||||
|   }; | ||||
|  | ||||
|   services.cgit = let | ||||
|     domain = "bicep.pvv.ntnu.no"; | ||||
|     domain = "mirrors.pvv.ntnu.no"; | ||||
|   in { | ||||
|     ${domain} = { | ||||
|       enable = true; | ||||
| @@ -81,7 +81,7 @@ in | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   services.nginx.virtualHosts."bicep.pvv.ntnu.no" = { | ||||
|   services.nginx.virtualHosts."mirrors.pvv.ntnu.no" = { | ||||
|     forceSSL = true; | ||||
|     enableACME = true; | ||||
|  | ||||
| @@ -94,7 +94,7 @@ in | ||||
|     in toString small-pvv-logo; | ||||
|   }; | ||||
|  | ||||
|   systemd.services."fcgiwrap-cgit-bicep.pvv.ntnu.no" = { | ||||
|   systemd.services."fcgiwrap-cgit-mirrors.pvv.ntnu.no" = { | ||||
|     serviceConfig.BindReadOnlyPaths = [ cfg.dataDir ]; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -3,7 +3,12 @@ let | ||||
|   cfg = config.services.gitea; | ||||
| in | ||||
| { | ||||
|   services.gitea-themes.monokai = pkgs.gitea-theme-monokai; | ||||
|   services.gitea-themes = { | ||||
|     monokai = pkgs.gitea-theme-monokai; | ||||
|     earl-grey = pkgs.gitea-theme-earl-grey; | ||||
|     pitch-black = pkgs.gitea-theme-pitch-black; | ||||
|     catppuccin = pkgs.gitea-theme-catppuccin; | ||||
|   }; | ||||
|  | ||||
|   systemd.services.gitea-customization = lib.mkIf cfg.enable { | ||||
|     description = "Install extra customization in gitea's CUSTOM_DIR"; | ||||
|   | ||||
							
								
								
									
										57
									
								
								justfile
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								justfile
									
									
									
									
									
								
							| @@ -1,25 +1,56 @@ | ||||
| set positional-arguments # makes variables accesible as $1 $2 $@ | ||||
| export GUM_FILTER_HEIGHT := "15" | ||||
| nom := `if command -v nom >/dev/null; then echo nom; else echo nix; fi` | ||||
| nom := `if [[ -t 2 ]] && command -v nom >/dev/null; then echo nom; else echo nix; fi` | ||||
| nix_eval_opts := "--log-format raw --option warn-dirty false" | ||||
|  | ||||
| @_default: | ||||
|   just "$(gum choose --ordered --header "Pick a recipie..." $(just --summary --unsorted))" | ||||
|  | ||||
| check: | ||||
|   nix flake check --keep-going | ||||
| check *_: | ||||
|   nix flake check --keep-going "$@" | ||||
|  | ||||
| build-machine machine=`just _a_machine`: | ||||
|   {{nom}} build .#nixosConfigurations.{{ machine }}.config.system.build.toplevel | ||||
| build-machine machine=`just _a_machine` *_: | ||||
|   {{nom}} build .#nixosConfigurations.{{ machine }}.config.system.build.toplevel "${@:2}" | ||||
|  | ||||
| run-vm machine=`just _a_machine`: | ||||
|   nixos-rebuild build-vm --flake .#{{ machine }} | ||||
| run-vm machine=`just _a_machine` *_: | ||||
|   nixos-rebuild build-vm --flake .#{{ machine }} "${@:2}" | ||||
|   QEMU_NET_OPTS="hostfwd=tcp::8080-:80,hostfwd=tcp::8081-:443,hostfwd=tcp::2222-:22" ./result/bin/run-*-vm | ||||
|  | ||||
| @update-inputs: | ||||
|   nix eval .#inputs --apply builtins.attrNames --json \ | ||||
|     | jq '.[]' -r \ | ||||
|     | gum choose --no-limit --height=15 \ | ||||
|     | xargs -L 1 nix flake lock --update-input | ||||
| @update-inputs *_: | ||||
|   @git reset flake.lock | ||||
|   @git restore flake.lock | ||||
|   nix eval {{nix_eval_opts}} --file flake.nix --apply 'x: builtins.attrNames x.inputs' --json \ | ||||
|     | { printf "%s\n" --commit-lock-file; jq '.[]' -r | grep -vxF "self" ||:; } \ | ||||
|     | gum choose --no-limit --header "Choose extra arguments:" \ | ||||
|     | tee >(xargs -d'\n' echo + nix flake update "$@" >&2) \ | ||||
|     | xargs -d'\n' nix flake update "$@" | ||||
|  | ||||
| @repl $machine=`just _a_machine` *_: | ||||
|   set -v; NIX_NO_NOM=1 nixos-rebuild --flake .#"$machine" repl "${@:2}" | ||||
|  | ||||
| @eval $machine=`just _a_machine` $attrpath="system.build.toplevel.outPath" *_: | ||||
|   set -v; nix eval {{nix_eval_opts}} ".#nixosConfigurations.\"$machine\".config.$attrpath" --show-trace "${@:3}" | ||||
|  | ||||
| @eval-vm $machine=`just _a_machine` $attrpath="system.build.toplevel.outPath" *_: | ||||
|   just eval "$machine" "virtualisation.vmVariant.$attrpath" "${@:3}" | ||||
|  | ||||
|  | ||||
| # helpers | ||||
|  | ||||
| [no-exit-message] | ||||
| _a_machine: | ||||
|   nix eval .#nixosConfigurations --apply builtins.attrNames --json | jq .[] -r | gum filter | ||||
|   #!/usr/bin/env -S sh -euo pipefail | ||||
|   machines="$( | ||||
|     nix eval {{nix_eval_opts}} .#nixosConfigurations --apply builtins.attrNames --json | jq .[] -r | ||||
|   )" | ||||
|   [ -n "$machines" ] || { echo >&2 "ERROR: no machines found"; false; } | ||||
|   if [ -s .direnv/vars/last-machine.txt ]; then | ||||
|     machines="$( | ||||
|       grep <<<"$machines" -xF  "$(cat .direnv/vars/last-machine.txt)" ||: | ||||
|       grep <<<"$machines" -xFv "$(cat .direnv/vars/last-machine.txt)" ||: | ||||
|     )" | ||||
|   fi | ||||
|   choice="$(gum filter <<<"$machines")" | ||||
|   mkdir -p .direnv/vars | ||||
|   cat <<<"$choice" >.direnv/vars/last-machine.txt | ||||
|   cat <<<"$choice" | ||||
|   | ||||
							
								
								
									
										12
									
								
								shell.nix
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								shell.nix
									
									
									
									
									
								
							| @@ -1,6 +1,18 @@ | ||||
| { pkgs ? import <nixpkgs> {} }: | ||||
|  | ||||
| let | ||||
|   nixos-rebuild-nom = pkgs.writeScriptBin "nixos-rebuild" '' | ||||
|     if [[ -t 1 && -z "''${NIX_NO_NOM-}" ]]; then | ||||
|       exec ${pkgs.lib.getExe pkgs.nixos-rebuild} -L "$@" |& ${pkgs.lib.getExe pkgs.nix-output-monitor} | ||||
|     else | ||||
|       exec ${pkgs.lib.getExe pkgs.nixos-rebuild} -L "$@" | ||||
|     fi | ||||
|   ''; | ||||
| in | ||||
|  | ||||
| pkgs.mkShellNoCC { | ||||
|   packages = with pkgs; [ | ||||
|     nixos-rebuild-nom | ||||
|     just | ||||
|     jq | ||||
|     gum | ||||
|   | ||||
		Reference in New Issue
	
	Block a user