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
|
|
|
|
2015-07-13 17:48:58 +02:00
|
|
|
# TODO assert sendmail's existence
|
|
|
|
out = {
|
2015-07-24 11:55:16 +02:00
|
|
|
options.krebs.urlwatch = api;
|
2015-07-13 17:48:58 +02:00
|
|
|
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
|
|
|
|
];
|
|
|
|
};
|
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" (concatStringsSep "\n" cfg.urls);
|
|
|
|
|
2015-07-13 17:48:58 +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}
|
|
|
|
|
|
|
|
cd /tmp
|
|
|
|
|
2015-10-26 00:04:15 +01:00
|
|
|
urlwatch -e ${optionalString cfg.verbose "-v"} --urls="$urlsFile" > 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
|
2015-07-13 17:48:58 +02:00
|
|
|
out
|