{ config, lib, pkgs, ... }:

with lib;

let
  home = "/var/lib/tox-bootstrapd";
  PIDFile = "${home}/pid";

  pkg = pkgs.libtoxcore;
  cfg = config.services.toxBootstrapd;
  cfgFile = builtins.toFile "tox-bootstrapd.conf"
    ''
      port = ${toString cfg.port}
      keys_file_path = "${home}/keys"
      pid_file_path = "${PIDFile}"
      ${cfg.extraConfig}
    '';
in
{
  options =
    { services.toxBootstrapd =
        { enable = mkOption {
            type = types.bool;
            default = false;
            description =
              ''
                Whether to enable the Tox DHT bootstrap daemon.
              '';
          };

          port = mkOption {
            type = types.int;
            default = 33445;
            description = "Listening port (UDP).";
          };

          keysFile = mkOption {
            type = types.str;
            default = "${home}/keys";
            description = "Node key file.";
          };

          extraConfig = mkOption {
            type = types.lines;
            default = "";
            description =
              ''
                Configuration for bootstrap daemon.
                See <link xlink:href="https://github.com/irungentoo/toxcore/blob/master/other/bootstrap_daemon/tox-bootstrapd.conf"/>
                and <link xlink:href="http://wiki.tox.im/Nodes"/>.
             '';
          };
      };

    };

  config = mkIf config.services.toxBootstrapd.enable {

    users.extraUsers = singleton
      { name = "tox-bootstrapd";
        uid = config.ids.uids.tox-bootstrapd;
        description = "Tox bootstrap daemon user";
        inherit home;
        createHome = true;
      };

    systemd.services.tox-bootstrapd = {
      description = "Tox DHT bootstrap daemon";
      after = [ "network.target" ];
      wantedBy = [ "multi-user.target" ];
      serviceConfig =
        { ExecStart = "${pkg}/bin/tox-bootstrapd ${cfgFile}";
          Type = "forking";
          inherit PIDFile;
          User = "tox-bootstrapd";
        };
    };

  };
}