Saltstack Official IPTables Formula
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

68 行
2.1KB

  1. iptables_{{ chain_name }}_{{ rule_name }}:
  2. {%- if rule.position is defined %}
  3. iptables.insert:
  4. - position: {{ rule.position }}
  5. {%- else %}
  6. iptables.append:
  7. {%- if loop.index != 1 %}
  8. - require:
  9. - iptables: iptables_{{ chain_name }}_{% if service_name is defined %}{{ service_name }}_{% endif %}{{ loop.index - 1 }}
  10. {%- endif %}
  11. {%- endif %}
  12. - table: {{ rule.get('table', 'filter') }}
  13. - chain: {{ chain_name }}
  14. {%- if rule.family is defined %}
  15. - family: {{ rule.family }}
  16. {%- endif %}
  17. {%- if rule.jump is defined %}
  18. - jump: {{ rule.jump }}
  19. {%- endif %}
  20. {%- if rule.match is defined %}
  21. - match: {{ rule.match }}
  22. {%- endif %}
  23. {%- if rule.comment is defined %}
  24. - comment: {{ rule.comment }}
  25. {%- endif %}
  26. {%- if rule.connection_state is defined %}
  27. - connstate: {{ rule.connection_state }}
  28. {%- endif %}
  29. {%- if rule.protocol is defined %}
  30. - proto: {{ rule.protocol }}
  31. {%- endif %}
  32. {%- if rule.destination_port is defined %}
  33. - dport: {{ rule.destination_port }}
  34. {%- endif %}
  35. {%- if rule.source_port is defined %}
  36. - sport: {{ rule.source_port }}
  37. {%- endif %}
  38. {%- if rule.in_interface is defined %}
  39. - in-interface: {{ rule.in_interface }}
  40. {%- endif %}
  41. {%- if rule.out_interface is defined %}
  42. - out-interface: {{ rule.out_interface }}
  43. {%- endif %}
  44. {%- if rule.to_destination is defined %}
  45. - to-destination: {{ rule.to_destination }}
  46. {%- endif %}
  47. {%- if rule.to_port is defined %}
  48. - to-port: {{ rule.to_port }}
  49. {%- endif %}
  50. {%- if rule.to_source is defined %}
  51. - to-source: {{ rule.to_source }}
  52. {%- endif %}
  53. {%- if rule.source_network is defined %}
  54. - source: {{ rule.source_network }}
  55. {%- endif %}
  56. {%- if rule.destination_network is defined %}
  57. - destination: {{ rule.destination_network }}
  58. {%- endif %}
  59. {%- if chain.policy is defined %}
  60. - require_in:
  61. - iptables: iptables_{{ chain_name }}_policy
  62. {%- endif %}
  63. {%- if grains.get('virtual_subtype', None) not in ['Docker', 'LXC'] %}
  64. - require:
  65. - iptables: iptables_{{ chain_name }}{% if rule.family is defined %}_{{ rule.family }}{% endif %}
  66. {%- endif %}
  67. - save: True