summaryrefslogtreecommitdiffstats
path: root/nixos/modules/services/web-servers
diff options
context:
space:
mode:
authorRyan Lahfa <masterancpp@gmail.com>2023-12-12 14:05:33 +0100
committerGitHub <noreply@github.com>2023-12-12 14:05:33 +0100
commit3bb93fb2cd3cb72f54e477b828a0fc717676fa51 (patch)
treefa44d5eaa2b12b928f4fcd6b5e0a91371e4239be /nixos/modules/services/web-servers
parent7fe7e5a3463a4e87e42c1417cd61c84f2b9d2ca8 (diff)
parenta3c60d2ddc9f70dca3fa5c5926aefc9a74bd2519 (diff)
Merge pull request #271506 from Misterio77/nginx-redirect-status-code
Diffstat (limited to 'nixos/modules/services/web-servers')
-rw-r--r--nixos/modules/services/web-servers/nginx/default.nix4
-rw-r--r--nixos/modules/services/web-servers/nginx/vhost-options.nix25
2 files changed, 21 insertions, 8 deletions
diff --git a/nixos/modules/services/web-servers/nginx/default.nix b/nixos/modules/services/web-servers/nginx/default.nix
index eafaa32f5b9b..6ea24e65f220 100644
--- a/nixos/modules/services/web-servers/nginx/default.nix
+++ b/nixos/modules/services/web-servers/nginx/default.nix
@@ -377,7 +377,7 @@ let
server_name ${vhost.serverName} ${concatStringsSep " " vhost.serverAliases};
${acmeLocation}
location / {
- return 301 https://$host$request_uri;
+ return ${toString vhost.redirectCode} https://$host$request_uri;
}
}
''}
@@ -396,7 +396,7 @@ let
${optionalString (vhost.root != null) "root ${vhost.root};"}
${optionalString (vhost.globalRedirect != null) ''
location / {
- return 301 http${optionalString hasSSL "s"}://${vhost.globalRedirect}$request_uri;
+ return ${toString vhost.redirectCode} http${optionalString hasSSL "s"}://${vhost.globalRedirect}$request_uri;
}
''}
${optionalString hasSSL ''
diff --git a/nixos/modules/services/web-servers/nginx/vhost-options.nix b/nixos/modules/services/web-servers/nginx/vhost-options.nix
index 9db4c8e23025..64a95afab9f4 100644
--- a/nixos/modules/services/web-servers/nginx/vhost-options.nix
+++ b/nixos/modules/services/web-servers/nginx/vhost-options.nix
@@ -162,10 +162,11 @@ with lib;
type = types.bool;
default = false;
description = lib.mdDoc ''
- Whether to add a separate nginx server block that permanently redirects (301)
- all plain HTTP traffic to HTTPS. This will set defaults for
- `listen` to listen on all interfaces on the respective default
- ports (80, 443), where the non-SSL listens are used for the redirect vhosts.
+ Whether to add a separate nginx server block that redirects (defaults
+ to 301, configurable with `redirectCode`) all plain HTTP traffic to
+ HTTPS. This will set defaults for `listen` to listen on all interfaces
+ on the respective default ports (80, 443), where the non-SSL listens
+ are used for the redirect vhosts.
'';
};
@@ -307,8 +308,20 @@ with lib;
default = null;
example = "newserver.example.org";
description = lib.mdDoc ''
- If set, all requests for this host are redirected permanently to
- the given hostname.
+ If set, all requests for this host are redirected (defaults to 301,
+ configurable with `redirectCode`) to the given hostname.
+ '';
+ };
+
+ redirectCode = mkOption {
+ type = types.ints.between 300 399;
+ default = 301;
+ example = 308;
+ description = lib.mdDoc ''
+ HTTP status used by `globalRedirect` and `forceSSL`. Possible usecases
+ include temporary (302, 307) redirects, keeping the request method and
+ body (307, 308), or explicitly resetting the method to GET (303).
+ See <https://developer.mozilla.org/en-US/docs/Web/HTTP/Redirections>.
'';
};