diff options
Diffstat (limited to 'modules/server')
| -rw-r--r-- | modules/server/default.nix | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/modules/server/default.nix b/modules/server/default.nix new file mode 100644 index 0000000..7fb1e76 --- /dev/null +++ b/modules/server/default.nix @@ -0,0 +1,60 @@ +{ + config, + lib, + pkgs, + ... +}: let + cfg = config.server; + inherit (lib) mkDefault mkEnableOption mkIf; +in { + options.server.enable = mkEnableOption "enable server configuration"; + + config = mkIf cfg.enable { + base = { + enable = true; + documentation.enable = mkDefault false; + defaultPackages.enable = mkDefault false; + }; + + environment.systemPackages = [pkgs.cachix]; + + nixos = { + enable = true; + networking.enable = false; + }; + + networking = { + firewall = let + ports = [80 420]; + in { + allowedUDPPorts = ports; + allowedTCPPorts = ports; + }; + }; + + nix.gc.options = "--delete-older-than 7d --max-freed 50G"; + + programs = { + git.enable = true; + vim.defaultEditor = true; + }; + + security = { + pam.enableSSHAgentAuth = true; + }; + + services = { + endlessh = { + enable = true; + port = 22; + openFirewall = true; + }; + + openssh = { + enable = true; + passwordAuthentication = false; + ports = [420]; + }; + }; + }; +} |
