nixos-config/2configs/elchos/irc-token.nix

78 lines
1.9 KiB
Nix
Raw Normal View History

2016-12-12 19:38:13 +01:00
{pkgs, ...}:
with import <stockholm/lib>;
let
secret = (import <secrets/elchos-token.nix>);
in {
2016-12-28 18:13:14 +01:00
systemd.services.elchos-irctoken2 = {
startAt = "*:0/5";
2016-12-12 19:38:13 +01:00
serviceConfig = {
RuntimeMaxSec = "20";
};
script = ''
set -euf
now=$(date -u +%Y-%m-%dT%H:%M)
2016-12-28 18:13:14 +01:00
sleep 5
sec=$(cat /tmp/irc-secret)
message="The current secret is $sec"
echo "$message"
2016-12-12 19:38:13 +01:00
LOGNAME=sec-announcer
2016-12-28 18:13:14 +01:00
HOSTNAME=$(${pkgs.systemd}/bin/hostnamectl --transient)
2016-12-12 19:38:13 +01:00
IRC_SERVER=irc.freenode.net
IRC_PORT=6667
IRC_NICK=$HOSTNAME-$$
IRC_CHANNEL='#eloop'
export IRC_CHANNEL # for privmsg_cat
echo2() { echo "$*"; echo "$*" >&2; }
privmsg_cat() { ${pkgs.gawk}/bin/awk '{ print "PRIVMSG "ENVIRON["IRC_CHANNEL"]" :"$0 }'; }
tmpdir="$(mktemp -d irc-announce_XXXXXXXX)"
cd "$tmpdir"
mkfifo ircin
trap "
rm ircin
cd '$OLDPWD'
rmdir '$tmpdir'
trap - EXIT INT QUIT
" EXIT INT QUIT
{
echo2 "USER $LOGNAME 0 * :$LOGNAME@$HOSTNAME"
echo2 "NICK $IRC_NICK"
# wait for MODE message
${pkgs.gnused}/bin/sed -un '/^:[^ ]* MODE /q'
echo2 "JOIN $IRC_CHANNEL"
printf '%s' "$message" \
| privmsg_cat
echo2 "PART $IRC_CHANNEL"
# wait for PART confirmation
sed -un '/:'"$IRC_NICK"'![^ ]* PART /q'
echo2 'QUIT :Gone to have lunch'
} < ircin \
| ${pkgs.netcat}/bin/netcat "$IRC_SERVER" "$IRC_PORT" |tee -a ircin
'';
};
2016-12-28 18:13:14 +01:00
systemd.services.elchos-create-token = {
startAt = "*:0/30";
serviceConfig = {
RuntimeMaxSec = "20";
};
script = ''
set -euf
now=$(date -u +%Y-%m-%dT%H:%M)
sec=$(echo -n "${secret}$now" | md5sum | cut -d\ -f1)
message="The secret valid for 30 minutes is $sec"
echo -n "$sec" > /tmp/irc-secret
echo "token for $now (UTC) is $sec"
'';
};
2016-12-12 19:38:13 +01:00
}