2023-11-04 10:14:42 +00:00
|
|
|
{
|
|
|
|
pkgs,
|
|
|
|
config,
|
|
|
|
...
|
|
|
|
}: let
|
2023-11-04 10:02:11 +00:00
|
|
|
etcDirectory = "hysteria";
|
|
|
|
port = 43956;
|
2023-11-04 10:14:42 +00:00
|
|
|
in {
|
2023-11-04 10:02:11 +00:00
|
|
|
imports = [
|
2023-11-17 05:38:25 +00:00
|
|
|
../../../../../../nixos/flake-modules/sops-nix.nix
|
2023-11-04 10:02:11 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
### Firewall
|
|
|
|
networking.firewall = {
|
2023-11-04 10:14:42 +00:00
|
|
|
allowedTCPPorts = [port 80 443];
|
|
|
|
allowedUDPPorts = [port 80 443];
|
2023-11-04 10:02:11 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#### sops-nix
|
|
|
|
sops.secrets."hysteria-config" = {
|
|
|
|
owner = config.users.users."hysteria".name;
|
|
|
|
group = config.users.groups."hysteria".name;
|
2023-11-04 10:14:42 +00:00
|
|
|
restartUnits = ["hysteria-server.service"];
|
2023-11-04 10:02:11 +00:00
|
|
|
path = "/etc/${etcDirectory}/config.yaml";
|
|
|
|
};
|
|
|
|
|
|
|
|
### User running proxy service
|
|
|
|
users.groups."hysteria" = {};
|
|
|
|
users.users."hysteria" = {
|
|
|
|
isSystemUser = true;
|
|
|
|
group = config.users.groups."hysteria".name;
|
|
|
|
};
|
|
|
|
|
|
|
|
### Proxy service
|
|
|
|
systemd.services."hysteria-server" = {
|
|
|
|
description = "Hysteria Server";
|
2023-11-04 10:14:42 +00:00
|
|
|
after = ["network.target"];
|
2023-11-04 10:02:11 +00:00
|
|
|
|
2023-11-04 10:14:42 +00:00
|
|
|
wantedBy = ["multi-user.target"];
|
2023-11-04 10:02:11 +00:00
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "simple";
|
|
|
|
WorkingDirectory = "/etc/${etcDirectory}";
|
2023-11-04 10:14:42 +00:00
|
|
|
User = [config.users.users."hysteria".name];
|
|
|
|
Group = [config.users.groups."hysteria".name];
|
2023-11-04 10:02:11 +00:00
|
|
|
ExecStart = "${pkgs.hysteria}/bin/hysteria server --config /etc/${etcDirectory}/config.yaml";
|
|
|
|
Restart = "on-failure";
|
|
|
|
CapabilityBoundingSet = [
|
|
|
|
"CAP_NET_ADMIN"
|
|
|
|
"CAP_NET_BIND_SERVICE"
|
|
|
|
"CAP_NET_RAW"
|
|
|
|
];
|
|
|
|
AmbientCapabilities = [
|
|
|
|
"CAP_NET_ADMIN"
|
|
|
|
"CAP_NET_BIND_SERVICE"
|
|
|
|
"CAP_NET_RAW"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
2023-11-04 10:14:42 +00:00
|
|
|
}
|