2020-05-01 16:50:28 +02:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.programs.steam;
|
2021-02-04 01:24:23 +01:00
|
|
|
|
|
|
|
steam = pkgs.steam.override {
|
|
|
|
extraLibraries = pkgs: with config.hardware.opengl;
|
|
|
|
if pkgs.hostPlatform.is64bit
|
|
|
|
then [ package ] ++ extraPackages
|
|
|
|
else [ package32 ] ++ extraPackages32;
|
|
|
|
};
|
2020-05-01 16:50:28 +02:00
|
|
|
in {
|
2021-02-19 20:06:01 +01:00
|
|
|
options.programs.steam = {
|
|
|
|
enable = mkEnableOption "steam";
|
|
|
|
|
|
|
|
remotePlay.openFirewall = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-07-28 23:19:15 +02:00
|
|
|
description = lib.mdDoc ''
|
2021-02-19 20:06:01 +01:00
|
|
|
Open ports in the firewall for Steam Remote Play.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
dedicatedServer.openFirewall = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-07-28 23:19:15 +02:00
|
|
|
description = lib.mdDoc ''
|
2021-02-19 20:06:01 +01:00
|
|
|
Open ports in the firewall for Source Dedicated Server.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
2020-05-01 16:50:28 +02:00
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
hardware.opengl = { # this fixes the "glXChooseVisual failed" bug, context: https://github.com/NixOS/nixpkgs/issues/47932
|
|
|
|
enable = true;
|
2021-03-02 20:17:53 +01:00
|
|
|
driSupport = true;
|
2020-05-01 16:50:28 +02:00
|
|
|
driSupport32Bit = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
# optionally enable 32bit pulseaudio support if pulseaudio is enabled
|
|
|
|
hardware.pulseaudio.support32Bit = config.hardware.pulseaudio.enable;
|
|
|
|
|
|
|
|
hardware.steam-hardware.enable = true;
|
|
|
|
|
2021-02-22 18:34:08 +01:00
|
|
|
environment.systemPackages = [ steam steam.run ];
|
2021-02-19 20:06:01 +01:00
|
|
|
|
|
|
|
networking.firewall = lib.mkMerge [
|
|
|
|
(mkIf cfg.remotePlay.openFirewall {
|
|
|
|
allowedTCPPorts = [ 27036 ];
|
|
|
|
allowedUDPPortRanges = [ { from = 27031; to = 27036; } ];
|
|
|
|
})
|
|
|
|
|
|
|
|
(mkIf cfg.dedicatedServer.openFirewall {
|
|
|
|
allowedTCPPorts = [ 27015 ]; # SRCDS Rcon port
|
|
|
|
allowedUDPPorts = [ 27015 ]; # Gameplay traffic
|
|
|
|
})
|
|
|
|
];
|
2020-05-01 16:50:28 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = with maintainers; [ mkg20001 ];
|
|
|
|
}
|