5 # Copyright:: 2011, OpenStreetMap Foundation
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
11 # https://www.apache.org/licenses/LICENSE-2.0
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
20 include_recipe "networking"
26 node[:rsyncd][:modules].each do |name, details|
27 writable_paths << details[:path] if details[:write_only]
29 hosts_allow[name] = details[:hosts_allow] || []
31 if details[:nodes_allow]
32 hosts_allow[name] |= search(:node, details[:nodes_allow]).collect do |n|
33 n.ipaddresses(:role => :external)
37 hosts_deny[name] = details[:hosts_deny] || []
39 next unless details[:nodes_deny]
41 hosts_deny[name] |= search(:node, details[:nodes_deny]).collect do |n|
42 n.ipaddresses(:role => :external)
48 systemd_service "rsync-override" do
51 exec_start "/usr/bin/rsync --daemon --no-detach --bwlimit=16384"
52 read_write_paths writable_paths.sort
53 notifies :restart, "service[rsync]"
57 action [:enable, :start]
58 supports :status => true, :restart => true
61 template "/etc/default/rsync" do
66 notifies :restart, "service[rsync]"
69 template "/etc/rsyncd.conf" do
70 source "rsyncd.conf.erb"
74 variables :hosts_allow => hosts_allow, :hosts_deny => hosts_deny
77 firewall_rule "accept-rsync" do