feat(nixosModules/server): add nginx
This commit is contained in:
parent
d478e9009f
commit
5ba9667f4e
4 changed files with 28 additions and 34 deletions
|
@ -1,24 +0,0 @@
|
|||
{ config, lib, ... }:
|
||||
let
|
||||
cfg = config.server.reverse-proxy;
|
||||
in
|
||||
{
|
||||
options.server.reverse-proxy = {
|
||||
enable = lib.mkEnableOption "";
|
||||
type = lib.pantheon.mkStrOption;
|
||||
proxies = lib.mkOption {
|
||||
type = lib.types.listOf lib.types.attrs;
|
||||
default = [ ];
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf cfg.enable (
|
||||
lib.mkMerge [
|
||||
(lib.mkIf (cfg.type == "nginx") {
|
||||
services.nginx = {
|
||||
enable = true;
|
||||
};
|
||||
})
|
||||
]
|
||||
);
|
||||
}
|
27
modules/nixos/server/web-servers/default.nix
Normal file
27
modules/nixos/server/web-servers/default.nix
Normal file
|
@ -0,0 +1,27 @@
|
|||
{ config, lib, ... }:
|
||||
let
|
||||
cfg = config.server.web-servers;
|
||||
in
|
||||
{
|
||||
options.server.web-servers = {
|
||||
nginx = {
|
||||
enable = lib.mkEnableOption "the Nginx server";
|
||||
};
|
||||
};
|
||||
config = lib.mkMerge [
|
||||
(lib.mkIf cfg.nginx.enable {
|
||||
networking.firewall.allowedTCPPorts = [ 80 ];
|
||||
services.nginx = {
|
||||
enable = true;
|
||||
virtualHosts.${config.system.hostname} = {
|
||||
locations."/" = {
|
||||
return = "200 '<html><body>It works!</body></html'";
|
||||
extraConfig = ''
|
||||
default_type text/html;
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
})
|
||||
];
|
||||
}
|
|
@ -25,6 +25,7 @@
|
|||
databases.mongodb.enable = true;
|
||||
databases.mysql.enable = true;
|
||||
librechat.enable = true;
|
||||
web-servers.nginx.enable = true;
|
||||
};
|
||||
|
||||
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
|
||||
|
|
|
@ -42,16 +42,6 @@
|
|||
|
||||
server = {
|
||||
mountHelios = true;
|
||||
reverse-proxy = {
|
||||
enable = true;
|
||||
type = "nginx";
|
||||
proxies = [
|
||||
{
|
||||
source = "chat.bwfiq.com";
|
||||
target = "";
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue