]> git.openstreetmap.org Git - chef.git/blob - cookbooks/snmpd/recipes/default.rb
Ensure snmpd.conf is created before starting snmpd
[chef.git] / cookbooks / snmpd / recipes / default.rb
1 #
2 # Cookbook:: snmpd
3 # Recipe:: default
4 #
5 # Copyright:: 2013, OpenStreetMap Foundation
6 #
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
10 #
11 #     https://www.apache.org/licenses/LICENSE-2.0
12 #
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.
18 #
19
20 include_recipe "networking"
21
22 communities = data_bag_item("snmpd", "communities")
23
24 package "snmpd"
25
26 template "/etc/snmp/snmpd.conf" do
27   source "snmpd.conf.erb"
28   owner "root"
29   group "root"
30   mode "600"
31   variables :communities => communities
32   notifies :restart, "service[snmpd]"
33 end
34
35 service "snmpd" do
36   action [:enable, :start]
37   supports :status => true, :restart => true
38 end
39
40 if node[:snmpd][:clients]
41   node[:snmpd][:clients].each do |address|
42     firewall_rule "accept-snmp" do
43       action :accept
44       family "inet"
45       source "net:#{address}"
46       dest "fw"
47       proto "udp"
48       dest_ports "snmp"
49       source_ports "1024:"
50     end
51   end
52 else
53   firewall_rule "accept-snmp" do
54     action :accept
55     family "inet"
56     source "net"
57     dest "fw"
58     proto "udp"
59     dest_ports "snmp"
60     source_ports "1024:"
61   end
62 end
63
64 if node[:snmpd][:clients6]
65   node[:snmpd][:clients6].each do |address|
66     firewall_rule "accept-snmp" do
67       action :accept
68       family "inet6"
69       source "net:#{address}"
70       dest "fw"
71       proto "udp"
72       dest_ports "snmp"
73       source_ports "1024:"
74     end
75   end
76 else
77   firewall_rule "accept-snmp" do
78     action :accept
79     family "inet6"
80     source "net"
81     dest "fw"
82     proto "udp"
83     dest_ports "snmp"
84     source_ports "1024:"
85   end
86 end