diff options
Diffstat (limited to 'lass/3modules')
| -rw-r--r-- | lass/3modules/default.nix | 8 | ||||
| -rw-r--r-- | lass/3modules/dnsmasq.nix | 55 | ||||
| -rw-r--r-- | lass/3modules/newsbot-js.nix | 87 | ||||
| -rw-r--r-- | lass/3modules/sshkeys.nix | 26 | 
4 files changed, 149 insertions, 27 deletions
diff --git a/lass/3modules/default.nix b/lass/3modules/default.nix index 9de987bf3..b081dc3cc 100644 --- a/lass/3modules/default.nix +++ b/lass/3modules/default.nix @@ -1,7 +1,13 @@  _: -  {    imports = [      ./xresources.nix +    ./bitlbee.nix +    ./folderPerms.nix +    ./go.nix +    ./newsbot-js.nix +    ./per-user.nix +    ./urxvtd.nix +    ./xresources.nix    ];  } diff --git a/lass/3modules/dnsmasq.nix b/lass/3modules/dnsmasq.nix new file mode 100644 index 000000000..99c165479 --- /dev/null +++ b/lass/3modules/dnsmasq.nix @@ -0,0 +1,55 @@ +{ config, lib, pkgs, ... }: + +with builtins; +with lib; + +let +  cfg = config.lass.dnsmasq; + +  out = { +    options.lass.dnsmasq = api; +    config = mkIf cfg.enable imp; +  }; + +  api = { +    enable = mkEnableOption "dnsmasq"; +    config = mkOption { +      type = types.str; +      #TODO: find a good default +      default = '' +      ''; +      description = "configuration dnsmasq is started with"; +    }; +  }; + +  configFile = pkgs.writeText "dnsmasq.conf" cfg.config; + +  imp = { +    #users.extraUsers.go = { +    #  name = "go"; +    #  uid = 42774411; #genid go +    #  description = "go url shortener user"; +    #  home = "/var/lib/go"; +    #  createHome = true; +    #}; + +    systemd.services.dnsmasq = { +      description = "dnsmasq"; +      after = [ "network.target" ]; +      wantedBy = [ "multi-user.target" ]; + +      path = with pkgs; [ +        dnsmasq +      ]; + + +      restartIfChanged = true; + +      serviceConfig = { +        Restart = "always"; +        ExecStart = "${pkgs.dnsmasq}/bin/dnsmasq -k -C ${configFile}"; +      }; +    }; +  }; + +in out diff --git a/lass/3modules/newsbot-js.nix b/lass/3modules/newsbot-js.nix new file mode 100644 index 000000000..6d87d256d --- /dev/null +++ b/lass/3modules/newsbot-js.nix @@ -0,0 +1,87 @@ +{ config, lib, pkgs, ... }: + +with builtins; +with lib; + +let +  cfg = config.lass.newsbot-js; + +  out = { +    options.lass.newsbot-js = api; +    config = mkIf cfg.enable imp; +  }; + +  api = { +    enable = mkEnableOption "Enable krebs newsbot"; +    ircServer = mkOption { +      type = types.str; +      default = "echelon.retiolum"; +      description = "to which server the bot should connect"; +    }; +    channel = mkOption { +      type = types.str; +      default = "#news"; +      description = "post the news in this channel"; +    }; +    masterNick = mkOption { +      type = types.str; +      default = "knews"; +      description = "nickname of the master bot"; +    }; +    feeds = mkOption { +      type = types.path; +      description = '' +        file with feeds to post +        format: +        $nick|$feedURI +      ''; +    }; +    urlShortenerHost = mkOption { +      type = types.str; +      default = "echelon"; +      description = "what server to use for url shortening, host"; +    }; +    urlShortenerPort = mkOption { +      type = types.str; +      default = "80"; +      description = "what server to use for url shortening, port"; +    }; +  }; + +  imp = { +    users.extraUsers.newsbot-js = { +      name = "newsbot-js"; +      uid = 1616759810; #genid newsbot-js +      description = "newsbot-js user"; +      home = "/var/empty"; +    }; + +    systemd.services.newsbot-js = { +      description = "krebs newsbot"; +      after = [ "network.target" ]; +      wantedBy = [ "multi-user.target" ]; + +      path = with pkgs; [ +        newsbot-js +      ]; + +      environment = { +        irc_server = cfg.ircServer; +        master_nick = cfg.masterNick; +        news_channel = cfg.channel; +        feeds_file = cfg.feeds; +        url_shortener_host = cfg.urlShortenerHost; +        url_shortener_port = cfg.urlShortenerPort; +      }; + +      restartIfChanged = true; + +      serviceConfig = { +        User = "newsbot-js"; +        Restart = "always"; +        ExecStart = "${pkgs.newsbot-js}/bin/newsbot"; +      }; +    }; +  }; + +in out diff --git a/lass/3modules/sshkeys.nix b/lass/3modules/sshkeys.nix deleted file mode 100644 index 5f1c60668..000000000 --- a/lass/3modules/sshkeys.nix +++ /dev/null @@ -1,26 +0,0 @@ -{ lib, ... }: - -with lib; - -{ -  options = { -    sshKeys = mkOption { -      type = types.attrsOf (types.submodule ( -      { config, ... }: -      { -        options = { -          pub = mkOption { -            type = types.str; -            description = "Public part of the ssh key."; -          }; - -          priv = mkOption { -            type = types.str; -            description = "Private part of the ssh key."; -          }; -        }; -      })); -      description = "collection of ssh-keys"; -    }; -  }; -}  | 
