2019-02-02 19:45:05 +00:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
let
|
|
|
|
secrets = import ./secrets.nix;
|
|
|
|
hostname = "code.dumpstack.io";
|
|
|
|
in {
|
|
|
|
imports = [ ./hardware-configuration.nix ];
|
|
|
|
|
|
|
|
boot.loader.grub.enable = true;
|
|
|
|
boot.loader.grub.version = 2;
|
|
|
|
boot.loader.grub.device = "/dev/vda";
|
|
|
|
|
|
|
|
networking.hostName = "${hostname}";
|
|
|
|
|
|
|
|
networking.firewall = {
|
|
|
|
enable = true;
|
|
|
|
allowedTCPPorts = [ 80 443 ];
|
|
|
|
};
|
|
|
|
|
|
|
|
users.extraUsers.root = {
|
|
|
|
openssh.authorizedKeys.keys = [ secrets.pubkey ];
|
|
|
|
};
|
|
|
|
|
|
|
|
services.openssh.enable = true;
|
|
|
|
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
vim
|
|
|
|
];
|
|
|
|
|
|
|
|
services.gitea = {
|
|
|
|
enable = true;
|
|
|
|
appName = "${hostname}";
|
|
|
|
domain = "${hostname}";
|
|
|
|
rootUrl = "https://${hostname}";
|
|
|
|
extraConfig = ''
|
|
|
|
[service]
|
|
|
|
DISABLE_REGISTRATION = true
|
|
|
|
|
|
|
|
[ui]
|
2019-04-12 17:24:06 +00:00
|
|
|
DEFAULT_THEME = gitea
|
2019-02-02 19:45:05 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
services.nginx = {
|
|
|
|
enable = true;
|
|
|
|
virtualHosts."${hostname}" = {
|
|
|
|
enableACME = true;
|
|
|
|
forceSSL = true;
|
|
|
|
|
|
|
|
locations."/".proxyPass = "http://127.0.0.1:3000";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2019-04-12 17:24:45 +00:00
|
|
|
systemd.services.nixos-upgrade.serviceConfig.ExecStartPost = pkgs.writeScript "post-upgrade-check" ''
|
|
|
|
#!${pkgs.stdenv.shell}
|
|
|
|
current=$(readlink -f /run/current-system/kernel)
|
|
|
|
booted=$(readlink -f /run/booted-system/kernel)
|
|
|
|
if [ "$current" != "$booted" ]; then
|
|
|
|
echo "kernel changed, reboot" | systemd-cat --identifier "post-upgrade-check";
|
|
|
|
reboot
|
|
|
|
else
|
|
|
|
echo "same kernel, do not reboot" | systemd-cat --identifier "post-upgrade-check";
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
|
2019-02-02 19:45:05 +00:00
|
|
|
system.stateVersion = "18.09";
|
|
|
|
system.autoUpgrade.enable = true;
|
|
|
|
}
|