diff options
author | Timo Kaufmann <timokau@zoho.com> | 2018-09-07 17:19:46 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-09-07 17:19:46 +0200 |
commit | e326c0156d71fa12e1ef4aa0930c18cd5ba78a40 (patch) | |
tree | eae01858bc5c9fda4c7378a4887842acc6d2a386 /nixos/modules/services | |
parent | 00c6f85d18f12552437618e455feab1938215699 (diff) | |
parent | f5becfb5b02f9071472abe61e86460e41dbb7a5c (diff) | |
download | nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar.gz nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar.bz2 nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar.lz nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar.xz nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.tar.zst nixlib-e326c0156d71fa12e1ef4aa0930c18cd5ba78a40.zip |
Merge pull request #45728 from Ma27/nixos/weechat-module
nixos/weechat: add module
Diffstat (limited to 'nixos/modules/services')
-rw-r--r-- | nixos/modules/services/misc/weechat.nix | 56 | ||||
-rw-r--r-- | nixos/modules/services/misc/weechat.xml | 61 |
2 files changed, 117 insertions, 0 deletions
diff --git a/nixos/modules/services/misc/weechat.nix b/nixos/modules/services/misc/weechat.nix new file mode 100644 index 000000000000..1fcfb440485d --- /dev/null +++ b/nixos/modules/services/misc/weechat.nix @@ -0,0 +1,56 @@ +{ config, lib, pkgs, ... }: + +with lib; + +let + cfg = config.services.weechat; +in + +{ + options.services.weechat = { + enable = mkEnableOption "weechat"; + root = mkOption { + description = "Weechat state directory."; + type = types.str; + default = "/var/lib/weechat"; + }; + sessionName = mkOption { + description = "Name of the `screen' session for weechat."; + default = "weechat-screen"; + type = types.str; + }; + binary = mkOption { + description = "Binary to execute (by default \${weechat}/bin/weechat)."; + example = literalExample '' + ''${pkgs.weechat}/bin/weechat-headless + ''; + default = "${pkgs.weechat}/bin/weechat"; + }; + }; + + config = mkIf cfg.enable { + users = { + groups.weechat = {}; + users.weechat = { + createHome = true; + group = "weechat"; + home = cfg.root; + isSystemUser = true; + }; + }; + + systemd.services.weechat = { + environment.WEECHAT_HOME = cfg.root; + serviceConfig = { + User = "weechat"; + Group = "weechat"; + RemainAfterExit = "yes"; + }; + script = "exec ${pkgs.screen}/bin/screen -Dm -S ${cfg.sessionName} ${cfg.binary}"; + wantedBy = [ "multi-user.target" ]; + wants = [ "network.target" ]; + }; + }; + + meta.doc = ./weechat.xml; +} diff --git a/nixos/modules/services/misc/weechat.xml b/nixos/modules/services/misc/weechat.xml new file mode 100644 index 000000000000..de86dede2eb5 --- /dev/null +++ b/nixos/modules/services/misc/weechat.xml @@ -0,0 +1,61 @@ +<chapter xmlns="http://docbook.org/ns/docbook" + xmlns:xlink="http://www.w3.org/1999/xlink" + xmlns:xi="http://www.w3.org/2001/XInclude" + version="5.0" + xml:id="module-services-weechat"> + +<title>WeeChat</title> +<para><link xlink:href="https://weechat.org/">WeeChat</link> is a fast and extensible IRC client.</para> + +<section><title>Basic Usage</title> +<para> +By default, the module creates a +<literal><link xlink:href="https://www.freedesktop.org/wiki/Software/systemd/">systemd</link></literal> unit +which runs the chat client in a detached +<literal><link xlink:href="https://www.gnu.org/software/screen/">screen</link></literal> session. + +</para> + +<para> +This can be done by enabling the <literal>weechat</literal> service: + +<programlisting> +{ ... }: + +{ + <link linkend="opt-services.weechat.enable">services.weechat.enable</link> = true; +} +</programlisting> +</para> +<para> +The service is managed by a dedicated user +named <literal>weechat</literal> in the state directory +<literal>/var/lib/weechat</literal>. +</para> +</section> +<section><title>Re-attaching to WeeChat</title> +<para> +WeeChat runs in a screen session owned by a dedicated user. To explicitly +allow your another user to attach to this session, the <literal>screenrc</literal> needs to be tweaked +by adding <link xlink:href="https://www.gnu.org/software/screen/manual/html_node/Multiuser.html#Multiuser">multiuser</link> support: + +<programlisting> +{ + <link linkend="opt-programs.screen.screenrc">programs.screen.screenrc</link> = '' + multiuser on + acladd normal_user + ''; +} +</programlisting> + +Now, the session can be re-attached like this: + +<programlisting> +screen -r weechat-screen +</programlisting> +</para> +<para> +<emphasis>The session name can be changed using <link linkend="opt-services.weechat.sessionName">services.weechat.sessionName.</link></emphasis> +</para> +</section> +</chapter> |