Merge pull request #274281 from RaitoBezarius/hebbot-module
nixos/hebbot: init
This commit is contained in:
commit
8cc42008aa
@ -50,6 +50,8 @@ In addition to numerous new and upgraded packages, this release has the followin
|
||||
|
||||
- [ollama](https://ollama.ai), server for running large language models locally.
|
||||
|
||||
- [hebbot](https://github.com/haecker-felix/hebbot), a Matrix bot to generate "This Week in X" like blog posts. Available as [services.hebbot](#opt-services.hebbot.enable).
|
||||
|
||||
- [Anki Sync Server](https://docs.ankiweb.net/sync-server.html), the official sync server built into recent versions of Anki. Available as [services.anki-sync-server](#opt-services.anki-sync-server.enable).
|
||||
The pre-existing [services.ankisyncd](#opt-services.ankisyncd.enable) has been marked deprecated and will be dropped after 24.05 due to lack of maintenance of the anki-sync-server softwares.
|
||||
|
||||
|
@ -634,6 +634,7 @@
|
||||
./services/matrix/appservice-irc.nix
|
||||
./services/matrix/conduit.nix
|
||||
./services/matrix/dendrite.nix
|
||||
./services/matrix/hebbot.nix
|
||||
./services/matrix/maubot.nix
|
||||
./services/matrix/mautrix-facebook.nix
|
||||
./services/matrix/mautrix-telegram.nix
|
||||
|
78
nixos/modules/services/matrix/hebbot.nix
Normal file
78
nixos/modules/services/matrix/hebbot.nix
Normal file
@ -0,0 +1,78 @@
|
||||
{ lib
|
||||
, config
|
||||
, pkgs
|
||||
, ...
|
||||
}:
|
||||
|
||||
let
|
||||
inherit (lib) mkEnableOption mkOption mkIf types;
|
||||
format = pkgs.formats.toml { };
|
||||
cfg = config.services.hebbot;
|
||||
settingsFile = format.generate "config.toml" cfg.settings;
|
||||
mkTemplateOption = templateName: mkOption {
|
||||
type = types.path;
|
||||
description = lib.mdDoc ''
|
||||
A path to the Markdown file for the ${templateName}.
|
||||
'';
|
||||
};
|
||||
in
|
||||
{
|
||||
meta.maintainers = [ lib.maintainers.raitobezarius ];
|
||||
options.services.hebbot = {
|
||||
enable = mkEnableOption "hebbot";
|
||||
botPasswordFile = mkOption {
|
||||
type = types.path;
|
||||
description = lib.mdDoc ''
|
||||
A path to the password file for your bot.
|
||||
|
||||
Consider using a path that does not end up in your Nix store
|
||||
as it would be world readable.
|
||||
'';
|
||||
};
|
||||
templates = {
|
||||
project = mkTemplateOption "project template";
|
||||
report = mkTemplateOption "report template";
|
||||
section = mkTemplateOption "section template";
|
||||
};
|
||||
settings = mkOption {
|
||||
type = format.type;
|
||||
default = { };
|
||||
description = lib.mdDoc ''
|
||||
Configuration for Hebbot, see, for examples:
|
||||
|
||||
- <https://github.com/matrix-org/twim-config/blob/master/config.toml>
|
||||
- <https://gitlab.gnome.org/Teams/Websites/thisweek.gnome.org/-/blob/main/hebbot/config.toml>
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
systemd.services.hebbot = {
|
||||
description = "hebbot - a TWIM-style Matrix bot written in Rust";
|
||||
after = [ "network.target" ];
|
||||
wantedBy = [ "multi-user.target" ];
|
||||
|
||||
preStart = ''
|
||||
ln -sf ${cfg.templates.project} ./project_template.md
|
||||
ln -sf ${cfg.templates.report} ./report_template.md
|
||||
ln -sf ${cfg.templates.section} ./section_template.md
|
||||
ln -sf ${settingsFile} ./config.toml
|
||||
'';
|
||||
|
||||
script = ''
|
||||
export BOT_PASSWORD="$(cat $CREDENTIALS_DIRECTORY/bot-password-file)"
|
||||
${lib.getExe pkgs.hebbot}
|
||||
'';
|
||||
|
||||
serviceConfig = {
|
||||
DynamicUser = true;
|
||||
Restart = "on-failure";
|
||||
LoadCredential = "bot-password-file:${cfg.botPasswordFile}";
|
||||
RestartSec = "10s";
|
||||
StateDirectory = "hebbot";
|
||||
WorkingDirectory = "hebbot";
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user