2018-01-04 17:19:54 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.mighttpd2;
|
|
|
|
configFile = pkgs.writeText "mighty-config" cfg.config;
|
|
|
|
routingFile = pkgs.writeText "mighty-routing" cfg.routing;
|
|
|
|
in {
|
|
|
|
options.services.mighttpd2 = {
|
2024-04-13 12:54:15 +00:00
|
|
|
enable = mkEnableOption "Mighttpd2 web server";
|
2018-01-04 17:19:54 +00:00
|
|
|
|
|
|
|
config = mkOption {
|
|
|
|
default = "";
|
|
|
|
example = ''
|
|
|
|
# Example configuration for Mighttpd 2
|
|
|
|
Port: 80
|
|
|
|
# IP address or "*"
|
|
|
|
Host: *
|
|
|
|
Debug_Mode: Yes # Yes or No
|
|
|
|
# If available, "nobody" is much more secure for User:.
|
|
|
|
User: root
|
|
|
|
# If available, "nobody" is much more secure for Group:.
|
|
|
|
Group: root
|
2018-12-19 21:42:48 +00:00
|
|
|
Pid_File: /run/mighty.pid
|
2018-01-04 17:19:54 +00:00
|
|
|
Logging: Yes # Yes or No
|
|
|
|
Log_File: /var/log/mighty # The directory must be writable by User:
|
|
|
|
Log_File_Size: 16777216 # bytes
|
|
|
|
Log_Backup_Number: 10
|
|
|
|
Index_File: index.html
|
|
|
|
Index_Cgi: index.cgi
|
|
|
|
Status_File_Dir: /usr/local/share/mighty/status
|
|
|
|
Connection_Timeout: 30 # seconds
|
|
|
|
Fd_Cache_Duration: 10 # seconds
|
|
|
|
# Server_Name: Mighttpd/3.x.y
|
|
|
|
Tls_Port: 443
|
|
|
|
Tls_Cert_File: cert.pem # should change this with an absolute path
|
|
|
|
# should change this with comma-separated absolute paths
|
|
|
|
Tls_Chain_Files: chain.pem
|
|
|
|
# Currently, Tls_Key_File must not be encrypted.
|
|
|
|
Tls_Key_File: privkey.pem # should change this with an absolute path
|
|
|
|
Service: 0 # 0 is HTTP only, 1 is HTTPS only, 2 is both
|
|
|
|
'';
|
|
|
|
type = types.lines;
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2018-01-04 17:19:54 +00:00
|
|
|
Verbatim config file to use
|
2023-10-30 20:41:44 +00:00
|
|
|
(see https://kazu-yamamoto.github.io/mighttpd2/config.html)
|
2018-01-04 17:19:54 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
routing = mkOption {
|
|
|
|
default = "";
|
|
|
|
example = ''
|
|
|
|
# Example routing for Mighttpd 2
|
|
|
|
|
|
|
|
# Domain lists
|
|
|
|
[localhost www.example.com]
|
|
|
|
|
|
|
|
# Entries are looked up in the specified order
|
|
|
|
# All paths must end with "/"
|
|
|
|
|
|
|
|
# A path to CGI scripts should be specified with "=>"
|
|
|
|
/~alice/cgi-bin/ => /home/alice/public_html/cgi-bin/
|
|
|
|
|
|
|
|
# A path to static files should be specified with "->"
|
|
|
|
/~alice/ -> /home/alice/public_html/
|
|
|
|
/cgi-bin/ => /export/cgi-bin/
|
|
|
|
|
|
|
|
# Reverse proxy rules should be specified with ">>"
|
|
|
|
# /path >> host:port/path2
|
|
|
|
# Either "host" or ":port" can be committed, but not both.
|
|
|
|
/app/cal/ >> example.net/calendar/
|
|
|
|
# Yesod app in the same server
|
|
|
|
/app/wiki/ >> 127.0.0.1:3000/
|
|
|
|
|
|
|
|
/ -> /export/www/
|
|
|
|
'';
|
|
|
|
type = types.lines;
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2018-01-04 17:19:54 +00:00
|
|
|
Verbatim routing file to use
|
2023-10-30 20:41:44 +00:00
|
|
|
(see https://kazu-yamamoto.github.io/mighttpd2/config.html)
|
2018-01-04 17:19:54 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
cores = mkOption {
|
|
|
|
default = null;
|
|
|
|
type = types.nullOr types.int;
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2018-01-04 17:19:54 +00:00
|
|
|
How many cores to use.
|
|
|
|
If null it will be determined automatically
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
assertions =
|
|
|
|
[ { assertion = cfg.routing != "";
|
|
|
|
message = "You need at least one rule in mighttpd2.routing";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
systemd.services.mighttpd2 = {
|
|
|
|
description = "Mighttpd2 web server";
|
2023-10-04 05:21:50 +00:00
|
|
|
wants = [ "network-online.target" ];
|
2018-01-04 17:19:54 +00:00
|
|
|
after = [ "network-online.target" ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = ''
|
|
|
|
${pkgs.haskellPackages.mighttpd2}/bin/mighty \
|
|
|
|
${configFile} \
|
|
|
|
${routingFile} \
|
|
|
|
+RTS -N${optionalString (cfg.cores != null) "${cfg.cores}"}
|
|
|
|
'';
|
|
|
|
Type = "simple";
|
|
|
|
User = "mighttpd2";
|
|
|
|
Group = "mighttpd2";
|
|
|
|
Restart = "on-failure";
|
|
|
|
AmbientCapabilities = "cap_net_bind_service";
|
|
|
|
CapabilityBoundingSet = "cap_net_bind_service";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2018-06-29 23:58:35 +00:00
|
|
|
users.users.mighttpd2 = {
|
2018-01-04 17:19:54 +00:00
|
|
|
group = "mighttpd2";
|
|
|
|
uid = config.ids.uids.mighttpd2;
|
|
|
|
isSystemUser = true;
|
|
|
|
};
|
|
|
|
|
2018-06-29 23:58:35 +00:00
|
|
|
users.groups.mighttpd2.gid = config.ids.gids.mighttpd2;
|
2018-01-04 17:19:54 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = with lib.maintainers; [ fgaz ];
|
|
|
|
}
|