aboutsummaryrefslogtreecommitdiff
path: root/virtual/modules/websites
diff options
context:
space:
mode:
authorIsmaël Bouya <ismael.bouya@normalesup.org>2019-01-10 22:40:32 +0100
committerIsmaël Bouya <ismael.bouya@normalesup.org>2019-01-10 22:40:32 +0100
commite4a945cd175fa78ee6373f2a30505c4322befa2b (patch)
tree8e958eaa618a06dd3fb588540ec5fc2794a25487 /virtual/modules/websites
parentf8bde3d6d31da84b5e81bdfc4f96efdf6bec3df2 (diff)
downloadNix-e4a945cd175fa78ee6373f2a30505c4322befa2b.tar.gz
Nix-e4a945cd175fa78ee6373f2a30505c4322befa2b.tar.zst
Nix-e4a945cd175fa78ee6373f2a30505c4322befa2b.zip
Move goaccess to specific module
Diffstat (limited to 'virtual/modules/websites')
-rw-r--r--virtual/modules/websites/aten.nix8
-rw-r--r--virtual/modules/websites/chloe.nix8
-rw-r--r--virtual/modules/websites/commons/stats.nix66
-rw-r--r--virtual/modules/websites/connexionswing.nix8
-rw-r--r--virtual/modules/websites/ludivine.nix8
-rw-r--r--virtual/modules/websites/piedsjaloux.nix12
6 files changed, 110 insertions, 0 deletions
diff --git a/virtual/modules/websites/aten.nix b/virtual/modules/websites/aten.nix
index 53db03a..4688db3 100644
--- a/virtual/modules/websites/aten.nix
+++ b/virtual/modules/websites/aten.nix
@@ -17,6 +17,14 @@ in {
17 17
18 config = lib.mkMerge [ 18 config = lib.mkMerge [
19 (lib.mkIf cfg.production.enable { 19 (lib.mkIf cfg.production.enable {
20 services.myWebsites.commons.stats.enable = true;
21 services.myWebsites.commons.stats.sites = [
22 {
23 name = "aten.pro";
24 conf = ../../packages/aten_goaccess.conf;
25 }
26 ];
27
20 security.acme.certs."aten" = config.services.myCertificates.certConfig // { 28 security.acme.certs."aten" = config.services.myCertificates.certConfig // {
21 domain = "aten.pro"; 29 domain = "aten.pro";
22 extraDomains = { 30 extraDomains = {
diff --git a/virtual/modules/websites/chloe.nix b/virtual/modules/websites/chloe.nix
index 67e8e1f..3309dd2 100644
--- a/virtual/modules/websites/chloe.nix
+++ b/virtual/modules/websites/chloe.nix
@@ -17,6 +17,14 @@ in {
17 17
18 config = lib.mkMerge [ 18 config = lib.mkMerge [
19 (lib.mkIf cfg.production.enable { 19 (lib.mkIf cfg.production.enable {
20 services.myWebsites.commons.stats.enable = true;
21 services.myWebsites.commons.stats.sites = [
22 {
23 name = "osteopathe-cc.fr";
24 conf = ../../packages/chloe_goaccess.conf;
25 }
26 ];
27
20 security.acme.certs."chloe" = config.services.myCertificates.certConfig // { 28 security.acme.certs."chloe" = config.services.myCertificates.certConfig // {
21 domain = "osteopathe-cc.fr"; 29 domain = "osteopathe-cc.fr";
22 extraDomains = { 30 extraDomains = {
diff --git a/virtual/modules/websites/commons/stats.nix b/virtual/modules/websites/commons/stats.nix
new file mode 100644
index 0000000..a7ade3b
--- /dev/null
+++ b/virtual/modules/websites/commons/stats.nix
@@ -0,0 +1,66 @@
1{ lib, pkgs, config, mylibs, ... }:
2let
3 cfg = config.services.myWebsites.commons.stats;
4in {
5 options = {
6 services.myWebsites.commons.stats = {
7 enable = lib.mkEnableOption "enable statistics";
8 sites = lib.mkOption {
9 # FIXME: specify
10 type = lib.types.listOf (lib.types.unspecified);
11 default = [];
12 description = "Sites to generate stats";
13 };
14 };
15 };
16
17 config = lib.mkIf cfg.enable {
18 environment.systemPackages = [
19 pkgs.goaccess
20 ];
21
22 nixpkgs.config.packageOverrides = oldpkgs: rec {
23 goaccess = oldpkgs.goaccess.overrideAttrs(old: rec {
24 name = "goaccess-${version}";
25 version = "1.3";
26 src = pkgs.fetchurl {
27 url = "https://tar.goaccess.io/${name}.tar.gz";
28 sha256 = "16vv3pj7pbraq173wlxa89jjsd279004j4kgzlrsk1dz4if5qxwc";
29 };
30 configureFlags = old.configureFlags ++ [ "--enable-tcb=btree" ];
31 buildInputs = old.buildInputs ++ [ pkgs.tokyocabinet pkgs.bzip2 ];
32 });
33 };
34
35 services.cron = {
36 enable = true;
37 systemCronJobs = let
38 stats = domain: conf: let
39 d = pkgs.writeScriptBin "stats-${domain}" ''
40 #!${pkgs.stdenv.shell}
41 set -e
42 shopt -s nullglob
43 date_regex=$(LC_ALL=C date -d yesterday +'%d\/%b\/%Y')
44 TMPFILE=$(mktemp)
45 trap "rm -f $TMPFILE" EXIT
46
47 cat /var/log/httpd/access_log-${domain} | sed -n "/\\[$date_regex/ p" > $TMPFILE
48 for i in /var/log/httpd/access_log-${domain}*.gz; do
49 zcat "$i" | sed -n "/\\[$date_regex/ p" >> $TMPFILE
50 done
51 goaccess $TMPFILE --no-progress -o /var/lib/goaccess/${domain}/index.html -p ${conf}
52 '';
53 in "${d}/bin/stats-${domain}";
54 # FIXME: running several goaccess simultaneously seems to be
55 # bugged?
56 in
57 pkgs.lib.lists.imap0 (i: v: "${toString (i+5)} 0 * * * root ${stats v.name v.conf}") cfg.sites;
58 };
59
60 # FIXME: initial sync
61 system.activationScripts.goaccess = ''
62 mkdir -p /var/lib/goaccess
63 '' +
64 builtins.concatStringsSep "\n" (map (v: "mkdir -p /var/lib/goaccess/${v.name}") cfg.sites);
65 };
66}
diff --git a/virtual/modules/websites/connexionswing.nix b/virtual/modules/websites/connexionswing.nix
index dcc7264..9fc0cec 100644
--- a/virtual/modules/websites/connexionswing.nix
+++ b/virtual/modules/websites/connexionswing.nix
@@ -17,6 +17,14 @@ in {
17 17
18 config = lib.mkMerge [ 18 config = lib.mkMerge [
19 (lib.mkIf cfg.production.enable { 19 (lib.mkIf cfg.production.enable {
20 services.myWebsites.commons.stats.enable = true;
21 services.myWebsites.commons.stats.sites = [
22 {
23 name = "connexionswing.com";
24 conf = ../../packages/connexionswing_goaccess.conf;
25 }
26 ];
27
20 security.acme.certs."connexionswing" = config.services.myCertificates.certConfig // { 28 security.acme.certs."connexionswing" = config.services.myCertificates.certConfig // {
21 domain = "connexionswing.com"; 29 domain = "connexionswing.com";
22 extraDomains = { 30 extraDomains = {
diff --git a/virtual/modules/websites/ludivine.nix b/virtual/modules/websites/ludivine.nix
index 6eb98e7..b3c1c51 100644
--- a/virtual/modules/websites/ludivine.nix
+++ b/virtual/modules/websites/ludivine.nix
@@ -17,6 +17,14 @@ in {
17 17
18 config = lib.mkMerge [ 18 config = lib.mkMerge [
19 (lib.mkIf cfg.production.enable { 19 (lib.mkIf cfg.production.enable {
20 services.myWebsites.commons.stats.enable = true;
21 services.myWebsites.commons.stats.sites = [
22 {
23 name = "ludivinecassal.com";
24 conf = ../../packages/ludivinecassal_goaccess.conf;
25 }
26 ];
27
20 security.acme.certs."ludivinecassal" = config.services.myCertificates.certConfig // { 28 security.acme.certs."ludivinecassal" = config.services.myCertificates.certConfig // {
21 domain = "ludivinecassal.com"; 29 domain = "ludivinecassal.com";
22 extraDomains = { 30 extraDomains = {
diff --git a/virtual/modules/websites/piedsjaloux.nix b/virtual/modules/websites/piedsjaloux.nix
index 46161c7..451ae52 100644
--- a/virtual/modules/websites/piedsjaloux.nix
+++ b/virtual/modules/websites/piedsjaloux.nix
@@ -15,8 +15,20 @@ in {
15 }; 15 };
16 }; 16 };
17 17
18 imports = [
19 ./commons/stats.nix
20 ];
21
18 config = lib.mkMerge [ 22 config = lib.mkMerge [
19 (lib.mkIf cfg.production.enable { 23 (lib.mkIf cfg.production.enable {
24 services.myWebsites.commons.stats.enable = true;
25 services.myWebsites.commons.stats.sites = [
26 {
27 name = "piedsjaloux.fr";
28 conf = ../../packages/piedsjaloux_goaccess.conf;
29 }
30 ];
31
20 security.acme.certs."piedsjaloux" = config.services.myCertificates.certConfig // { 32 security.acme.certs."piedsjaloux" = config.services.myCertificates.certConfig // {
21 domain = "piedsjaloux.fr"; 33 domain = "piedsjaloux.fr";
22 extraDomains = { 34 extraDomains = {