drastikbot
This commit is contained in:
parent
07236ef77e
commit
7d7169def6
@ -18,6 +18,7 @@
|
|||||||
./server/zerobin.nix
|
./server/zerobin.nix
|
||||||
./server/gitea.nix
|
./server/gitea.nix
|
||||||
./server/privatebin/privatebin.nix
|
./server/privatebin/privatebin.nix
|
||||||
|
./server/drastikbot.nix
|
||||||
./pc/de.nix
|
./pc/de.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
90
common/server/drasktikbot.nix
Normal file
90
common/server/drasktikbot.nix
Normal 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}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
@ -65,6 +65,8 @@
|
|||||||
age.secrets.peertube-smtp.file = ../../secrets/peertube-smtp.age;
|
age.secrets.peertube-smtp.file = ../../secrets/peertube-smtp.age;
|
||||||
networking.firewall.allowedTCPPorts = [ 1935 ];
|
networking.firewall.allowedTCPPorts = [ 1935 ];
|
||||||
|
|
||||||
|
services.drastikbot.enable = true;
|
||||||
|
|
||||||
services.searx = {
|
services.searx = {
|
||||||
enable = true;
|
enable = true;
|
||||||
environmentFile = "/run/secrets/searx";
|
environmentFile = "/run/secrets/searx";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user