stockholm/krebs/3modules/urlwatch.nix

186 lines
4.4 KiB
Nix
Raw Normal View History

2015-07-11 16:55:22 +02:00
{ config, lib, pkgs, ... }:
# TODO multiple users
# TODO inform about unused caches
# cache = url: "${cfg.dataDir}/.urlwatch/cache/${hashString "sha1" url}"
# TODO hooks.py
with lib;
let
2015-07-24 11:55:16 +02:00
cfg = config.krebs.urlwatch;
2015-07-11 16:55:22 +02:00
# TODO assert sendmail's existence
out = {
2015-07-24 11:55:16 +02:00
options.krebs.urlwatch = api;
config = mkIf cfg.enable imp;
};
2015-07-11 16:55:22 +02:00
api = {
2015-07-24 11:55:16 +02:00
enable = mkEnableOption "krebs.urlwatch";
2015-07-13 17:36:31 +02:00
2015-07-11 16:55:22 +02:00
dataDir = mkOption {
type = types.str;
default = "/var/lib/urlwatch";
description = ''
Directory where the urlwatch service should store its state.
'';
};
from = mkOption {
type = types.str;
2015-07-22 19:25:51 +02:00
default = "${user.name}@${config.networking.hostName}.retiolum";
2015-07-11 16:55:22 +02:00
description = ''
Content of the From: header of the generated mails.
'';
};
mailto = mkOption {
type = types.str;
2015-07-27 02:39:41 +02:00
default = config.krebs.build.user.mail;
2015-07-11 16:55:22 +02:00
description = ''
Content of the To: header of the generated mails. [AKA recipient :)]
'';
};
onCalendar = mkOption {
type = types.str;
2015-07-27 02:39:41 +02:00
default = "04:23";
2015-07-11 16:55:22 +02:00
description = ''
Run urlwatch at this interval.
The format is described in systemd.time(7), CALENDAR EVENTS.
'';
};
urls = mkOption {
type = with types; listOf str;
2015-07-27 02:39:41 +02:00
default = [];
2015-07-11 16:55:22 +02:00
description = "URL to watch.";
example = [
https://nixos.org/channels/nixos-unstable/git-revision
];
apply = map (x: getAttr (typeOf x) {
set = x;
string.url = x;
});
2015-07-11 16:55:22 +02:00
};
2015-10-26 00:04:15 +01:00
verbose = mkOption {
type = types.bool;
default = false;
description = ''
verbose output of urlwatch
'';
};
2015-07-11 16:55:22 +02:00
};
urlsFile = toFile "urls" (concatMapStringsSep "\n---\n" toJSON cfg.urls);
configFile = toFile "urlwatch.yaml" (toJSON {
display = {
error = true;
new = true;
unchanged = false;
};
report = {
email = {
enabled = false;
from = "";
html = false;
smtp = {
host = "localhost";
keyring = true;
port = 25;
starttls = true;
};
subject = "{count} changes: {jobs}";
to = "";
};
html.diff = "unified";
stdout = {
color = true;
enabled = true;
};
text = {
details = true;
footer = true;
line_length = 75;
};
};
});
2015-07-11 16:55:22 +02:00
imp = {
2015-07-11 16:55:22 +02:00
systemd.timers.urlwatch = {
wantedBy = [ "timers.target" ];
timerConfig = {
OnCalendar = cfg.onCalendar;
Persistent = "true";
};
};
systemd.services.urlwatch = {
path = with pkgs; [
coreutils
gnused
urlwatch
];
environment = {
HOME = cfg.dataDir;
LC_ALL = "en_US.UTF-8";
LOCALE_ARCHIVE = "${pkgs.glibcLocales}/lib/locale/locale-archive";
2015-08-26 17:10:02 +02:00
SSL_CERT_FILE = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
2015-07-11 16:55:22 +02:00
};
serviceConfig = {
2015-07-22 19:25:51 +02:00
User = user.name;
2015-07-11 16:55:22 +02:00
PermissionsStartOnly = "true";
PrivateTmp = "true";
Type = "oneshot";
ExecStartPre =
pkgs.writeScript "urlwatch-prestart" ''
#! /bin/sh
set -euf
dataDir=$HOME
if ! test -e "$dataDir"; then
mkdir -m 0700 -p "$dataDir"
2015-07-22 19:25:51 +02:00
chown ${user.name}: "$dataDir"
2015-07-11 16:55:22 +02:00
fi
'';
ExecStart = pkgs.writeScript "urlwatch" ''
#! /bin/sh
set -euf
from=${escapeShellArg cfg.from}
mailto=${escapeShellArg cfg.mailto}
urlsFile=${escapeShellArg urlsFile}
configFile=${escapeShellArg configFile}
2015-07-11 16:55:22 +02:00
cd /tmp
urlwatch \
${optionalString cfg.verbose "-v"} \
--urls="$urlsFile" \
--config="$configFile" \
> changes || :
2015-07-11 16:55:22 +02:00
if test -s changes; then
date=$(date -R)
subject=$(sed -n 's/^\(CHANGED\|ERROR\|NEW\): //p' changes \
| tr \\n \ )
{
echo "Date: $date"
echo "From: $from"
echo "Subject: $subject"
echo "To: $mailto"
echo
cat changes
} | /var/setuid-wrappers/sendmail -t
fi
'';
};
};
2015-07-22 19:25:51 +02:00
users.extraUsers = singleton {
inherit (user) name uid;
};
2015-07-11 16:55:22 +02:00
};
2015-12-26 05:55:13 +01:00
user = rec {
2015-07-22 19:25:51 +02:00
name = "urlwatch";
2015-12-26 05:55:13 +01:00
uid = genid name;
2015-07-22 19:25:51 +02:00
};
2015-07-11 16:55:22 +02:00
in
out