Re: [ansible-project] ufw or iptables module

1,893 views
Skip to first unread message

Michael DeHaan

unread,
Feb 11, 2013, 2:29:11 AM2/11/13
to ansible...@googlegroups.com
I'm conceptually interested, though I think there is a reason iptables
is *typically* best managed by a template and then issuing a service
load command. (Namely, expressing rules some other way is a little
difficult, because there is so much you can do). Curious what you
had in mind?

Note Fedora18 is apparently going to Firewalld -- haven't tried it yet.

I like the idea of being able to easily punch holes in firewalls.

I think Seth Vidal was using lokkit in his playbooks for this purpose.

--Michael

On Sun, Feb 10, 2013 at 6:15 PM, Oscar Korz <okor...@gmail.com> wrote:
> Hi,
>
> I'm wondering if anyone is working on either a ufw or iptables module. If
> not, I will start my own (with the intention of contributing it back). I
> just want to avoid duplicating work if anyone else has started this.
>
> Thanks,
> Oscar.
>
> --
> You received this message because you are subscribed to the Google Groups
> "Ansible Project" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to ansible-proje...@googlegroups.com.
> For more options, visit https://groups.google.com/groups/opt_out.
>
>

Ahmad Khayyat

unread,
Feb 11, 2013, 8:40:49 AM2/11/13
to ansible...@googlegroups.com
I use shorewall to manage iptables, and rely on its support for a rules.d directory.

In /etc/shorewall/rules:
SHELL cat /etc/shorewall/rules.d/*.rules

Then, each service that needs a port open installs its own rule file, e.g.:
/etc/shorewall/rules.d/ssh.rules

Shorewall's formats are simple enough to manage with templates.

Tin Tvrtković

unread,
Feb 11, 2013, 9:15:34 AM2/11/13
to ansible...@googlegroups.com
I've generally only needed to open up very specific ports on my hosts, nothing very complicated. For that I've used snippets like:

  - name: ensure PostgreSQL main port is open
    shell: iptables -D INPUT -p tcp --dport 5432 -j ACCEPT; iptables -I INPUT -p tcp --dport 5432 -j ACCEPT && iptables-save


It's kinda clumsy since you have to drop the rule first so they don't pile up. I'd love an iptables module that'd make this more elegant. For my needs it needn't be very complex.

Oscar Korz

unread,
Feb 11, 2013, 7:55:42 PM2/11/13
to ansible...@googlegroups.com
I haven't though too much into how to do this task yet. It's an outstanding action item for what I need to maintain with ansible. In the past when I used chef, I did indeed use a template to generate a shell script.

Conceptually, I like that there's an authorized_keys module. I don't want to be bothered with generating the actual file, I just want to describe what keys I do and do not want on this host. I'd like to create a ufw module that provides a similarly clean abstraction. 

My organization is currently using ufw to maintain the firewall rules, so if I'm going to be developing something (which it sounds like I will be doing), then I will be targeting this. However, this is my first exposure to ufw so I'm not sure of the best way to manage this.

It appears that ufw uses iptables rules files, so I suppose I could just template this. The assemble module looks interesting as well. However, I think I could also use ufw directly, taking advantage of --dry-run to determine whether or not this task will be "ok" or "changed". Do any other modules spawn child processes, or are most things done in process with pure Python? I'm very open to suggestions about this, if people have any opinions.

To be honest, I think I'm just excited about an opportunity to learn more about ufw and ansible. I'm naturally curious about my systems and tools.

Michael DeHaan

unread,
Feb 11, 2013, 7:58:37 PM2/11/13
to ansible...@googlegroups.com
>
> It appears that ufw uses iptables rules files, so I suppose I could just
> template this. The assemble module looks interesting as well. However, I
> think I could also use ufw directly, taking advantage of --dry-run to
> determine whether or not this task will be "ok" or "changed". Do any other
> modules spawn child processes, or are most things done in process with pure
> Python? I'm very open to suggestions about this, if people have any
> opinions.

It's totally ok for them to call other shell commands, and many
modules do. Main thing
is only to call them to change things when a change is needed (basic
idempotency stuff).

>
> To be honest, I think I'm just excited about an opportunity to learn more
> about ufw and ansible. I'm naturally curious about my systems and tools.

Cool!

Ben Hood

unread,
Feb 11, 2013, 11:04:19 PM2/11/13
to ansible...@googlegroups.com
I'd love to see some declarative handling for iptables in ansible - I'd like to be able to declare a bunch of rules that need to exist and have the module worry about whether they currently exist or not. Having said that, I'd be intrigued as to how you delineate between asserting the existence of additional rules that aren't already in iptables and being able to assert the entire state of the iptables (i.e. delete the entire table and reload each rule).

Seth Vidal

unread,
Feb 12, 2013, 3:37:55 AM2/12/13
to ansible...@googlegroups.com


On Sun, 10 Feb 2013, Michael DeHaan wrote:

> I'm conceptually interested, though I think there is a reason iptables
> is *typically* best managed by a template and then issuing a service
> load command. (Namely, expressing rules some other way is a little
> difficult, because there is so much you can do). Curious what you
> had in mind?
>
> Note Fedora18 is apparently going to Firewalld -- haven't tried it yet.
>
> I like the idea of being able to easily punch holes in firewalls.
>
> I think Seth Vidal was using lokkit in his playbooks for this purpose.
>


I was using lokkit out of laziness and out of a desire to send a playbook
to someone that would do everything w/o having to include a template file
w/it.

-sv

Oscar Korz

unread,
Feb 18, 2013, 6:34:28 AM2/18/13
to ansible...@googlegroups.com
After only three hours of hacking yesterday morning, I'm quite satisfied with my initial results. I was quite surprised and excited to find out that ufw's CLI parsing is smart enough to realize that the following rules are all identical:

* ufw allow 22
* ufw allow to any port 22
* ufw allow from any to any port 22

This means I don't have to parse anything myself and can just run the command and trust ufw's output to determine whether or not applying this changed the firewall state.

Well, almost. Apparently removing a rule that doesn't actually exist always generates output as if the firewall state had changed. So this is my first bug. But otherwise, it's functional. This kind of false positive is the same thing that would happen if the command module was used to manipulate ufw, so I don't consider it a huge detriment, but it's still something I'd like to fix somehow. (I haven't checked if this is a known bug with ufw; it's certainly a bug in my opinion!)

I'm posting this here as a status update and to see if there's any interest or suggestions. It is not meant as a submission at this point. It's not documented like the official modules yet but the source is trivial enough to you should be able to follow it.

My fork:

My ufw module:

I'm quite pleased with how easy ansible was to extend. The three hours of hacking started with reading the ansible module API for the first time! :)

Jonathan Palley

unread,
Feb 18, 2013, 5:44:42 PM2/18/13
to ansible...@googlegroups.com
For what its worth I have an (old and not-well-developed) module for punching holes in iptables: https://github.com/brainpage/ansible-library/blob/master/iptables

When I wrote this the general discussion was iptables should be managed with templates.  We've ultimately moved to a combination: templates as a basis + complex chains while using this module to punch holes for different services/apps that may or may not be on the server.

Oscar Korz

unread,
Feb 19, 2013, 8:09:43 PM2/19/13
to ansible...@googlegroups.com
Hi Peter,

I will look into this.

There are still a few other minor things here and there missing, so its definitely still a work in progress. For example, default policies, and in|out on INTERFACE.

Oscar.

On Monday, February 18, 2013 3:35:14 PM UTC-8, Peter Petrov wrote:
Hey Oscar, thanks a lot for the ufw module.

One suggestion: you could add support for numbered rules (ufw insert NUM ...). The order of rules is sometimes important.

Cheers,
Peter

Oscar Korz

unread,
Feb 25, 2013, 3:04:05 AM2/25/13
to ansible...@googlegroups.com
Hi Peter,

At first I was certain this was not a useful feature, given that insert NUM is only meaningful if you know the ordering of all existing rules. However, I just remembered that ansible's register clause can be used to access stdout of previous tasks. So I guess this is useful if you grep the output of "ufw status numbered" to determine where to insert your rules. ufw will not re-insert a rule if the only difference is the number.

The alternative to this is to use ansible to insert both rules. Playbook's tasks are executed in order, so you know the ordering will be correct. However, I guess there is an issue if for some reason the first rule (assuming a pair of rules) gets deleted after the fact... Hmm.

Anyway, I've updated my fork today with support for your request as well as "in|out on INTERFACE" which was required for my organization.

On Monday, February 18, 2013 3:35:14 PM UTC-8, Peter Petrov wrote:
Hey Oscar, thanks a lot for the ufw module.

One suggestion: you could add support for numbered rules (ufw insert NUM ...). The order of rules is sometimes important.

Cheers,
Peter

David Reagan

unread,
Sep 15, 2013, 3:53:07 AM9/15/13
to ansible...@googlegroups.com
What's the status of the ufw module? I'm looking into how to manage firewalls in Ansible, and since I already somewhat understand the basics of ufw, this sounded good. :)

Mathieu Martin

unread,
Sep 15, 2013, 4:26:32 AM9/15/13
to ansible...@googlegroups.com
I was wondering exactly that, moments ago. I'd love to have a ufw module, even if it's not perfect.

I found another ufw module in ansible-examples's riak playbook. I'm glad you've pointed out this one though, it looks less hacky than the one in the examples.

Mat


--
You received this message because you are subscribed to the Google Groups "Ansible Project" group.
To unsubscribe from this group and stop receiving emails from it, send an email to ansible-proje...@googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.



--

I'm the founder of Rock Solid Ops, a web operations and development consultancy.

My main fields of expertise are web development with Ruby on Rails, DevOps and a bit of mobile development. If you need help scaling, monitoring, securing or managing your web infrastructure (Rails or not), get in touch!

Connect with me and read testimonials on my LinkedIn, follow me on twitter @webmat, or check out my blog at programblings.com.

Michael DeHaan

unread,
Sep 15, 2013, 3:38:07 PM9/15/13
to ansible...@googlegroups.com
The status would be that I'm open to entertaining pull requests.

Without a pull request, it's not really "in process" yet.

There is an open pull request for a firewalld module, but not one for ufw yet.

Would definitely be welcome.

--Michael


Michael DeHaan <mic...@ansibleworks.com>
CTO, AnsibleWorks, Inc.
http://www.ansibleworks.com/

David Reagan

unread,
Sep 15, 2013, 4:13:52 PM9/15/13
to ansible...@googlegroups.com
And it doesn't look like Oscar Korz has done anything on his fork for the last 7 months. 

I'll repeat his link here: https://github.com/okorz001/ansible/blob/ufw/library/ufw I'd try to work on it myself, but I don't think that's the kind of project I want to use to learn Python...

Anyone else want to tackle it?

How good is the firewalld module? 

jo...@wrale.com

unread,
Nov 6, 2013, 10:51:00 PM11/6/13
to ansible...@googlegroups.com
This is awesome... Thank you!

Gonzalo Sainz Trápaga

unread,
Nov 22, 2013, 8:04:08 PM11/22/13
to ansible...@googlegroups.com
It seems there is an iptables frontend called "ferm" that does the trick quite nicely based on a single config file and templates. I will give it a shot and document the results afterwards, but using this might solve the issue without custom modules.

David Reagan

unread,
Nov 23, 2013, 2:32:09 AM11/23/13
to ansible...@googlegroups.com
I actually found Ferm via the Sovereign set of playbooks a while back. I just couldn't quite make the pieces fit together well enough to write a role for it, and the one from Sovereign didn't work for me when looked at it..

Fortunately, I found that I can template /lib/ufw/user.rules and make ufw work for me a few days ago.

Templating rules that look like:

### tuple ### allow any 22 0.0.0.0/0 any 0.0.0.0/0 in
-A ufw-user-input -p tcp --dport 22 -j ACCEPT
-A ufw-user-input -p udp --dport 22 -j ACCEPT


### tuple ### allow any 443 0.0.0.0/0 any 0.0.0.0/0 in
-A ufw-user-input -p tcp --dport 443 -j ACCEPT
-A ufw-user-input -p udp --dport 443 -j ACCEPT

Is a lot easier than FireHOL, ferm, or Shorwall's methods.

'Course, I think my role is pretty limited in what it can do, but still, at least it makes sense to me. :)

My ufw role is still very rough and I've only tested it on a vagrant vm, so I don't really have anything to share. But at least you all know it's possible. :)

--David Reagan


--
You received this message because you are subscribed to a topic in the Google Groups "Ansible Project" group.
To unsubscribe from this topic, visit https://groups.google.com/d/topic/ansible-project/I1Vd3oPBfFw/unsubscribe.
To unsubscribe from this group and all its topics, send an email to ansible-proje...@googlegroups.com.

James Martin

unread,
Nov 25, 2013, 3:02:43 PM11/25/13
to ansible...@googlegroups.com
I have been using a home-grown ufw module for a while. Just today I
decided to submit a pull request to get it pulled in to ansible:

https://github.com/ansible/ansible/pull/5048

Please test, comment, add feature requests, etc.

- James
> You received this message because you are subscribed to the Google Groups
> "Ansible Project" group.
> To unsubscribe from this group and stop receiving emails from it, send an

Gastón Sánchez

unread,
Apr 23, 2014, 8:00:06 PM4/23/14
to ansible...@googlegroups.com, jma...@basho.com
Now there is an ufw module.

Reply all
Reply to author
Forward
0 new messages