Saltstack Official UFW Formula

README.md 1.8KB

6 years ago
6 years ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. # Ufw Salt Formula
  2. [![Build Status](https://travis-ci.org/aanriot/ufw-formula.svg?branch=master)](https://travis-ci.org/aanriot/ufw-formula)
  3. This module manages your firewall using ufw with pillar configured rules.
  4. See the full [Salt Formulas installation and usage instructions](http://docs.saltstack.com/topics/development/conventions/formulas.html).
  5. ## Usage
  6. All the configuration for the firewall is done via pillar (pillar.example).
  7. Enable firewall, applying default configuration:
  8. ```javascript
  9. ufw:
  10. enabled: True
  11. ```
  12. Allow 80/tcp (http) traffic from only two remote addresses:
  13. ```
  14. ufw:
  15. services:
  16. http:
  17. protocol: tcp
  18. from_addr:
  19. - 10.0.2.15
  20. - 10.0.2.16
  21. ```
  22. Allow 443/tcp (https) traffic from network 10.0.0.0/8 to an specific local ip:
  23. ```
  24. ufw:
  25. services:
  26. https:
  27. protocol: tcp
  28. from_addr:
  29. - 10.0.0.0/8
  30. to_addr: 10.0.2.1
  31. ```
  32. Allow from a service port:
  33. ```
  34. ufw:
  35. services:
  36. smtp:
  37. protocol: tcp
  38. ```
  39. Allow from an specific port, by number:
  40. ```
  41. ufw:
  42. services:
  43. 139:
  44. protocol: tcp
  45. ```
  46. Allow from a range of ports, udp:
  47. ```
  48. ufw:
  49. services:
  50. "10000:20000":
  51. protocol: udp
  52. ```
  53. Allow from two specific ports, udp:
  54. ```
  55. ufw:
  56. services:
  57. "30000,40000":
  58. protocol: udp
  59. ```
  60. Allow an application defined at /etc/ufw/applications.d/:
  61. ```
  62. ufw:
  63. applications:
  64. - OpenSSH
  65. ```
  66. ## Run tests
  67. This formula is tested with [Kitchen](https://kitchen.ci/) and [Inspec](https://www.inspec.io/) in a Docker container.
  68. To run tests you need to
  69. * install Ruby dependencies : `bundle install`
  70. * run Kitchen : `kitchen test`
  71. ## Authors
  72. Original state and module based on the work from [Yigal Duppen](https://github.com/publysher/infra-example-nginx/tree/develop).
  73. Salt formula originally developed by Mario del Pozo.