Difference between revisions of "Mullvad"

From ArchWiki
Jump to: navigation, search
(I had problems running Mullvad in Arch so I thought it might be useful the share the solution to my problems.)
 
(Using Mullvad as plain OpenVPN)
(One intermediate revision by one other user not shown)
Line 1: Line 1:
 +
[[Category:Virtual Private Network]]
 
==Using Mullvad as plain OpenVPN==
 
==Using Mullvad as plain OpenVPN==
  
 
To use the VPN service Mullvad on Arch Linux a few small adjustments need to be done. First, install [[OpenVPN]] and [[resolvconf]]. Download the plain [[OpenVPN]] version of Mullvad [http://mullvad.net/en/openvpn_conf.php "here"]. Next, copy the content of the zip file to /etc/openvpn. Open the file mullvad_linux.conf and change the end of the file from  
 
To use the VPN service Mullvad on Arch Linux a few small adjustments need to be done. First, install [[OpenVPN]] and [[resolvconf]]. Download the plain [[OpenVPN]] version of Mullvad [http://mullvad.net/en/openvpn_conf.php "here"]. Next, copy the content of the zip file to /etc/openvpn. Open the file mullvad_linux.conf and change the end of the file from  
    # Parses DHCP options from openvpn to update resolv.conf
+
{{hc|mullvad_linux.conf|<nowiki>
    up /etc/openvpn/update-resolv-conf
+
# Parses DHCP options from openvpn to update resolv.conf
    down /etc/openvpn/update-resolv-conf
+
up /etc/openvpn/update-resolv-conf
   
+
down /etc/openvpn/update-resolv-conf
    ping 10
+
   
+
    ca master.mullvad.net.crt
+
    cert mullvad.crt
+
    key mullvad.key
+
  
 +
ping 10
 +
 +
ca master.mullvad.net.crt
 +
cert mullvad.crt
 +
key mullvad.key
 +
</nowiki>}}
 
to
 
to
 +
{{hc|mullvad_linux.conf|<nowiki>
 +
# Parses DHCP options from openvpn to update resolv.conf
 +
# up /etc/openvpn/update-resolv-conf
 +
# down /etc/openvpn/update-resolv-conf
 +
up /usr/share/openvpn/update-resolv-conf
 +
down /usr/share/openvpn/update-resolv-conf
  
    # Parses DHCP options from openvpn to update resolv.conf
+
ping 10
    # up /etc/openvpn/update-resolv-conf
+
 
    # down /etc/openvpn/update-resolv-conf
+
ca /etc/openvpn/master.mullvad.net.crt
    up /usr/share/openvpn/update-resolv-conf
+
cert /etc/openvpn/mullvad.crt
    down /usr/share/openvpn/update-resolv-conf
+
key /etc/openvpn/mullvad.key
   
+
</nowiki>}}
    ping 10
+
and make it executable by running
   
+
    sudo chmod +x /etc/openvpn/mullvad_linux.conf
    ca /etc/openvpn/master.mullvad.net.crt
+
    cert /etc/openvpn/mullvad.crt
+
    key /etc/openvpn/mullvad.key
+
  
Following [[OpenVPN]], load the tun module
+
Load the tun module by creating the file
 
{{hc|/etc/modules-load.d/tun.conf|<nowiki>
 
{{hc|/etc/modules-load.d/tun.conf|<nowiki>
 
# Load tun.ko at boot
 
# Load tun.ko at boot
Line 88: Line 93:
 
</nowiki>}}
 
</nowiki>}}
  
and don't forget to make it executable by running chmod +x
+
and don't forget to make it executable by running
 +
    sudo chmod +x /usr/share/openvpn/update-resolv-conf
  
 
Lastly create the file
 
Lastly create the file
Line 96: Line 102:
 
openvpn /etc/openvpn/mullvad_linux.conf
 
openvpn /etc/openvpn/mullvad_linux.conf
 
</nowiki>}}
 
</nowiki>}}
 +
make it executable
 +
    sudo chmod +x /usr/bin/mullvad
 
and simply run Mullvad in the terminal by typing
 
and simply run Mullvad in the terminal by typing
 
     sudo mullvad
 
     sudo mullvad

Revision as of 10:33, 6 November 2012

Using Mullvad as plain OpenVPN

To use the VPN service Mullvad on Arch Linux a few small adjustments need to be done. First, install OpenVPN and resolvconf. Download the plain OpenVPN version of Mullvad "here". Next, copy the content of the zip file to /etc/openvpn. Open the file mullvad_linux.conf and change the end of the file from

mullvad_linux.conf
# Parses DHCP options from openvpn to update resolv.conf
up /etc/openvpn/update-resolv-conf
down /etc/openvpn/update-resolv-conf

ping 10

ca master.mullvad.net.crt
cert mullvad.crt
key mullvad.key

to

mullvad_linux.conf
# Parses DHCP options from openvpn to update resolv.conf
# up /etc/openvpn/update-resolv-conf
# down /etc/openvpn/update-resolv-conf
up /usr/share/openvpn/update-resolv-conf
down /usr/share/openvpn/update-resolv-conf

ping 10

ca /etc/openvpn/master.mullvad.net.crt
cert /etc/openvpn/mullvad.crt
key /etc/openvpn/mullvad.key

and make it executable by running

   sudo chmod +x /etc/openvpn/mullvad_linux.conf

Load the tun module by creating the file

/etc/modules-load.d/tun.conf
# Load tun.ko at boot
tun

and create

/usr/share/openvpn/update-resolv-conf
#!/bin/bash
#
# Parses DHCP options from openvpn to update resolv.conf
# To use set as 'up' and 'down' script in your openvpn *.conf:
# up /etc/openvpn/update-resolv-conf
# down /etc/openvpn/update-resolv-conf
#
# Used snippets of resolvconf script by Thomas Hood <jdthood@yahoo.co.uk>
# and Chris Hanson
# Licensed under the GNU GPL.  See /usr/share/common-licenses/GPL.
#
# 05/2006 chlauber@bnc.ch
#
# Example envs set from openvpn:
# foreign_option_1='dhcp-option DNS 193.43.27.132'
# foreign_option_2='dhcp-option DNS 193.43.27.133'
# foreign_option_3='dhcp-option DOMAIN be.bnc.ch'

[ -x /usr/sbin/resolvconf ] || exit 0

case $script_type in

up)
   for optionname in ${!foreign_option_*} ; do
      option="${!optionname}"
      echo $option
      part1=$(echo "$option" | cut -d " " -f 1)
      if [ "$part1" == "dhcp-option" ] ; then
         part2=$(echo "$option" | cut -d " " -f 2)
         part3=$(echo "$option" | cut -d " " -f 3)
         if [ "$part2" == "DNS" ] ; then
            IF_DNS_NAMESERVERS="$IF_DNS_NAMESERVERS $part3"
         fi
         if [ "$part2" == "DOMAIN" ] ; then
            IF_DNS_SEARCH="$part3"
         fi
      fi
   done
   R=""
   if [ "$IF_DNS_SEARCH" ] ; then
           R="${R}search $IF_DNS_SEARCH
"
   fi
   for NS in $IF_DNS_NAMESERVERS ; do
           R="${R}nameserver $NS
"
   done
   echo -n "$R" | /usr/sbin/resolvconf -a "${dev}.inet"
   ;;
down)
   /usr/sbin/resolvconf -d "${dev}.inet"
   ;;
esac

and don't forget to make it executable by running

   sudo chmod +x /usr/share/openvpn/update-resolv-conf

Lastly create the file

/usr/bin/mullvad
 #! /bin/bash
# Script to start Mullvad
openvpn /etc/openvpn/mullvad_linux.conf

make it executable

   sudo chmod +x /usr/bin/mullvad

and simply run Mullvad in the terminal by typing

   sudo mullvad