]> git.immae.eu Git - perso/Immae/Config/Nix.git/blame - modules/private/websites/ludivinecassal/integration.nix
Add a filesWatcher service to restart them when secrets change
[perso/Immae/Config/Nix.git] / modules / private / websites / ludivinecassal / integration.nix
CommitLineData
f8026b6e
IB
1{ lib, pkgs, config, myconfig, ... }:
2let
3 ludivinecassal = pkgs.callPackage ./builder.nix {
4 inherit (pkgs.webapps) ludivinecassal;
5 config = myconfig.env.websites.ludivinecassal.integration;
6 apacheUser = config.services.httpd.Inte.user;
7 apacheGroup = config.services.httpd.Inte.group;
8 };
9
10 cfg = config.myServices.websites.ludivinecassal.integration;
11in {
12 options.myServices.websites.ludivinecassal.integration.enable = lib.mkEnableOption "enable Ludivine's website in integration";
13
14 config = lib.mkIf cfg.enable {
15 secrets.keys = ludivinecassal.keys;
16
f40f5b23
IB
17 systemd.services.phpfpm-ludivinecassal_dev.after = lib.mkAfter ludivinecassal.phpFpm.serviceDeps;
18 systemd.services.phpfpm-ludivinecassal_dev.wants = ludivinecassal.phpFpm.serviceDeps;
19 systemd.services.phpfpm-ludivinecassal_dev.preStart = lib.mkAfter ludivinecassal.phpFpm.preStart;
20 services.phpfpm.poolConfigs.ludivinecassal_dev = ludivinecassal.phpFpm.pool;
f8026b6e 21 system.activationScripts.ludivinecassal_dev = ludivinecassal.activationScript;
4288c2f2 22 myServices.websites.webappDirs."${ludivinecassal.apache.webappName}" = ludivinecassal.app.webRoot;
f8026b6e
IB
23 services.websites.integration.modules = ludivinecassal.apache.modules;
24 services.websites.integration.vhostConfs.ludivine = {
25 certName = "eldiron";
26 addToCerts = true;
27 hosts = [ "ludivine.immae.eu" ];
28 root = ludivinecassal.apache.root;
29 extraConfig = [ ludivinecassal.apache.vhostConf ];
30 };
17f6eae9
IB
31 services.filesWatcher.phpfpm-ludivinecassal_dev = {
32 restart = true;
33 paths = [ "/var/secrets/webapps/${ludivinecassal.app.environment}-ludivinecassal" ];
34 };
f8026b6e
IB
35 };
36}