{ php, env, ttrss, ttrss-plugins }: rec { varDir = "/var/lib/ttrss"; activationScript = { deps = [ "wrappers" ]; text = '' install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir} \ ${varDir}/lock ${varDir}/cache ${varDir}/feed-icons install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir}/cache/export/ \ ${varDir}/cache/feeds/ \ ${varDir}/cache/images/ \ ${varDir}/cache/js/ \ ${varDir}/cache/simplepie/ \ ${varDir}/cache/upload/ touch ${varDir}/feed-icons/index.html install -m 0750 -o ${apache.user} -g ${apache.group} -d ${varDir}/phpSessions ''; }; keys = [{ dest = "webapps/tools-ttrss"; user = apache.user; group = apache.group; permissions = "0400"; text = '' DirectoryIndex index.php SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost" AllowOverride All Options FollowSymlinks Require all granted ''; }; phpFpm = rec { serviceDeps = [ "postgresql.service" "openldap.service" ]; basedir = builtins.concatStringsSep ":" ( [ webRoot "/var/secrets/webapps/tools-ttrss" varDir ] ++ webRoot.plugins); socket = "/var/run/phpfpm/ttrss.sock"; pool = '' listen = ${socket} user = ${apache.user} group = ${apache.group} listen.owner = ${apache.user} listen.group = ${apache.group} pm = ondemand pm.max_children = 60 pm.process_idle_timeout = 60 ; Needed to avoid clashes in browser cookies (same domain) php_value[session.name] = TtrssPHPSESSID php_admin_value[open_basedir] = "${basedir}:/tmp" php_admin_value[session.save_path] = "${varDir}/phpSessions" ''; }; }