Skip to content

PhilippLemke/wireguard-formula

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

76 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

wireguard-formula

This formula is supposed to install WireGuard (usually dkms and utils), create and manage interfaces including peers. Configuration is done via pillar (see below).

Attention: WireGuard is not yet included in the linux mainline kernel. Also, the installation is different on every distribution and sometimes you even have to include unstable/testing branches. For now, please install WireGuard yourself. You can use this formula afterwards.

Important: On every configuration change, this formula restarts the wireguard interface in order to apply any changes.

Requirements

  • systemd: This formula makes use of wireguard-shipped systemd service files
  • wireguard kernel module

Installation

See the full Salt Formulas installation and usage instructions.

Configuration

All configuration is done via pillar data. See pillar.example for examples. This means in particular, that you do not have to use any of the following states youself.

Some keys can be present in the config file multiple times. To do this, you can start a list under a key. If the configuration format allows a single comma separated string for the respective key, they all will appear in the config file. Also see pillar.example.

Available modules

wireguard.create_peer_config

This module is designed to manage peers easily which are connected to the configured wireguard instance(s). It's add-on for this formular and not a mandatory component.

The module creates the following parts of configuration:

  • Standard Wireguard configuration files
  • QR-Codes from Wireguard configuration files (e.g. for smartphone import)
  • Additional Pillar File (easy_peer.sls) to include in pillar top.sls

Define-Pillar: (e.g. /srv/pillar/wireguard_new.sls) easy_peer:

Requirements

Available states

No states. Include wireguard in the top.sls file.

base:
  'some_minion':
    - wireguard

About

Saltstack formula for wireguard

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 77.1%
  • SaltStack 15.8%
  • HTML 7.1%