# # Copyright (C) 2015 eNovance SAS <licensing@enovance.com> # # Licensed under the Apache License, Version 2.0 (the "License"); you may # not use this file except in compliance with the License. You may obtain # a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. # # == Class: tripleo::firewall::post # # Firewall rules during 'post' Puppet stage # # === Parameters: # # [*debug*] # (optional) Set log output to debug output # Defaults to false # # [*firewall_settings*] # (optional) Allow to add custom parameters to firewall rules # Should be a hash. # Default to {} # # [*logging_settings*] # (optional) Allow to add custom parameters to the logging firewall rule # Should be a hash. # Default to {} # class tripleo::firewall::post( $debug = false, $firewall_settings = {}, $logging_settings = {}, ){ if $debug { warning('debug is enabled, the traffic is not blocked.') } else { $default_logging_extras = { 'burst' => '15', 'limit' => '20/min', } $logging_extras = merge($default_logging_extras, $logging_settings) tripleo::firewall::rule{ '998 log all': proto => 'all', jump => 'LOG', tag => 'tripleo-firewall-postrule', extras => $logging_extras, } tripleo::firewall::rule{ '999 drop all': proto => 'all', action => 'drop', extras => $firewall_settings, tag => 'tripleo-firewall-postrule', } notice('At this stage, all network traffic is blocked.') } }