diff options
| author | Caroline Larimore <caroline@larimo.re> | 2025-04-14 19:01:38 -0700 |
|---|---|---|
| committer | Caroline Larimore <caroline@larimo.re> | 2025-04-14 19:01:38 -0700 |
| commit | e8077fde966e051fc449fffcfa061c7f7edc47b0 (patch) | |
| tree | a0b1ce60f2718f90c64e924ed8df8d5d4f0d2289 /modules/nixos/services/minecraft | |
| parent | e486d896215e7ef04438809952bc7317512d5765 (diff) | |
migration: finalize
Diffstat (limited to 'modules/nixos/services/minecraft')
| -rw-r--r-- | modules/nixos/services/minecraft/default.nix | 25 | ||||
| -rw-r--r-- | modules/nixos/services/minecraft/stargazers/default.nix | 83 | ||||
| -rw-r--r-- | modules/nixos/services/minecraft/zenith/default.nix | 21 |
3 files changed, 129 insertions, 0 deletions
diff --git a/modules/nixos/services/minecraft/default.nix b/modules/nixos/services/minecraft/default.nix new file mode 100644 index 0000000..7705c1c --- /dev/null +++ b/modules/nixos/services/minecraft/default.nix @@ -0,0 +1,25 @@ +{ options, config, lib, namespace, inputs, ... }: + +with lib; with lib.${namespace}; let + cfg = config.${namespace}.services.minecraft; + impermanence = config.${namespace}.system.impermanence; +in { + options.${namespace}.services.minecraft = with types; { + enable = mkEnableOption "minecraft server support"; + }; + + config = mkIf cfg.enable { + nixpkgs = { + overlays = [ inputs.nix-minecraft.overlay ]; + config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ + "minecraft-server" + ]; + }; + + services.minecraft-servers = { + enable = true; + eula = true; + openFirewall = true; + }; + }; +} diff --git a/modules/nixos/services/minecraft/stargazers/default.nix b/modules/nixos/services/minecraft/stargazers/default.nix new file mode 100644 index 0000000..cb934f8 --- /dev/null +++ b/modules/nixos/services/minecraft/stargazers/default.nix @@ -0,0 +1,83 @@ +{ options, config, lib, pkgs, namespace, ... }: + +with lib; with lib.${namespace}; let + cfg = config.${namespace}.services.minecraft.stargazers; + impermanence = config.${namespace}.system.impermanence; +in { + options.${namespace}.services.minecraft.stargazers = with types; { + enable = mkEnableOption "stargazers minecraft server"; + + port = mkOption { + type = types.port; + default = 25565; + description = "server port"; + }; + + start = mkOption { + type = types.bool; + default = true; + description = "autostart"; + }; + }; + + config = mkIf cfg.enable { + cxl.services.minecraft.enable = true; + + #TODO: enable tmux + #cxl.tools.tmux.enable = true; + + environment.persistence.${impermanence.location} = { + directories = [ + "/srv/minecraft/stargazers" + ]; + }; + + services.minecraft-servers.servers.stargazers = { + enable = true; + openFirewall = true; + autoStart = cfg.start; + + package = pkgs.fabricServers.fabric-1_21; + + operators = { + "grippysockjail" = "9448c89d-34eb-4e2c-a231-8112eb1a9e4a"; + "antonymph" = "6b1f7a3c-a1c3-491a-8514-12b6b90d9152"; + }; + + serverProperties = { + white-list = true; + enforce-whitelist = true; + + gamemode = "survival"; + difficulty = "hard"; + level-seed = "4167799982467607063"; + spawn-protection = 0; + + max-players = 69; + motd = "\\u00a7r \\u00a75\\u00a7lstrge gazrer\\u00a7r\\n join or i will rip your bones out and eat them"; + + server-port = cfg.port; + query-port = cfg.port; + }; + + symlinks.mods = pkgs.linkFarmFromDrvs "mods" (builtins.attrValues { + fabric = pkgs.fetchurl { + url = "https://cdn.modrinth.com/data/P7dR8mSH/versions/vMQdA5QJ/fabric-api-0.100.7%2B1.21.jar"; + sha256 = "sha256-grNmYgSekBaTztR1SLbqZCOC6+QNUDLe4hp105qfibA="; + }; + lithium = pkgs.fetchurl { + url = "https://cdn.modrinth.com/data/gvQqBUqZ/versions/my7uONjU/lithium-fabric-mc1.21-0.12.7.jar"; + sha256 = "sha256-Qku6c545jVgrdxDSNe3BULVQlMtgGuXebNqirRcmsh0="; + }; + noChatReports = pkgs.fetchurl { + url = "https://cdn.modrinth.com/data/qQyHxfxd/versions/riMhCAII/NoChatReports-FABRIC-1.21-v2.8.0.jar"; + sha256 = "sha256-jskscOeK3ri2dt3mvWLPVmzddwPqBHJ8Ps+VfZ6l9os="; + }; + appleskin = pkgs.fetchurl { + url = "https://cdn.modrinth.com/data/EsAfCjCV/versions/YxFxnyd4/appleskin-fabric-mc1.21-3.0.2.jar"; + sha256 = "sha256-8XaZREWzA5Mi2/LTs/a6ACvDKmHWYIy8JcOfQaq4yiE="; + }; + }); + }; + }; +} diff --git a/modules/nixos/services/minecraft/zenith/default.nix b/modules/nixos/services/minecraft/zenith/default.nix new file mode 100644 index 0000000..0bc19f7 --- /dev/null +++ b/modules/nixos/services/minecraft/zenith/default.nix @@ -0,0 +1,21 @@ +{ options, config, lib, pkgs, namespace, ... }: + +#TODO: nix-ify zenithproxy +with lib; with lib.${namespace}; let + cfg = config.${namespace}.services.minecraft.zenith; + impermanence = config.${namespace}.system.impermanence; +in { + options.${namespace}.services.minecraft.zenith = with types; { + enable = mkEnableOption "zenithproxy server"; + + port = mkOption { + type = types.port; + default = 25565; + description = "server port"; + }; + }; + + config = mkIf cfg.enable { + networking.firewall.allowedTCPPorts = mkIf cfg.openFirewall [ cfg.port ]; + }; +} |