1
0
mirror of https://github.com/kmein/niveum synced 2026-03-16 10:11:08 +01:00

fix(weechat): move bouncer from toum to makanek and make stateless

This commit is contained in:
2021-02-06 13:44:38 +01:00
parent 444336cd19
commit a592947bbf
4 changed files with 74 additions and 9 deletions

View File

@@ -124,7 +124,7 @@ in {
zathura = swallow "${pkgs.zathura}/bin/zathura";
us = "${pkgs.systemd}/bin/systemctl --user";
wcd = "source ${wcd}";
weechat = "${pkgs.openssh}/bin/ssh weechat@toum -t screen -x weechat-screen";
im = "${pkgs.openssh}/bin/ssh weechat@makanek -t tmux attach-session -t IM";
where = "source ${where}";
yt =
"${pkgs.youtube-dl}/bin/youtube-dl --add-metadata -ic"; # Download video link

71
configs/weechat.nix Normal file
View File

@@ -0,0 +1,71 @@
{ pkgs, ... }:
let inherit (import <niveum/lib>) kieran;
in {
systemd.services.weechat =
let
tmux = pkgs.writers.writeDash "tmux" ''
exec ${pkgs.tmux}/bin/tmux -f ${pkgs.writeText "tmux.conf" ''
set-option -g prefix `
unbind-key C-b
bind ` send-prefix
set-option -g status off
set-option -g default-terminal screen-256color
#use session instead of windows
bind-key c new-session
bind-key p switch-client -p
bind-key n switch-client -n
bind-key C-s switch-client -l
''} "$@"
'';
weechat = pkgs.weechat.override {
configure = { ... }: {
init = ''
/set irc.server_default.nicks "kmein,kfm,kieran"
/set irc.server_default.msg_part "tschö mit ö"
/set irc.server_default.msg_quit "ciao kakao"
/set irc.server_default.msg_kick "warum machst du diese?"
/set irc.server_default.realname "${kieran.name}"
/server add freenode chat.freenode.org
/server add irc.r irc.r
/server add news.r news.r
/alias add mod /quote omode $channel +o $nick
/set irc.server.freenode.autojoin "#krebs,##myengadin"
/set irc.server.irc.r.autojoin "#xxx,#brockman"
/set irc.server.news.r.autojoin "#drachengame,#memes,#all,#berlin"
/set logger.level.irc.news.r.#all 0
/filter addreplace corona irc.news.r.* * corona|covid|virus|lockdown|va[kc][sc]in|mutante|mutation|impf|pandemi
/connect freenode
/connect irc.r
/connect news.r
'';
};
};
in {
description = "Weechat bouncer";
after = [ "network.target" ];
wantedBy = [ "multi-user.target" ];
restartIfChanged = false;
path = [ pkgs.alacritty.terminfo ];
environment.WEECHAT_HOME = "/var/lib/weechat";
script = "${tmux} -2 new-session -d -s IM ${weechat}/bin/weechat";
preStop = "${tmux} kill-session -t IM";
serviceConfig = {
User = "weechat";
RemainAfterExit = true;
Type = "oneshot";
};
};
users.groups.weechat = {};
users.extraUsers.weechat = {
useDefaultShell = true;
openssh.authorizedKeys.keys = kieran.sshKeys pkgs;
createHome = true;
group = "weechat";
home = "/var/lib/weechat";
isSystemUser = true;
packages = [ pkgs.tmux ];
};
}

View File

@@ -15,6 +15,7 @@ in
<niveum/configs/urlwatch.nix>
<niveum/configs/gitea.nix>
<niveum/configs/telegram-bots>
<niveum/configs/weechat.nix>
<niveum/configs/matterbridge.nix>
<niveum/modules/retiolum.nix>
];
@@ -63,5 +64,5 @@ in
email = kieran.email;
};
environment.systemPackages = [ pkgs.vim pkgs.git ];
environment.systemPackages = [ pkgs.vim pkgs.git pkgs.tmux ];
}

View File

@@ -15,13 +15,6 @@ in {
<niveum/configs/version.nix>
<niveum/configs/traadfri.nix>
<niveum/modules/retiolum.nix>
{
services.weechat.enable = true;
users.extraUsers.weechat = {
useDefaultShell = true;
openssh.authorizedKeys.keys = kieran.sshKeys pkgs;
};
}
];
nix.nixPath = [ "/var/src" ];