mirror of
https://github.com/kmein/niveum
synced 2026-03-16 10:11:08 +01:00
brockman: remove
This commit is contained in:
@@ -1,178 +0,0 @@
|
|||||||
{ pkgs, ... }:
|
|
||||||
{
|
|
||||||
services.rss-bridge = {
|
|
||||||
enable = true;
|
|
||||||
config.system.enabled_bridges = [ "*" ];
|
|
||||||
};
|
|
||||||
services.nginx.virtualHosts = {
|
|
||||||
rss-bridge = {
|
|
||||||
serverAliases = [
|
|
||||||
"rss.r"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
"brockman.r" = {
|
|
||||||
serverAliases = [
|
|
||||||
"news.r"
|
|
||||||
];
|
|
||||||
locations."/api".extraConfig = ''
|
|
||||||
proxy_pass http://127.0.0.1:7777/;
|
|
||||||
proxy_pass_header Server;
|
|
||||||
'';
|
|
||||||
locations."/".extraConfig = ''
|
|
||||||
root /var/lib/brockman;
|
|
||||||
index brockman.json;
|
|
||||||
'';
|
|
||||||
extraConfig = ''
|
|
||||||
add_header 'Access-Control-Allow-Origin' '*';
|
|
||||||
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
systemd.tmpfiles.rules = [
|
|
||||||
"d /var/lib/brockman 1750 brockman nginx -"
|
|
||||||
"d /run/irc-api 1750 brockman nginx -"
|
|
||||||
];
|
|
||||||
|
|
||||||
services.restic.backups.niveum.paths = [ "/var/lib/brockman" ];
|
|
||||||
|
|
||||||
networking.firewall.allowedTCPPorts = [6667];
|
|
||||||
|
|
||||||
services.ergochat.enable = true;
|
|
||||||
services.ergochat.openFilesLimit = 16384;
|
|
||||||
services.ergochat.settings = {
|
|
||||||
limits.nicklen = 100;
|
|
||||||
limits.identlen = 100;
|
|
||||||
history.enabled = false;
|
|
||||||
};
|
|
||||||
systemd.services.brockman.bindsTo = [ "ergochat.service" ];
|
|
||||||
systemd.services.brockman.serviceConfig.LimitNOFILE = 16384;
|
|
||||||
systemd.services.brockman.environment.BROCKMAN_LOG_LEVEL = "DEBUG";
|
|
||||||
services.brockman = {
|
|
||||||
enable = true;
|
|
||||||
config = {
|
|
||||||
irc.host = "localhost";
|
|
||||||
channel = "#all";
|
|
||||||
shortener = "http://go.r";
|
|
||||||
controller = {
|
|
||||||
nick = "brockman";
|
|
||||||
extraChannels = [ "#all" ];
|
|
||||||
};
|
|
||||||
statePath = "/var/lib/brockman/brockman.json";
|
|
||||||
bots = {};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
krebs.reaktor2.api = {
|
|
||||||
hostname = "localhost";
|
|
||||||
port = "6667";
|
|
||||||
nick = "api";
|
|
||||||
API.listen = "inet://127.0.0.1:7777";
|
|
||||||
plugins = [
|
|
||||||
{
|
|
||||||
plugin = "register";
|
|
||||||
config = {
|
|
||||||
channels = [
|
|
||||||
"#all"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
krebs.reaktor2.news = let
|
|
||||||
name = "candyman";
|
|
||||||
in {
|
|
||||||
hostname = "localhost";
|
|
||||||
port = "6667";
|
|
||||||
nick = name;
|
|
||||||
plugins = [
|
|
||||||
{
|
|
||||||
plugin = "register";
|
|
||||||
config = {
|
|
||||||
channels = [
|
|
||||||
"#all"
|
|
||||||
"#aluhut"
|
|
||||||
"#news"
|
|
||||||
"#lasstube"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
{
|
|
||||||
plugin = "system";
|
|
||||||
config = {
|
|
||||||
hooks.PRIVMSG = [
|
|
||||||
{
|
|
||||||
activate = "match";
|
|
||||||
pattern = "^${name}:\\s*(\\S*)(?:\\s+(.*\\S))?\\s*$";
|
|
||||||
command = 1;
|
|
||||||
arguments = [2];
|
|
||||||
commands = {
|
|
||||||
add-reddit.filename = pkgs.writers.writeDash "add-reddit" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: add-reddit $reddit_channel'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
reddit_channel=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
echo "brockman: add r_$reddit_channel http://rss.r/?action=display&bridge=Reddit&context=single&r=$reddit_channel&format=Atom"
|
|
||||||
'';
|
|
||||||
add-telegram.filename = pkgs.writers.writeDash "add-telegram" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: add-telegram $telegram_user'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
telegram_user=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
echo "brockman: add t_$telegram_user http://rss.r/?action=display&bridge=Telegram&username=$telegram_user&format=Mrss"
|
|
||||||
'';
|
|
||||||
add-youtube.filename = pkgs.writers.writeDash "add-youtube" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: add-youtube $nick $channel/video/stream/id'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
youtube_nick=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
youtube_url=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][1]')
|
|
||||||
if [ ''${#youtube_url} -eq 24 ]; then
|
|
||||||
youtube_id=$youtube_url
|
|
||||||
else
|
|
||||||
youtube_id=$(${pkgs.yt-dlp}/bin/yt-dlp --max-downloads 1 -j "$youtube_url" | ${pkgs.jq}/bin/jq -r '.channel_id')
|
|
||||||
fi
|
|
||||||
echo "brockman: add yt_$youtube_nick http://rss.r/?action=display&bridge=Youtube&context=By+channel+id&c=$youtube_id&duration_min=&duration_max=&format=Mrss"
|
|
||||||
'';
|
|
||||||
add-twitch.filename = pkgs.writers.writeDash "add-twitch" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: add-twitch $handle'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
twitch_nick=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
echo "brockman: add twitch_$twitch_nick http://rss.r/?action=display&bridge=Twitch&channel=$twitch_nick&type=all&format=Atom"
|
|
||||||
'';
|
|
||||||
add-twitter.filename = pkgs.writers.writeDash "add-twitter" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: add-twitter $handle'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
twitter_nick=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
echo "brockman: add tw_$twitter_nick http://rss.r/?action=display&bridge=Twitter&context=By+username&u=$twitter_nick&norep=on&noretweet=on&nopinned=on&nopic=on&format=Atom"
|
|
||||||
'';
|
|
||||||
search.filename = pkgs.writers.writeDash "search" ''
|
|
||||||
set -euf
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo 'usage: ${name}: search $searchterm'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
searchterm=$(echo "$1" | ${pkgs.jq}/bin/jq -Rr '[match("(\\S+)\\s*";"g").captures[].string][0]')
|
|
||||||
${pkgs.curl}/bin/curl -Ss "https://feedsearch.dev/api/v1/search?url=$searchterm&info=true&favicon=false" |
|
|
||||||
${pkgs.jq}/bin/jq '.[].url'
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -12,7 +12,6 @@ in {
|
|||||||
./radio.nix
|
./radio.nix
|
||||||
./panoptikon.nix
|
./panoptikon.nix
|
||||||
./hledger.nix
|
./hledger.nix
|
||||||
./brockman.nix
|
|
||||||
./alew.nix
|
./alew.nix
|
||||||
../../configs/monitoring.nix
|
../../configs/monitoring.nix
|
||||||
../../configs/tor.nix
|
../../configs/tor.nix
|
||||||
|
|||||||
Reference in New Issue
Block a user