1 # Edit this configuration file to define what should be installed on
2 # your system. Help is available in the configuration.nix(5) man page, on
3 # https://search.nixos.org/options and in the NixOS manual (`nixos-help`).
5 { config, lib, pkgs, ... } @ args:
9 [ # Include the results of the hardware scan.
10 ./hardware-configuration.nix
13 # Use the GRUB 2 boot loader.
14 boot.loader.systemd-boot.enable = true;
15 # boot.loader.grub.efiSupport = true;
16 # boot.loader.grub.efiInstallAsRemovable = true;
17 # boot.loader.efi.efiSysMountPoint = "/boot/efi";
18 # Define on which hard drive you want to install Grub.
19 # boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only
21 nix.settings.experimental-features = [ "nix-command" "flakes" ];
22 nix.package = pkgs.nixVersions.nix_2_28;
26 options = "--delete-older-than 30d";
28 nix.optimise.automatic = true;
29 system.autoUpgrade = {
34 networking.hostName = "pschdev"; # Define your hostname.
36 networking.firewall = {
38 allowedTCPPorts = [ 80 443 7777 9418 ];
42 time.timeZone = "Europe/Amsterdam";
44 # Configure network proxy if necessary
45 # networking.proxy.default = "http://user:password@proxy:port/";
46 # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
48 # Select internationalisation properties.
49 i18n.defaultLocale = "de_DE.UTF-8";
51 font = "Lat2-Terminus16";
52 keyMap = "de-latin1-nodeadkeys";
53 # useXkbConfig = true; # use xkb.options in tty.
56 # Define a user account. Don't forget to set a password with ‘passwd’.
59 extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user.
60 packages = with pkgs; [
69 useDefaultShell = true;
71 users.groups.live = {};
75 sudo.wheelNeedsPassword = false;
78 # nixpkgs.config.allowUnfree = true;
80 # List packages installed in system profile. To search, run:
82 environment.systemPackages = with pkgs; [
83 vim wget file git fzf bat
92 python312Packages.pygments
97 environment.shellAliases = {
98 snrs = "sudo nixos-rebuild switch --flake /etc/nixos#default";
99 snrt = "sudo nixos-rebuild test --flake /etc/nixos#default";
100 snrb = "sudo nixos-rebuild boot --flake /etc/nixos#default";
101 senc = "sudo ${pkgs.helix}/bin/hx /etc/nixos/configuration.nix";
111 shell = "${pkgs.git}/bin/git-shell";
112 openssh.authorizedKeys.keys = [
113 "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICQOPefMnq0qvFjYxlrdlSmUgyCbvV85gkfRykVlTnrn ps@nixos"
114 "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB0mNZn4EWdIwXEGfqUwwJy5STaZLYWbeKqDd4MN8WIK root@nixos"
115 "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIL+1sLAf+I+o3aODJeDuNvbqKD1wokQyk6oX0ZGK8su5 root@pschdev"
116 "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIN6sNqiMZpmRkiwjj5Dv0QljLObzhopwIsF0WDQbr/Hg ps@nixos"
119 users.groups.git = {};
124 init.defaultBranch = "main";
125 user.name = "Patrick";
126 user.email = "patrick.schoenberger@posteo.de";
130 services.gitDaemon = {
132 basePath = "/srv/git";
133 repositories = [ "/srv/git" ];
138 # Enable the OpenSSH daemon.
143 AllowTcpForwarding no
144 AllowAgentForwarding no
145 PasswordAuthentication no
150 services.qemuGuest.enable = true;
151 # virtualisation.qemu.guestAgent.enable = true;
152 programs.mosh.enable = true;
157 virtualHosts."psch.dev".extraConfig = ''
161 virtualHosts."julius.psch.dev".extraConfig = ''
162 basic_auth { test $2a$14$iKv0GlwavCunG0zQbaf2fOl4r4/8k8gDKUVUouu9Q3o.MfSDkp6Te }
163 root * /srv/julius_cam
166 virtualHosts."chirp.psch.dev".extraConfig = ''
167 reverse_proxy http://localhost:8080 {
172 services.caddy.virtualHosts."git.psch.dev".extraConfig = ''
175 @assets path /cgit.css /cgit.png /favicon.ico /robots.txt
183 root ${pkgs.cgit}/cgit
187 reverse_proxy unix//run/fcgiwrap-git.sock {
189 env CGIT_CONFIG ${pkgs.writeText "cgitrc" ''
190 snapshots=tar tar.gz zip
195 module-link=/%s/commit/?id=%s
196 clone-url=https://git.psch.dev/$CGIT_REPO_URL git://psch.dev/$CGIT_REPO_URL ssh://git@psch.dev:$CGIT_REPO_URL
199 about-filter=${pkgs.writeShellScript "markdown-filter" ''
200 echo '<div class="markdown-body">'
201 ${pkgs.md4c}/bin/md2html --github --ftables
204 # source-filter=${pkgs.cgit}/lib/cgit/filters/syntax-highlighting.py
205 head-include=/srv/cgithub/head-include.html
206 footer=/srv/cgithub/footer.html
213 env SCRIPT_FILENAME ${pkgs.cgit}/cgit/cgit.cgi
218 # virtualHosts."git.psch.dev".extraConfig = ''
219 # reverse_proxy unix//run/anubis/anubis-cgit.sock
221 services.caddy.virtualHosts."gitweb.psch.dev".extraConfig = ''
228 reverse_proxy unix//run/fcgiwrap-git.sock {
230 env GITWEB_CONFIG ${pkgs.writeText "gitweb.conf" ''
231 $projectroot = "/srv/git";
233 $feature{'pathinfo'}{'default'} = [1];
234 $default_projects_order = "age";
236 $site_html_head_string = "<meta xmlns=\"http://www.w3.org/1999/xhtml\" name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />";
238 env SCRIPT_FILENAME ${pkgs.gitweb}/gitweb.cgi
243 # virtualHosts."gitweb.psch.dev".extraConfig = ''
244 # reverse_proxy unix//run/anubis/anubis-gitweb.sock
253 # instances.cgit.settings.TARGET = "http://localhost:8082/cgit";
254 # instances.gitweb.settings.TARGET = "http://localhost:8082";
257 services.fcgiwrap.instances."git" = {
258 process.user = "git";
259 process.group = "git";
260 socket.user = "caddy";
261 socket.group = "caddy";
264 users.users.chirp = {
267 home = "/var/lib/chirp";
270 users.groups.chirp = {};
272 systemd.services.chirp = {
273 description = "Chirp SystemD Service";
274 wantedBy = ["multi-user.target"];
275 after = ["network.target"];
277 WorkingDirectory = "/var/lib/chirp";
278 ExecStart = "${args.inputs.chirp.packages.${pkgs.system}.default}/bin/chirp";
286 # Copy the NixOS configuration file and link it from the resulting system
287 # (/run/current-system/configuration.nix). This is useful in case you
288 # accidentally delete configuration.nix.
289 # system.copySystemConfiguration = true;
291 # This option defines the first version of NixOS you have installed on this particular machine,
292 # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
294 # Most users should NEVER change this value after the initial install, for any reason,
295 # even if you've upgraded your system to a new NixOS release.
297 # This value does NOT affect the Nixpkgs version your packages and OS are pulled from,
298 # so changing it will NOT upgrade your system - see https://nixos.org/manual/nixos/stable/#sec-upgrading for how
299 # to actually do that.
301 # This value being lower than the current NixOS release does NOT mean your system is
302 # out of date, out of support, or vulnerable.
304 # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration,
305 # and migrated your data accordingly.
307 # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion .
308 system.stateVersion = "24.05"; # Did you read the comment?