summaryrefslogtreecommitdiffstats
path: root/krebs/2configs/syncthing.nix
blob: 90ae66f6e4fdb0e88cb752b8ec37fe67bd88eb05 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
{ config, lib, options, pkgs, ... }:
with import ../../lib/pure.nix { inherit lib; };
let
  mk_peers = mapAttrs (n: v: { id = v.syncthing.id; });

  all_peers = filterAttrs (n: v: v.syncthing.id != null) config.krebs.hosts;
  used_peer_names = unique (filter isString (flatten (mapAttrsToList (n: v: v.devices) config.services.syncthing.folders)));
  used_peers = filterAttrs (n: v: elem n used_peer_names) all_peers;
in {
  services.syncthing = {
    enable = true;
    configDir = "/var/lib/syncthing";
    key = "${config.krebs.secret.directory}/syncthing.key";
    cert = "${config.krebs.secret.directory}/syncthing.cert";
    # workaround for infinite recursion on unstable, remove in 23.11
  } // (if builtins.hasAttr "settings" options.services.syncthing then
    { settings.devices = mk_peers used_peers; }
  else
    { devices = mk_peers used_peers; }
  );

  boot.kernel.sysctl."fs.inotify.max_user_watches" = 524288;
}