Переглянути джерело

Inserts deny rules first, to ensure they take precedence

tags/v0.2.0
Rob Ruana 6 роки тому
джерело
коміт
62fbb150de
1 змінених файлів з 8 додано та 1 видалено
  1. +8
    -1
      _states/ufw.py

+ 8
- 1
_states/ufw.py Переглянути файл

@@ -94,6 +94,9 @@ def _add_rule(method, name, app=None, interface=None, protocol=None,
try:
out = __salt__['ufw.add_rule'](rule)
except (CommandExecutionError, CommandNotFoundError) as e:
if method.startswith('insert 1 deny') and "Invalid position '1'" in e.message:
# This is probably the first rule to be added, so try again without "insert 1"
return _add_rule('deny', name, app, interface, protocol, from_addr, from_port, to_addr, to_port, comment)
return _error(name, e.message)

adds = False
@@ -111,6 +114,10 @@ def _add_rule(method, name, app=None, interface=None, protocol=None,
if __opts__['test']:
return _test(name, "{0} would have been configured".format(name))
break

if method.startswith('insert 1 deny') and "Invalid position '1'" in line:
# This is probably the first rule to be added, so try again without "insert 1"
return _add_rule('deny', name, app, interface, protocol, from_addr, from_port, to_addr, to_port, comment)
return _error(name, line)

if adds:
@@ -181,7 +188,7 @@ def default_outgoing(name, default):
def deny(name, app=None, interface=None, protocol=None,
from_addr=None, from_port=None, to_addr=None, to_port=None, comment=None):

return _add_rule('deny', name, app, interface, protocol, from_addr, from_port, to_addr, to_port, comment)
return _add_rule('insert 1 deny', name, app, interface, protocol, from_addr, from_port, to_addr, to_port, comment)


def limit(name, app=None, interface=None, protocol=None,

Завантаження…
Відмінити
Зберегти