2014-04-14 16:26:48 +02:00
|
|
|
{ config, lib, pkgs, ... }:
|
2014-03-11 23:46:57 +01:00
|
|
|
|
2014-04-14 16:26:48 +02:00
|
|
|
with lib;
|
2014-03-11 23:46:57 +01:00
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.phpfpm;
|
2017-02-28 00:00:57 +01:00
|
|
|
enabled = cfg.poolConfigs != {} || cfg.pools != {};
|
2014-03-11 23:46:57 +01:00
|
|
|
|
|
|
|
stateDir = "/run/phpfpm";
|
|
|
|
|
2017-01-25 23:21:33 +01:00
|
|
|
poolConfigs = cfg.poolConfigs // mapAttrs mkPool cfg.pools;
|
|
|
|
|
2016-06-19 23:42:26 +02:00
|
|
|
mkPool = n: p: ''
|
|
|
|
listen = ${p.listen}
|
|
|
|
${p.extraConfig}
|
|
|
|
'';
|
|
|
|
|
2017-01-25 23:21:33 +01:00
|
|
|
fpmCfgFile = pool: poolConfig: pkgs.writeText "phpfpm-${pool}.conf" ''
|
2014-03-11 23:46:57 +01:00
|
|
|
[global]
|
|
|
|
error_log = syslog
|
2016-10-05 17:30:31 +02:00
|
|
|
daemonize = no
|
2014-03-11 23:46:57 +01:00
|
|
|
${cfg.extraConfig}
|
|
|
|
|
2017-01-25 23:21:33 +01:00
|
|
|
[${pool}]
|
|
|
|
${poolConfig}
|
2014-03-11 23:46:57 +01:00
|
|
|
'';
|
|
|
|
|
2017-02-26 13:29:46 +01:00
|
|
|
phpIni = pkgs.runCommand "php.ini" {
|
|
|
|
inherit (cfg) phpPackage phpOptions;
|
|
|
|
passAsFile = [ "phpOptions" ];
|
|
|
|
} ''
|
2017-03-07 15:08:55 +01:00
|
|
|
cat $phpPackage/etc/php.ini $phpOptionsPath > $out
|
2016-04-29 08:26:20 +02:00
|
|
|
'';
|
|
|
|
|
2014-03-11 23:46:57 +01:00
|
|
|
in {
|
|
|
|
|
|
|
|
options = {
|
|
|
|
services.phpfpm = {
|
|
|
|
extraConfig = mkOption {
|
2014-03-12 11:45:31 +01:00
|
|
|
type = types.lines;
|
2014-03-11 23:46:57 +01:00
|
|
|
default = "";
|
|
|
|
description = ''
|
|
|
|
Extra configuration that should be put in the global section of
|
2016-09-27 03:20:22 +02:00
|
|
|
the PHP-FPM configuration file. Do not specify the options
|
2016-10-05 17:30:31 +02:00
|
|
|
<literal>error_log</literal> or
|
2014-03-11 23:46:57 +01:00
|
|
|
<literal>daemonize</literal> here, since they are generated by
|
|
|
|
NixOS.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2014-04-10 07:52:26 +02:00
|
|
|
phpPackage = mkOption {
|
2016-01-17 19:34:55 +01:00
|
|
|
type = types.package;
|
2015-07-17 18:09:50 +02:00
|
|
|
default = pkgs.php;
|
2016-01-17 19:34:55 +01:00
|
|
|
defaultText = "pkgs.php";
|
2014-04-10 07:52:26 +02:00
|
|
|
description = ''
|
2016-09-27 03:20:22 +02:00
|
|
|
The PHP package to use for running the PHP-FPM service.
|
2014-04-10 07:52:26 +02:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2016-04-29 08:26:20 +02:00
|
|
|
phpOptions = mkOption {
|
|
|
|
type = types.lines;
|
|
|
|
default = "";
|
|
|
|
example =
|
|
|
|
''
|
|
|
|
date.timezone = "CET"
|
|
|
|
'';
|
|
|
|
description =
|
|
|
|
"Options appended to the PHP configuration file <filename>php.ini</filename>.";
|
2014-06-07 17:34:27 +02:00
|
|
|
};
|
|
|
|
|
2016-07-26 22:44:34 +02:00
|
|
|
poolConfigs = mkOption {
|
2014-03-11 23:46:57 +01:00
|
|
|
default = {};
|
2016-06-19 23:42:26 +02:00
|
|
|
type = types.attrsOf types.lines;
|
2016-07-26 22:44:34 +02:00
|
|
|
example = literalExample ''
|
|
|
|
{ mypool = '''
|
|
|
|
listen = /run/phpfpm/mypool
|
|
|
|
user = nobody
|
|
|
|
pm = dynamic
|
|
|
|
pm.max_children = 75
|
|
|
|
pm.start_servers = 10
|
|
|
|
pm.min_spare_servers = 5
|
|
|
|
pm.max_spare_servers = 20
|
|
|
|
pm.max_requests = 500
|
|
|
|
''';
|
|
|
|
}
|
|
|
|
'';
|
2014-03-11 23:46:57 +01:00
|
|
|
description = ''
|
2016-09-27 03:20:22 +02:00
|
|
|
A mapping between PHP-FPM pool names and their configurations.
|
2016-07-26 22:44:34 +02:00
|
|
|
See the documentation on <literal>php-fpm.conf</literal> for
|
|
|
|
details on configuration directives. If no pools are defined,
|
|
|
|
the phpfpm service is disabled.
|
2014-03-11 23:46:57 +01:00
|
|
|
'';
|
|
|
|
};
|
2016-06-19 23:42:26 +02:00
|
|
|
|
|
|
|
pools = mkOption {
|
|
|
|
type = types.attrsOf (types.submodule (import ./pool-options.nix {
|
|
|
|
inherit lib;
|
|
|
|
}));
|
|
|
|
default = {};
|
2016-09-27 03:20:22 +02:00
|
|
|
example = literalExample ''
|
|
|
|
{
|
|
|
|
mypool = {
|
|
|
|
listen = "/path/to/unix/socket";
|
|
|
|
extraConfig = '''
|
|
|
|
user = nobody
|
|
|
|
pm = dynamic
|
|
|
|
pm.max_children = 75
|
|
|
|
pm.start_servers = 10
|
|
|
|
pm.min_spare_servers = 5
|
|
|
|
pm.max_spare_servers = 20
|
|
|
|
pm.max_requests = 500
|
|
|
|
''';
|
|
|
|
}
|
|
|
|
}'';
|
2016-06-19 23:42:26 +02:00
|
|
|
description = ''
|
2016-09-27 03:20:22 +02:00
|
|
|
PHP-FPM pools. If no pools or poolConfigs are defined, the PHP-FPM
|
|
|
|
service is disabled.
|
2016-06-19 23:42:26 +02:00
|
|
|
'';
|
|
|
|
};
|
2014-03-11 23:46:57 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-02-28 00:00:57 +01:00
|
|
|
config = mkIf enabled {
|
|
|
|
|
|
|
|
systemd.slices.phpfpm = {
|
|
|
|
description = "PHP FastCGI Process manager pools slice";
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.targets.phpfpm = {
|
|
|
|
description = "PHP FastCGI Process manager pools target";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
};
|
|
|
|
|
2017-01-25 23:21:33 +01:00
|
|
|
systemd.services = flip mapAttrs' poolConfigs (pool: poolConfig:
|
|
|
|
nameValuePair "phpfpm-${pool}" {
|
2017-02-28 00:00:57 +01:00
|
|
|
description = "PHP FastCGI Process Manager service for pool ${pool}";
|
2017-01-25 23:21:33 +01:00
|
|
|
after = [ "network.target" ];
|
2017-02-28 00:00:57 +01:00
|
|
|
wantedBy = [ "phpfpm.target" ];
|
|
|
|
partOf = [ "phpfpm.target" ];
|
2017-01-25 23:21:33 +01:00
|
|
|
preStart = ''
|
|
|
|
mkdir -p ${stateDir}
|
|
|
|
'';
|
|
|
|
serviceConfig = let
|
|
|
|
cfgFile = fpmCfgFile pool poolConfig;
|
|
|
|
in {
|
2017-02-28 00:00:57 +01:00
|
|
|
Slice = "phpfpm.slice";
|
2017-01-25 23:21:33 +01:00
|
|
|
PrivateTmp = true;
|
|
|
|
PrivateDevices = true;
|
|
|
|
ProtectSystem = "full";
|
|
|
|
ProtectHome = true;
|
|
|
|
NoNewPrivileges = true;
|
|
|
|
RestrictAddressFamilies = "AF_UNIX AF_INET AF_INET6";
|
|
|
|
Type = "notify";
|
|
|
|
ExecStart = "${cfg.phpPackage}/bin/php-fpm -y ${cfgFile} -c ${phpIni}";
|
|
|
|
ExecReload = "${pkgs.coreutils}/bin/kill -USR2 $MAINPID";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
);
|
2014-03-11 23:46:57 +01:00
|
|
|
};
|
|
|
|
}
|