drastikbot

This commit is contained in:
zuckerberg 2021-08-21 11:04:29 -04:00
parent 07236ef77e
commit 7d7169def6
3 changed files with 93 additions and 0 deletions

View File

@ -18,6 +18,7 @@
./server/zerobin.nix
./server/gitea.nix
./server/privatebin/privatebin.nix
./server/drastikbot.nix
./pc/de.nix
];

View File

@ -0,0 +1,90 @@
{ config, pkgs, lib, ... }:
let
cfg = config.services.drastikbot;
drastikbot = python3Packages.buildPythonApplication rec {
pname = "drastikbot";
version = "v2.1";
format = "other";
srcs = [
(fetchFromGitHub {
name = pname;
owner = "olagood";
repo = pname;
rev = version;
sha256 = "1L8vTE1YEhFWzY5RYb+s5Hb4LrVJNN2leKlZEugEyRU=";
})
(fetchFromGitHub {
name = "drastikbot_modules";
owner = "olagood";
repo = "drastikbot_modules";
rev = version;
sha256 = "w1164FkRkeyWnx6a95WDbwEUvNkNwFWa/6mhKtgVw0c=";
})
];
sourceRoot = pname;
nativeBuildInputs = [ makeWrapper ];
installPhase = ''
cp -r src $out/
arr=($srcs)
echo ''${arr[1]}
cp -r ''${arr[1]}/* $out/irc/modules
makeWrapper ${python3}/bin/python3 $out/drastikbot \
--prefix PYTHONPATH : ${with python3Packages; makePythonPath [requests beautifulsoup4]} \
--add-flags "$out/drastikbot.py"
'';
};
in {
options.services.drastikbot = {
enable = lib.mkEnableOption "enable drastikbot";
user = mkOption {
type = types.str;
default = "drastikbot";
description = ''
The user drastikbot should run as
'';
};
group = mkOption {
type = types.str;
default = "drastikbot";
description = ''
The group drastikbot should run as
'';
};
dataDir = mkOption {
type = types.str;
default = "/var/lib/drastikbot";
description = ''
Path to the drastikbot data directory
'';
};
};
config = lib.mkIf cfg.enable {
users.users.${cfg.user} = {
isSystemUser = true;
group = cfg.group;
home = cfg.dataDir;
createHome = true;
};
systemd.services.drastikbot = {
enable = true;
after = ["network.target"];
wantedBy = ["multi-user.target"];
serviceConfig.ExecStart = "${drastikbot}/drastikbot -c ${cfg.dataDir}";
serviceConfig.User = cfg.user;
serviceConfig.Group = cfg.group;
preStart = ''
mkdir -p ${cfg.dataDir}
chown ${cfg.user} ${cfg.dataDir}
'';
};
};
}

View File

@ -65,6 +65,8 @@
age.secrets.peertube-smtp.file = ../../secrets/peertube-smtp.age;
networking.firewall.allowedTCPPorts = [ 1935 ];
services.drastikbot.enable = true;
services.searx = {
enable = true;
environmentFile = "/run/secrets/searx";