2 # Cookbook Name:: networking
3 # Definition:: firewall_rule
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 # http://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 define :firewall_rule, :action => :accept do
25 inet = resources(:template => "/etc/shorewall/rules")
26 inet6 = resources(:template => "/etc/shorewall6/rules")
31 :action => params[:action].to_s.upcase,
32 :source => params[:source],
33 :dest => params[:dest],
34 :proto => params[:proto],
35 :dest_ports => params[:dest_ports] || "-",
36 :source_ports => params[:source_ports] || "-",
37 :rate_limit => params[:rate_limit] || "-"
40 if params[:family].nil?
41 inet.variables[:rules] << rule unless inet.nil?
42 inet6.variables[:rules] << rule unless inet6.nil?
43 elsif params[:family].to_s == "inet"
44 inet.variables[:rules] << rule unless inet.nil?
45 elsif params[:family].to_s == "inet6"
46 inet6.variables[:rules] << rule unless inet6.nil?
48 log "Unsupported network family" do