This charm provides OpenVPN Community VPN.
This Charm installs and configures the VPN service and creates client certificates. What can you do with this Charm?
- Give remote users secure access to an internal network and let them use internal DNS servers.
- Secure remote users' communications by tunneling all their traffic through a secure connection.
Deploy the application and you're ready to go!
Juju deploy openvpn-puppet
Please note that this charm must be deployed on physical or virtual machines. This Charm does not work in LXC/LCD containers. Also note that changing the key settings will cause existing client configs to fail.
Metrics
This Charm exposes the number of connected clients using a juju metric.
$ juju metrics --all
UNIT TIMESTAMP METRIC VALUE
openvpn-puppet/0 2016-11-27T15:05:25Z users 1
You can find more detailed status information on the unit itself.
# On the openvpn-puppet unit
sudo cat /var/log/openvpn/openvpn-server1-status.log
Get client config file
Once the OpenVPN application is ready, you will need to download the client configuration in order to connect. The charm creates a <client-name>.ovpn
config file in /home/ubuntu
for every client specified in the application config. You can download the config with juju scp
.
juju scp openvpn-puppet/0:~/<client-name>.ovpn .
Install OpenVPN client
Install the OpenVPN network-manager integration. This will add the "VPN connections" menu in the network applet.
sudo apt install network-manager-openvpn-gnome
Add VPN using config file
-
Click the Network applet.
-
Choose
VPN connections > Configure VPN
as shown in the picture below. -
Scroll all the way down and click "import a saved VPN configuration".
-
Select the
.ovpn
config file, add the VPN, and connect using the network applet. -
[Optional] Regardless of server configuration, NetworkManager uses the VPN as default gateway, effectively sending ALL traffic over the VPN. If you set
push-default-gateway
to False and want NetworkManager to respect that setting, you need extra configuration on the client. Edit the VPN connection > IPv4 Settings > Routes...'. -
[Optional] Then mark "Use this connection only for resources on its network." -->
Alternative: start OpenVPN from commandline
sudo apt install openvpn
sudo openvpn --config <client-name>.ovpn
# Use the following command if you want to use the DNS settings that the OpenVPN server pushes
sudo openvpn --config <client-name>.ovpn --script-security 2 --up /etc/openvpn/update-resolv-conf --down /etc/openvpn/update-resolv-conf
- push-dns [
True
]: Set to False if clients shouldn't use the server's DNS settings. - push-default-gateway [
True
]: Set to False if you want to use the VPN only for connections to servers in the private subnet. By default, ALL traffic will go over the VPN. Note that NetworkManager uses the VPN as default gateway regardless of server config. Useopenvpn
from the commandline to enable this behavior. - port and protocol [
443:tcp
]:443:tcp
and8080:tcp
have the least chance of being blocked by firewalls.1194:udp
is the fastest. - key-* : Information for key certificate. You don't actually need to change this.
- NetworkManager uses the VPN as default gateway regardless of server config. Follow steps 6. and 7. to disable this.
- For cases where the VPN is not be the default gateway, and DNS settings are enabled, it is important to keep in mind that the clients will have two options for DNS nameservers: a public one (from the clients network) and a private one (from the network behind the VPN). The
openvpn
cli client will strictly use the private nameserver. Network Manager is a little bit smarter. Network Manager will send the DNS query to the public nameserver unless the url address is part of the search domain of the private network. This means that if the search domain on the private network isexample.com
, queries forintranet.example.com
will be send to the private DNS server and queries forwww.google.com
will be send to the public DNS server. More information: https://bugs.launchpad.net/ubuntu/+source/openvpn/+bug/1211110/comments/50
Report bugs on the tengu-charms
Github project.
This software was created in the IBCN research group of Ghent University in Belgium. This software is used in Tengu, a project that aims to make experimenting with data frameworks and tools as easy as possible.
- Merlijn Sebrechts merlijn.sebrechts@gmail.com
- Images come from TorGuard OpenVPN guide and AskUbuntu.