50 lines
1.8 KiB
Nix
50 lines
1.8 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
let
|
|
secrets = import ../configs/secrets.nix;
|
|
in
|
|
{
|
|
services = {
|
|
nginx = {
|
|
virtualHosts = {
|
|
"goaccess.szczepan.ski" = {
|
|
forceSSL = true;
|
|
enableACME = true;
|
|
basicAuthFile = config.sops.secrets.goaccess-htpasswd.path;
|
|
locations = {
|
|
"/" = { root = "/var/www/goaccess"; };
|
|
"/ws" = {
|
|
proxyPass = "http://127.0.0.1:7890/";
|
|
proxyWebsockets = true;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
systemd = {
|
|
tmpfiles.settings = {
|
|
"goaccess" = {
|
|
"/var/www/goaccess" = { d.mode = "0755"; };
|
|
};
|
|
};
|
|
|
|
services = {
|
|
# Limit stack size to reduce memory usage
|
|
fail2ban.serviceConfig.LimitSTACK = 256 * 1024;
|
|
|
|
goaccess = {
|
|
description = "GoAccess real-time web log analysis";
|
|
after = [ "network.target" ];
|
|
wantedBy = [ "multi-user.target" ];
|
|
script = "${pkgs.gzip}/bin/zcat -f /var/log/nginx/access.* | ${pkgs.goaccess}/bin/goaccess - -o /var/www/goaccess/index.html --log-format='%v %h %^[%d:%t %^]%^\"%r\" %s %b \"%R\" \"%u\"' --real-time-html --ws-url=wss://goaccess.szczepan.ski:443/ws --port 7890 --time-format \"%H:%M:%S\" --date-format \"%d/%b/%Y\"";
|
|
# serviceConfig = {
|
|
# StateDirectory = "/var/www/goaccess";
|
|
# # ExecStart = "${pkgs.bash}/bin/bash -c "${pkgs.gzip}/bin/zcat -f /var/log/nginx/access.* | ${pkgs.goaccess}/bin/goaccess -o /var/www/goaccess/index.html --log-format='%v %h %^[%d:%t %^]%^\"%r\" %s %b \"%R\" \"%u\"' --real-time-html --ws-url=wss://goaccess.szczepan.ski:443/ws --port 7890 --time-format \"%H:%M:%S\" --date-format \"%d/%b/%Y\"'";
|
|
# # ExecStop = "/bin/kill -9 ${MAINPID}";
|
|
# };
|
|
};
|
|
};
|
|
};
|
|
}
|