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