95 lines
2.5 KiB
Nix
95 lines
2.5 KiB
Nix
all: {
|
|
config,
|
|
pkgs,
|
|
lib,
|
|
options,
|
|
...
|
|
}: {
|
|
imports = [all];
|
|
|
|
boot.loader = {
|
|
efi.canTouchEfiVariables = lib.mkDefault true;
|
|
systemd-boot.editor = lib.mkDefault false;
|
|
grub.extraConfig = lib.mkIf (!config.boot.loader.systemd-boot.editor) ''
|
|
set superusers=""
|
|
'';
|
|
};
|
|
|
|
security.rtkit.enable = lib.mkDefault true;
|
|
|
|
services.earlyoom.enable = lib.mkDefault true;
|
|
|
|
programs.mosh.enable = lib.mkDefault true;
|
|
|
|
systemd.services.nix-gc.serviceConfig.IOSchedulingPriority =
|
|
lib.mkDefault 7;
|
|
systemd.services.nix-gc.serviceConfig.IOSchedulingClass =
|
|
lib.mkDefault "idle";
|
|
systemd.services.nix-gc.serviceConfig.CPUSchedulingPolicy =
|
|
lib.mkDefault "idle";
|
|
|
|
nix = {
|
|
gc = {
|
|
automatic = lib.mkDefault true;
|
|
dates = lib.mkDefault "20:00";
|
|
options = lib.mkDefault "--delete-older-than 40d";
|
|
};
|
|
|
|
daemonIOSchedPriority = lib.mkDefault 7;
|
|
daemonIOSchedClass = lib.mkDefault "idle";
|
|
daemonCPUSchedPolicy = lib.mkDefault "idle";
|
|
|
|
settings = {
|
|
trusted-users = ["root" "builder" "@wheel"];
|
|
builders-use-substitutes = true;
|
|
experimental-features = ["nix-command" "flakes"];
|
|
};
|
|
};
|
|
|
|
# make nginx have good logging and defaults
|
|
services.nginx = {
|
|
recommendedGzipSettings = lib.mkDefault true;
|
|
recommendedOptimisation = lib.mkDefault true;
|
|
recommendedProxySettings = lib.mkDefault true;
|
|
appendHttpConfig = ''
|
|
error_log stderr;
|
|
access_log syslog:server=unix:/dev/log combined;
|
|
'';
|
|
};
|
|
|
|
# set some basic system props
|
|
security.sudo.wheelNeedsPassword = lib.mkDefault false;
|
|
networking.networkmanager.enable = lib.mkDefault true;
|
|
|
|
# package list
|
|
environment.systemPackages = with pkgs; [
|
|
exfat
|
|
|
|
# to stop NixOS breaking
|
|
git
|
|
];
|
|
|
|
services.openssh = {
|
|
# Allow ssh
|
|
enable = lib.mkDefault true;
|
|
# lol no
|
|
settings.PermitRootLogin = lib.mkDefault "no";
|
|
settings.PasswordAuthentication = lib.mkDefault false;
|
|
# allow reverse ssh port shit to be public sometimes
|
|
settings.GatewayPorts = lib.mkDefault "clientspecified";
|
|
extraConfig = ''
|
|
StreamLocalBindUnlink yes
|
|
'';
|
|
};
|
|
|
|
# Use a firewall
|
|
networking.firewall.enable = lib.mkDefault true;
|
|
networking.firewall.allowPing = true;
|
|
networking.firewall.allowedTCPPorts = lib.mkDefault [22];
|
|
# but not too much, don't break VPNs etc
|
|
networking.firewall.checkReversePath = "loose";
|
|
|
|
programs.fish.enable = lib.mkDefault true;
|
|
users.defaultUserShell = lib.mkOverride 900 pkgs.fish;
|
|
}
|