drastikbot as a flake
This commit is contained in:
parent
43e31a8d2d
commit
ca6a2c1bef
@ -12,7 +12,6 @@
|
|||||||
./zerobin.nix
|
./zerobin.nix
|
||||||
./gitea.nix
|
./gitea.nix
|
||||||
./privatebin/privatebin.nix
|
./privatebin/privatebin.nix
|
||||||
./drastikbot.nix
|
|
||||||
./radio.nix
|
./radio.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
@ -1,90 +0,0 @@
|
|||||||
{ config, pkgs, lib, ... }:
|
|
||||||
|
|
||||||
let
|
|
||||||
cfg = config.services.drastikbot;
|
|
||||||
drastikbot = pkgs.python3Packages.buildPythonApplication rec {
|
|
||||||
pname = "drastikbot";
|
|
||||||
version = "v2.1";
|
|
||||||
|
|
||||||
format = "other";
|
|
||||||
|
|
||||||
srcs = [
|
|
||||||
config.inputs.drastikbot
|
|
||||||
config.inputs.drastikbot_modules
|
|
||||||
config.inputs.dailybuild_modules
|
|
||||||
];
|
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgs.makeWrapper ];
|
|
||||||
|
|
||||||
phases = [ "installPhase" ]; # Removes all phases except installPhase
|
|
||||||
|
|
||||||
installPhase = ''
|
|
||||||
arr=($srcs)
|
|
||||||
mkdir -p $out/irc/modules
|
|
||||||
cp -r ''${arr[0]}/src/* $out/
|
|
||||||
cp -r ''${arr[1]}/* $out/irc/modules
|
|
||||||
cp -r ''${arr[2]}/* $out/irc/modules
|
|
||||||
|
|
||||||
sed -i 's|\(http://drastik.org/drastikbot"\)|\1 " https://git.neet.dev/zuckerberg/dailybuild_modules"|' $out/irc/modules/information.py
|
|
||||||
sed -i 's|\(https://github.com/olagood/drastikbot_modules\\x0F"\)|\1 " : \\x0311https://git.neet.dev/zuckerberg/dailybuild_modules\\x0F"|' $out/irc/modules/information.py
|
|
||||||
sed -i 's|AppID = "Enter your AppID here"|import pathlib\nAppID = pathlib.Path("${cfg.wolframAppIdFile}").read_text()|' $out/irc/modules/wolframalpha.py
|
|
||||||
|
|
||||||
makeWrapper ${pkgs.python3}/bin/python3 $out/drastikbot \
|
|
||||||
--prefix PYTHONPATH : ${with pkgs.python3Packages; makePythonPath [requests beautifulsoup4]} \
|
|
||||||
--add-flags "$out/drastikbot.py"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
options.services.drastikbot = {
|
|
||||||
enable = lib.mkEnableOption "enable drastikbot";
|
|
||||||
user = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
default = "drastikbot";
|
|
||||||
description = ''
|
|
||||||
The user drastikbot should run as
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
group = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
default = "drastikbot";
|
|
||||||
description = ''
|
|
||||||
The group drastikbot should run as
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
dataDir = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
default = "/var/lib/drastikbot";
|
|
||||||
description = ''
|
|
||||||
Path to the drastikbot data directory
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
wolframAppIdFile = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
description = ''
|
|
||||||
The file containing the Wolfram Alpha App ID
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = lib.mkIf cfg.enable {
|
|
||||||
users.users.${cfg.user} = {
|
|
||||||
isSystemUser = true;
|
|
||||||
group = cfg.group;
|
|
||||||
home = cfg.dataDir;
|
|
||||||
createHome = true;
|
|
||||||
};
|
|
||||||
users.groups.${cfg.group} = {};
|
|
||||||
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}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
60
flake.lock
generated
60
flake.lock
generated
@ -37,13 +37,18 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"dailybuild_modules": {
|
"dailybuild_modules": {
|
||||||
"flake": false,
|
"inputs": {
|
||||||
|
"drastikbot": "drastikbot",
|
||||||
|
"drastikbot_modules": "drastikbot_modules",
|
||||||
|
"flake-utils": "flake-utils",
|
||||||
|
"nixpkgs": "nixpkgs"
|
||||||
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1633210754,
|
"lastModified": 1648509055,
|
||||||
"narHash": "sha256-jBIE07mLsF+qHoa/CQLSRipvfNSivgbuWUatI6Wwy0s=",
|
"narHash": "sha256-y8AXfcbkAqn9UcfnfQz1MisT4YIXxj2I6P7uMnqMn9E=",
|
||||||
"ref": "master",
|
"ref": "master",
|
||||||
"rev": "e6a1c8686dad46b7847a5c690107a48fc20a6a29",
|
"rev": "82f4cddc27be4370f321a8d758db1b35c2ce28e5",
|
||||||
"revCount": 9,
|
"revCount": 11,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.neet.dev/zuckerberg/dailybuild_modules.git"
|
"url": "https://git.neet.dev/zuckerberg/dailybuild_modules.git"
|
||||||
},
|
},
|
||||||
@ -87,6 +92,21 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"flake-utils": {
|
"flake-utils": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1648297722,
|
||||||
|
"narHash": "sha256-W+qlPsiZd8F3XkzXOzAoR+mpFqzm3ekQkJNa+PIh1BQ=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"rev": "0f8662f1319ad6abf89b3380dd2722369fc51ade",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"flake-utils_2": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1620759905,
|
"lastModified": 1620759905,
|
||||||
"narHash": "sha256-WiyWawrgmyN0EdmiHyG2V+fqReiVi8bM9cRdMaKQOFg=",
|
"narHash": "sha256-WiyWawrgmyN0EdmiHyG2V+fqReiVi8bM9cRdMaKQOFg=",
|
||||||
@ -103,16 +123,16 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1646675913,
|
"lastModified": 1638239011,
|
||||||
"narHash": "sha256-ZvGf51XpXM7JojKLZ5yI0XLUq8UOFX6AwZ3bhtdcpIo=",
|
"narHash": "sha256-AjhmbT4UBlJWqxY0ea8a6GU2C2HdKUREkG43oRr3TZg=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "9b1c7ba323732ddc85a51850a7f10ecc5269b8e9",
|
"rev": "a7ecde854aee5c4c7cd6177f54a99d2c1ff28a31",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"ref": "nixos-21.11",
|
"ref": "21.11",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@ -132,9 +152,25 @@
|
|||||||
"type": "indirect"
|
"type": "indirect"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nixpkgs_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1646675913,
|
||||||
|
"narHash": "sha256-ZvGf51XpXM7JojKLZ5yI0XLUq8UOFX6AwZ3bhtdcpIo=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "9b1c7ba323732ddc85a51850a7f10ecc5269b8e9",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixos-21.11",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"radio": {
|
"radio": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils_2",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
]
|
]
|
||||||
@ -174,9 +210,7 @@
|
|||||||
"inputs": {
|
"inputs": {
|
||||||
"agenix": "agenix",
|
"agenix": "agenix",
|
||||||
"dailybuild_modules": "dailybuild_modules",
|
"dailybuild_modules": "dailybuild_modules",
|
||||||
"drastikbot": "drastikbot",
|
"nixpkgs": "nixpkgs_2",
|
||||||
"drastikbot_modules": "drastikbot_modules",
|
|
||||||
"nixpkgs": "nixpkgs",
|
|
||||||
"radio": "radio",
|
"radio": "radio",
|
||||||
"radio-web": "radio-web",
|
"radio-web": "radio-web",
|
||||||
"simple-nixos-mailserver": "simple-nixos-mailserver"
|
"simple-nixos-mailserver": "simple-nixos-mailserver"
|
||||||
|
@ -18,12 +18,7 @@
|
|||||||
radio-web.flake = false;
|
radio-web.flake = false;
|
||||||
|
|
||||||
# drastikbot
|
# drastikbot
|
||||||
drastikbot.url = "github:olagood/drastikbot/v2.1";
|
|
||||||
drastikbot.flake = false;
|
|
||||||
drastikbot_modules.url = "github:olagood/drastikbot_modules/v2.1";
|
|
||||||
drastikbot_modules.flake = false;
|
|
||||||
dailybuild_modules.url = "git+https://git.neet.dev/zuckerberg/dailybuild_modules.git";
|
dailybuild_modules.url = "git+https://git.neet.dev/zuckerberg/dailybuild_modules.git";
|
||||||
dailybuild_modules.flake = false;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = inputs: {
|
outputs = inputs: {
|
||||||
@ -39,6 +34,7 @@
|
|||||||
./common
|
./common
|
||||||
inputs.simple-nixos-mailserver.nixosModule
|
inputs.simple-nixos-mailserver.nixosModule
|
||||||
inputs.agenix.nixosModules.age
|
inputs.agenix.nixosModules.age
|
||||||
|
inputs.dailybuild_modules.nixosModule
|
||||||
({ lib, ... }: {
|
({ lib, ... }: {
|
||||||
config.environment.systemPackages = [ inputs.agenix.defaultPackage.${system} ];
|
config.environment.systemPackages = [ inputs.agenix.defaultPackage.${system} ];
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user