ansible_ipsec

ANSIBLE IPSEC

Install ipsec (LibreSwan)/ Currently supports:

  • CentOS/RHEL 7

Requirements

We are not setting any iptables rules here, if you need any, use another role for that.

Role Variables

Almost everything is setup by defaults/main.yml (you can check there). But you need to set at least 1 connection (there is a fake one in defaults/main.yml.

Be very carefull with values, Ansible will change yes/no to True/False and will try to interpret things with {} like 'subnets' ipsec option. Trust me, I lost a few hours before discover that that was my problem, check my defaults file.

Dependencies

Create a vault protected secret string for the ipsec secret:

  echo -ne 'supersecret' | ansible-vault encrypt_string  --ask-vault-pass --stdin-name 'secret'

This needs to be done this way, so we do not add extra line breakers at the end of the string

Example Playbook

    - hosts: all
      roles:
         - { role: kleinstuff.ansible_ipsec }
      vars:
         ansible_ipsec__conns:
           ipsec_conn_1_name:
             dpdaction: restart
             dpdtimeout: 120
             pfs: 'no'
             authby: secret
             lifetime: 3600s
             dpddelay: 30
             auto: start
             aggressive: 'yes'
             ike: aes256-sha1;modp2048
             leftid: OUR PUBLIC IP (set here the elastic IP if you are using an AWS EC2)
             left: OUR LOCAL IP (can be the same as the public)
             leftsubnets: '{ OUR SUBNETS }'
             right: THE OTHER SIDE PUBLIC IP
             rightsubnets: '{ THE OTHER SIDE SUBNETS }'
             secret: !vault |
                   $ANSIBLE_VAULT;1.1;AES256
                   32633463653339363465616363346363363330313336386563326638343366653934353333346331
                   3533333038343332356632656166616339383637373039380a303431323635653634343339363831
                   37663664616133396237363531336435306537376632396362663662613134386336336665313838
                   6632396236376439620a363264643661396165363538343466303061623762336162643333373462
                   6636

You can add as many "ipsec_conns" you need.

License

GPL

Author Information

If you want to suggest changes or request new features, please feel free to create a issue or send a pull request.

About

Role to install and configure ipsec (LibreSwan)

Install
ansible-galaxy install kleinstuff/ansible-ipsec
GitHub repository
License
gpl-3.0
Downloads
28
Owner