Consolidates V-Rising into the existing game-servers module instead of a separate file. Also uncomments the game-servers import in common.nix and adds UDP 9876/9877 to the shared firewall rules. https://claude.ai/code/session_01Ays1x4CUUJE1jPLkeNMojV
69 lines
2 KiB
Nix
69 lines
2 KiB
Nix
{ config, pkgs, lib, ... }:
|
|
{
|
|
config = lib.mkIf (config.networking.hostName == "FredOS-Mediaserver") {
|
|
## <----- V-RISING ----> ##
|
|
virtualisation.docker.enable = true;
|
|
|
|
systemd.tmpfiles.rules = [
|
|
"d /var/lib/v-rising 0755 root root -"
|
|
"d /var/lib/v-rising/server 0755 root root -"
|
|
"d /var/lib/v-rising/persistentdata 0755 root root -"
|
|
];
|
|
|
|
virtualisation.oci-containers = {
|
|
backend = "docker";
|
|
containers.v-rising = {
|
|
image = "trueosiris/vrising:latest";
|
|
|
|
volumes = [
|
|
"/var/lib/v-rising/server:/mnt/vrising/server"
|
|
"/var/lib/v-rising/persistentdata:/mnt/vrising/persistentdata"
|
|
];
|
|
|
|
ports = [
|
|
"9876:9876/udp"
|
|
"9877:9877/udp"
|
|
];
|
|
|
|
environment = {
|
|
TZ = "Europe/Stockholm";
|
|
SERVERNAME = "FredOS V-Rising";
|
|
WORLDNAME = "world1";
|
|
# SERVERPASSWORD = "";
|
|
};
|
|
};
|
|
};
|
|
|
|
## <----- HYTALE ----> ##
|
|
systemd.services.hytale-server = {
|
|
description = "Hytale Dedicated Server";
|
|
wantedBy = [ "multi-user.target" ];
|
|
after = [ "network.target" ];
|
|
|
|
path = with pkgs; [ bash jdk unzip gawk gnugrep coreutils screen ]; # Added screen
|
|
|
|
environment = {
|
|
HYTALE_MEMORY = "8G";
|
|
};
|
|
|
|
serviceConfig = {
|
|
Type = "forking"; # Changed from "simple"
|
|
User = "fred";
|
|
Group = "users";
|
|
WorkingDirectory = "/home/fred/docker/hytale-server/Server";
|
|
ExecStart = "${pkgs.screen}/bin/screen -dmS hytale /home/fred/docker/hytale-server/start-hytale.sh";
|
|
ExecStop = "${pkgs.screen}/bin/screen -S hytale -X stuff 'stop^M'";
|
|
RemainAfterExit = "yes";
|
|
Restart = "on-failure";
|
|
RestartSec = "10s";
|
|
TimeoutStopSec = "30s";
|
|
|
|
# Security hardening
|
|
NoNewPrivileges = true;
|
|
PrivateTmp = true;
|
|
};
|
|
};
|
|
|
|
networking.firewall.allowedUDPPorts = [ 5520 9876 9877 ];
|
|
};
|
|
}
|