]> git.immae.eu Git - perso/Immae/Config/Nix.git/blob - nixops/modules/websites/piedsjaloux/default.nix
Move secrets module outside of nixops
[perso/Immae/Config/Nix.git] / nixops / modules / websites / piedsjaloux / default.nix
1 { lib, pkgs, config, myconfig, mylibs, ... }:
2 let
3 piedsjaloux = pkgs.callPackage ./piedsjaloux.nix { inherit (mylibs) fetchedGitPrivate; };
4 piedsjaloux_dev = piedsjaloux {
5 config = myconfig.env.websites.piedsjaloux.integration;
6 };
7 piedsjaloux_prod = piedsjaloux {
8 config = myconfig.env.websites.piedsjaloux.production;
9 };
10
11 cfg = config.services.myWebsites.PiedsJaloux;
12 in {
13 options.services.myWebsites.PiedsJaloux = {
14 production = {
15 enable = lib.mkEnableOption "enable PiedsJaloux's website in production";
16 };
17 integration = {
18 enable = lib.mkEnableOption "enable PiedsJaloux's website in integration";
19 };
20 };
21
22 imports = [
23 ../commons/stats.nix
24 ];
25
26 config = lib.mkMerge [
27 (lib.mkIf cfg.production.enable {
28 secrets.keys = piedsjaloux_prod.keys;
29 services.myWebsites.commons.stats.enable = true;
30 services.myWebsites.commons.stats.sites = [
31 {
32 name = "piedsjaloux.fr";
33 conf = ./goaccess.conf;
34 }
35 ];
36
37 security.acme.certs."piedsjaloux" = config.services.myCertificates.certConfig // {
38 domain = "piedsjaloux.fr";
39 extraDomains = {
40 "www.piedsjaloux.fr" = null;
41 };
42 };
43
44 services.myPhpfpm.preStart.piedsjaloux_prod = piedsjaloux_prod.phpFpm.preStart;
45 services.myPhpfpm.serviceDependencies.piedsjaloux_prod = piedsjaloux_prod.phpFpm.serviceDeps;
46 services.myPhpfpm.poolConfigs.piedsjaloux_prod = piedsjaloux_prod.phpFpm.pool;
47 system.activationScripts.piedsjaloux_prod = piedsjaloux_prod.activationScript;
48 system.extraSystemBuilderCmds = ''
49 mkdir -p $out/webapps
50 ln -s ${piedsjaloux_prod.webRoot} $out/webapps/${piedsjaloux_prod.apache.webappName}
51 '';
52 services.myWebsites.production.modules = piedsjaloux_prod.apache.modules;
53 services.myWebsites.production.vhostConfs.piedsjaloux = {
54 certName = "piedsjaloux";
55 hosts = [ "piedsjaloux.fr" "www.piedsjaloux.fr" ];
56 root = piedsjaloux_prod.apache.root;
57 extraConfig = [ piedsjaloux_prod.apache.vhostConf ];
58 };
59 })
60 (lib.mkIf cfg.integration.enable {
61 secrets.keys = piedsjaloux_dev.keys;
62 security.acme.certs."eldiron".extraDomains."piedsjaloux.immae.eu" = null;
63 services.myPhpfpm.preStart.piedsjaloux_dev = piedsjaloux_dev.phpFpm.preStart;
64 services.myPhpfpm.serviceDependencies.piedsjaloux_dev = piedsjaloux_dev.phpFpm.serviceDeps;
65 services.myPhpfpm.poolConfigs.piedsjaloux_dev = piedsjaloux_dev.phpFpm.pool;
66 system.activationScripts.piedsjaloux_dev = piedsjaloux_dev.activationScript;
67 system.extraSystemBuilderCmds = ''
68 mkdir -p $out/webapps
69 ln -s ${piedsjaloux_dev.webRoot} $out/webapps/${piedsjaloux_dev.apache.webappName}
70 '';
71 services.myWebsites.integration.modules = piedsjaloux_dev.apache.modules;
72 services.myWebsites.integration.vhostConfs.piedsjaloux = {
73 certName = "eldiron";
74 hosts = [ "piedsjaloux.immae.eu" ];
75 root = piedsjaloux_dev.apache.root;
76 extraConfig = [ piedsjaloux_dev.apache.vhostConf ];
77 };
78 })
79 ];
80 }
81