mirror of
https://github.com/SebastianStork/nixos-config.git
synced 2026-01-21 15:11:34 +01:00
meta/ports: Separate tcp and udp lists to avoid false conflicts
This commit is contained in:
parent
b51d0d095d
commit
e288bb2bf3
19 changed files with 61 additions and 32 deletions
|
|
@ -10,7 +10,11 @@ let
|
|||
in
|
||||
{
|
||||
options.meta.ports = {
|
||||
list = lib.mkOption {
|
||||
tcp.list = lib.mkOption {
|
||||
type = lib.types.listOf lib.types.port;
|
||||
default = [ ];
|
||||
};
|
||||
udp.list = lib.mkOption {
|
||||
type = lib.types.listOf lib.types.port;
|
||||
default = [ ];
|
||||
};
|
||||
|
|
@ -20,8 +24,9 @@ in
|
|||
config = lib.mkIf cfg.assertUnique {
|
||||
assertions =
|
||||
let
|
||||
duplicatePorts =
|
||||
options.meta.ports.list.definitionsWithLocations
|
||||
findDuplicatePorts =
|
||||
protocol:
|
||||
options.meta.ports.${protocol}.list.definitionsWithLocations
|
||||
|> lib.concatMap (
|
||||
entry:
|
||||
entry.value
|
||||
|
|
@ -33,7 +38,8 @@ in
|
|||
|> lib.groupBy (entry: builtins.toString entry.port)
|
||||
|> lib.filterAttrs (_: entries: lib.length entries > 1);
|
||||
|
||||
errorMessage =
|
||||
mkErrorMessage =
|
||||
duplicatePorts:
|
||||
duplicatePorts
|
||||
|> lib.mapAttrsToList (
|
||||
port: entries:
|
||||
|
|
@ -41,11 +47,19 @@ in
|
|||
+ (entries |> lib.map (entry: " - ${entry.file}") |> lib.concatLines)
|
||||
)
|
||||
|> lib.concatStrings;
|
||||
|
||||
duplicateTcpPorts = findDuplicatePorts "tcp";
|
||||
|
||||
duplicateUdpPorts = findDuplicatePorts "udp";
|
||||
in
|
||||
[
|
||||
{
|
||||
assertion = duplicatePorts == { };
|
||||
message = errorMessage;
|
||||
assertion = duplicateTcpPorts == { };
|
||||
message = mkErrorMessage duplicateTcpPorts;
|
||||
}
|
||||
{
|
||||
assertion = duplicateUdpPorts == { };
|
||||
message = mkErrorMessage duplicateUdpPorts;
|
||||
}
|
||||
];
|
||||
};
|
||||
|
|
|
|||
|
|
@ -12,14 +12,14 @@ in
|
|||
};
|
||||
port = lib.mkOption {
|
||||
type = lib.types.port;
|
||||
default = 8888;
|
||||
default = 5006;
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
services.actual = {
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
services.alloy = {
|
||||
|
|
|
|||
|
|
@ -81,7 +81,7 @@ in
|
|||
config = lib.mkIf (virtualHosts != { }) (
|
||||
lib.mkMerge [
|
||||
{
|
||||
meta.ports.list = lib.mkIf nonTailscaleHostsExist ports;
|
||||
meta.ports.tcp.list = lib.mkIf nonTailscaleHostsExist ports;
|
||||
|
||||
networking.firewall.allowedTCPPorts = lib.mkIf nonTailscaleHostsExist ports;
|
||||
|
||||
|
|
|
|||
|
|
@ -36,7 +36,7 @@ in
|
|||
};
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
meta.ports.list = [
|
||||
meta.ports.tcp.list = [
|
||||
cfg.apiPort
|
||||
cfg.prometheusPort
|
||||
];
|
||||
|
|
|
|||
|
|
@ -24,7 +24,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
sops.secrets."forgejo/admin-password".owner = config.users.users.forgejo.name;
|
||||
|
|
|
|||
|
|
@ -12,7 +12,7 @@ in
|
|||
};
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
meta.ports.list = [ cfg.port ];
|
||||
meta.ports.tcp.list = [ cfg.port ];
|
||||
|
||||
services.forgejo.settings.server.SSH_PORT = cfg.port;
|
||||
|
||||
|
|
|
|||
|
|
@ -75,7 +75,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
sops = {
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
sops.secrets."grafana/admin-password".owner = config.users.users.grafana.name;
|
||||
|
|
|
|||
|
|
@ -24,7 +24,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
sops = {
|
||||
|
|
|
|||
|
|
@ -23,7 +23,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
services.static-web-server = {
|
||||
|
|
|
|||
|
|
@ -27,7 +27,10 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports = {
|
||||
tcp.list = [ cfg.port ];
|
||||
udp.list = [ config.services.postgresql.settings.port ];
|
||||
};
|
||||
};
|
||||
|
||||
sops.secrets."nextcloud/admin-password".owner = user;
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
services.ntfy-sh = {
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
virtualisation.oci-containers.containers.openspeedtest = {
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
sops = {
|
||||
|
|
|
|||
|
|
@ -3,11 +3,18 @@
|
|||
options.custom.services.resolved.enable = lib.mkEnableOption "";
|
||||
|
||||
config = lib.mkIf config.custom.services.resolved.enable {
|
||||
meta.ports.list = [
|
||||
53
|
||||
5353
|
||||
5355
|
||||
];
|
||||
meta.ports =
|
||||
let
|
||||
ports = [
|
||||
53
|
||||
5353
|
||||
5355
|
||||
];
|
||||
in
|
||||
{
|
||||
tcp.list = ports;
|
||||
udp.list = ports;
|
||||
};
|
||||
|
||||
services.resolved.enable = true;
|
||||
};
|
||||
|
|
|
|||
|
|
@ -49,10 +49,13 @@ in
|
|||
|
||||
meta = {
|
||||
domains.list = lib.mkIf cfg.isServer [ cfg.gui.domain ];
|
||||
ports.list = [
|
||||
cfg.syncPort
|
||||
cfg.gui.port
|
||||
];
|
||||
ports = {
|
||||
tcp.list = [
|
||||
cfg.syncPort
|
||||
cfg.gui.port
|
||||
];
|
||||
udp.list = [ cfg.syncPort ];
|
||||
};
|
||||
};
|
||||
|
||||
sops.secrets = lib.mkIf useStaticTls {
|
||||
|
|
|
|||
|
|
@ -14,7 +14,9 @@ in
|
|||
};
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
meta.ports.list = [ config.services.tailscale.port ];
|
||||
meta.ports.udp.list = lib.mkIf config.services.tailscale.openFirewall [
|
||||
config.services.tailscale.port
|
||||
];
|
||||
|
||||
sops.secrets."tailscale/auth-key" = { };
|
||||
|
||||
|
|
|
|||
|
|
@ -27,7 +27,7 @@ in
|
|||
config = lib.mkIf cfg.enable {
|
||||
meta = {
|
||||
domains.list = [ cfg.domain ];
|
||||
ports.list = [ cfg.port ];
|
||||
ports.tcp.list = [ cfg.port ];
|
||||
};
|
||||
|
||||
services.victorialogs = {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue