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, ... }:
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;
24 networking.hostName = "nixos"; # Define your hostname.
25 # Pick only one of the below networking options.
26 # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
27 # networking.networkmanager.enable = true; # Easiest to use and most distros use this by default.
29 networking.firewall = {
31 allowedTCPPorts = [ 80 443 9418 ];
35 time.timeZone = "Europe/Amsterdam";
37 # Configure network proxy if necessary
38 # networking.proxy.default = "http://user:password@proxy:port/";
39 # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
41 # Select internationalisation properties.
42 i18n.defaultLocale = "de_DE.UTF-8";
44 font = "Lat2-Terminus16";
45 keyMap = "de-latin1-nodeadkeys";
46 # useXkbConfig = true; # use xkb.options in tty.
49 # Enable the X11 windowing system.
50 # services.xserver.enable = true;
52 # Configure keymap in X11
53 # services.xserver.xkb.layout = "us";
54 # services.xserver.xkb.options = "eurosign:e,caps:escape";
56 # Enable CUPS to print documents.
57 # services.printing.enable = true;
60 # hardware.pulseaudio.enable = true;
62 # services.pipewire = {
64 # pulse.enable = true;
67 # Enable touchpad support (enabled default in most desktopManager).
68 # services.libinput.enable = true;
70 # Define a user account. Don't forget to set a password with ‘passwd’.
73 extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user.
74 packages = with pkgs; [
80 sudo.wheelNeedsPassword = false;
83 # nixpkgs.config.allowUnfree = true;
85 # List packages installed in system profile. To search, run:
87 environment.systemPackages = with pkgs; [
88 vim neovim wget file git
105 shell = "${pkgs.git}/bin/git-shell";
106 openssh.authorizedKeys.keys = [
107 "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICQOPefMnq0qvFjYxlrdlSmUgyCbvV85gkfRykVlTnrn ps@nixos"
110 users.groups.git = {};
115 init.defaultBranch = "main";
116 user.name = "Patrick";
117 user.email = "patrick.schoenberger@posteo.de";
121 # Some programs need SUID wrappers, can be configured further or are
122 # started in user sessions.
123 # programs.mtr.enable = true;
124 # programs.gnupg.agent = {
126 # enableSSHSupport = true;
129 # List services that you want to enable:
131 # Enable the OpenSSH daemon.
136 AllowTcpForwarding no
137 AllowAgentForwarding no
138 PasswordAuthentication no
143 services.qemuGuest.enable = true;
144 # virtualisation.qemu.guestAgent.enable = true;
148 virtualHosts."psch.dev".extraConfig = ''
151 virtualHosts."chirp.psch.dev".extraConfig = ''
152 reverse_proxy http://localhost:8080
154 protocols tls1.3 tls1.3
159 services.dbus.enable = true;
161 # virtualHosts."git.psch.dev".extraConfig = ''
162 # reverse_proxy unix//run/fcgiwrap.socket {
163 # transport fastcgi {
173 # services."cgit".cgit = {
175 # scanPath = "/srv/git";
178 # Open ports in the firewall.
179 # networking.firewall.allowedTCPPorts = [ ... ];
180 # networking.firewall.allowedUDPPorts = [ ... ];
181 # Or disable the firewall altogether.
182 # networking.firewall.enable = false;
184 # Copy the NixOS configuration file and link it from the resulting system
185 # (/run/current-system/configuration.nix). This is useful in case you
186 # accidentally delete configuration.nix.
187 # system.copySystemConfiguration = true;
189 # This option defines the first version of NixOS you have installed on this particular machine,
190 # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
192 # Most users should NEVER change this value after the initial install, for any reason,
193 # even if you've upgraded your system to a new NixOS release.
195 # This value does NOT affect the Nixpkgs version your packages and OS are pulled from,
196 # so changing it will NOT upgrade your system - see https://nixos.org/manual/nixos/stable/#sec-upgrading for how
197 # to actually do that.
199 # This value being lower than the current NixOS release does NOT mean your system is
200 # out of date, out of support, or vulnerable.
202 # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration,
203 # and migrated your data accordingly.
205 # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion .
206 system.stateVersion = "24.05"; # Did you read the comment?