aboutsummaryrefslogblamecommitdiff
path: root/modules/private/irc.nix
blob: 4e6eaabd9ee2f656d48cd2742cce9dd6eb09c200 (plain) (tree)
1
2
3
4
5
6
7
8
9
10



                              
 




                                                                                     







                                    
                                
                                         

                                   
                                                               






                                                   
                                   


                              

                       

                 



                        








                         
                                                                  




          
{ lib, pkgs, config, ... }:
let
  cfg = config.myServices.irc;
in
{
  options.myServices = {
    ircCerts = lib.mkOption {
      description = "Default ircconfigurations for certificates as accepted by acme";
    };
    irc.enable = lib.mkOption {
      type = lib.types.bool;
      default = false;
      description = ''
        Whether to enable irc stuff.
      '';
    };
  };

  config = lib.mkIf cfg.enable {
    services.duplyBackup.profiles.irc = {
      rootDir = "/var/lib/bitlbee";
    };
    security.acme.certs."irc" = config.myServices.ircCerts // {
      domain = "irc.immae.eu";
      postRun = ''
        systemctl restart stunnel.service
      '';
    };

    networking.firewall.allowedTCPPorts = [ 6697 ];
    services.bitlbee = with pkgs; {
      enable = true;
      authMode = "Registered";
      libpurple_plugins = [
        purple-hangouts
        purple-matrix
      ];
      plugins = [
        bitlbee-mastodon
        bitlbee-facebook
        bitlbee-discord
        bitlbee-steam
      ];
    };

    services.stunnel = {
      enable = true;
      servers = {
        bitlbee = {
          accept = 6697;
          connect = 6667;
          cert = "${config.security.acme.directory}/irc/full.pem";
        };
      };
    };
  };
}