rsync::site dependency cleanup, part 1
authorPeter Palfrader <peter@palfrader.org>
Tue, 10 Sep 2019 07:31:27 +0000 (09:31 +0200)
committerPeter Palfrader <peter@palfrader.org>
Tue, 10 Sep 2019 07:32:51 +0000 (09:32 +0200)
We define three things: a .service file, a .socket file, and a service.

Previously, the service would require the two files, and the .socket
file would also notify the service.  Change that to the service
subscribing to the files, so it gets a) applied after the files, and
b) refreshed if either changes.

This seems cleaner.  The net change should be that the service gets
also notified if the .service file changes.

modules/rsync/manifests/site.pp

index c762d6d..45836df 100644 (file)
@@ -46,17 +46,14 @@ define rsync::site (
                owner   => 'root',
                group   => 'root',
                mode    => '0444',
-               notify  => [
-                       Exec['systemctl daemon-reload'],
-                       Service["rsyncd-${name}.socket"],
-               ],
+               notify  => Exec['systemctl daemon-reload'],
        }
 
        service { "rsyncd-${name}.socket":
                ensure   => $ensure_service,
                enable   => $ensure_enable,
-               require  => [
-                       Exec['systemctl daemon-reload'],
+               notify   => Exec['systemctl daemon-reload'],
+               subscribe => [
                        File["/etc/systemd/system/rsyncd-${name}@.service"],
                        File["/etc/systemd/system/rsyncd-${name}.socket"],
                ],