X-Git-Url: http://git.scottworley.com/syncthing-autoregister/blobdiff_plain/7fb0951bc9caf6bd5cf71439638beea3499a0acc..274332f765ef56a9ca46f83859f5208849cb4c30:/modules/syncthing-autoregister.nix?ds=sidebyside diff --git a/modules/syncthing-autoregister.nix b/modules/syncthing-autoregister.nix index 158cd52..ad710f6 100644 --- a/modules/syncthing-autoregister.nix +++ b/modules/syncthing-autoregister.nix @@ -4,14 +4,33 @@ let cfg = config.services.syncthing.autoRegister; localpkgs = import ../. { inherit pkgs; }; register-script = pkgs.writeShellScript "syncthing-autoregister-script" '' - ${localpkgs.syncthing-set-id}/bin/syncthing-set-id /tmp/syncthing-auto-register-test-device-ids.nix + ${localpkgs.syncthing-set-id}/bin/syncthing-set-id ${ + escapeShellArg cfg.path + } ''; in { options = { services.syncthing.autoRegister = { enable = mkEnableOption '' - Automatically write the local syncthing device id to /tmp/syncthing-auto-register-test-device-ids.nix + Automatically write the local syncthing device id to the nix module + file . ''; + path = mkOption { + type = types.path; + description = '' + Path of nix module file to write our syncthing + device id into. It will be written into + services.syncthing.declarative.devices..id. This file + can be imported as a NixOS module. + + We recommend using a separate file just for this purpose. I.e., + don't point this at your main NixOS config. Instead, import this + file from your main NixOS config. (The current nix-configuration + read-modify-write implementation only supports attrsets of strings; + it does not support functions, which you probably use in your + main configuration.) + ''; + }; }; }; config = mkIf cfg.enable { @@ -26,6 +45,20 @@ in { ExecStart = register-script; }; }; + systemd.services.syncthing-reregister = { + after = [ "syncthing-autoregister.service" ]; + script = '' + ${pkgs.coreutils}/bin/sleep 1 + ${pkgs.systemd}/bin/systemctl restart syncthing-autoregister + ''; + serviceConfig = { + Type = "oneshot"; + }; + }; + systemd.paths.syncthing-reregister = { + pathConfig.PathChanged = cfg.path; + wantedBy = [ "multi-user.target" ]; + }; }; }