A CLI tool for automating the importing, securing and usage of NordVPN OpenVPN servers through NetworkManager.
Project description
I don’t plan to actively maintain this repository any further. I haven’t used NordVPN’s services in quite some time and lacking an account also makes testing it more difficult. If you are interested in becoming a maintainer, please contact me at ``nordnm@ross.ch`` and I can provide direct access to the repository.
This tool automates the importing and secures the usage of NordVPN (and eventually any) OpenVPN configurations through Network Manager.
Disclaimer: I am not associated with Tesonet/NordVPN in any shape or form, nor do I recommend their services for sensitive traffic (or any other private VPN provider for that matter). If you plan on using this tool for anonymity much beyond circumventing geo-blocking, I would recommend a different approach.
Using a self-hosted VPN solution (such as Algo) provides higher assurance that your traffic isn’t being monitored by a bad actor. Better yet, use TOR or another mix network.
WebRTC Privacy Warning: This tool can’t protect against IP leaks through WebRTC in browsers. For more information: The WebRTC “bug”
Features:
If you encounter a problem or have a feature request, please make an issue report and it will be looked into ASAP.
Small Footprint: Nordnm does not use any background processes. Once a synchronise has finished, it’s all handled by Network Manager.
Improved readability: Humanly readable connection names, so you can easily tell what each connection offers.
Only import what you need: Your preference of countries, VPN categories and protocols can be saved, to synchronise only the options you need.
Always up-to-date: The tool can be configured to always check if it is using the latest NordVPN OpenVPN configuration files.
Server Benchmarking: Servers are benchmarked according to their latency and server load, to determine the optimal options available.
Auto-Connect: A server of your choice can be set to automatically activate whenever you connect to the Internet.
DNS Tunnelling: DNS requests are forced to go through the VPN tunnel, to prevent privacy ruining DNS leaks.
IPv6 Disabled: IPv6 is disabled by default, to avoid IPv6 leaks.
Kill-Switch: Set a network kill-switch, to disable the network interface being used if the active VPN disconnects.
MAC Address Manipulation: Change the MAC address used by Network Manager in a variety of ways (randomization, spoofing, etc), to avoid tracking across networks.
1. Installation
1.1 Arch (AUR)
Use your preferred method of installing packages via AUR. An easy option is to use yay:
yay -S nordnm
1.2 Debian/Ubuntu
wget -qO - https://bintray.com/user/downloadSubjectPublicKey?username=bintray | sudo apt-key add - sudo apt-add-repository "https://dl.bintray.com/chadsr/nordnm-deb main" sudo apt update && sudo apt install nordnm
1.3 RPM Based Distributions (Fedora, CentOS, etc)
wget https://bintray.com/chadsr/nordnm-rpm/rpm -O bintray-chadsr-nordnm-rpm.repo sudo mv bintray-chadsr-nordnm-rpm.repo /etc/yum.repos.d/ sudo yum install nordnm
1.4 Python PIP
Note: If you install via PIP, system dependencies will need to be installed manually. It is therefore recommended to install via your system package manager. If your system is not yet listed above, leave an issue and it can be added ASAP.
If your default Python version is 2.x (check using ``python -V``), you will need to use pip3 below
System Install
sudo -H pip install nordnm
User Install
pip install --user nordnm
2. Usage
usage: nordnm [-h] [-v] [-k] [-i] [-a [COUNTRY_CODE] [VPN_CATEGORY] [PROTOCOL]] ... optional arguments: -h, --help show this help message and exit -v, --version Display the package version. -k, --kill-switch Sets a network kill-switch, to disable the active network interface when an active VPN connection disconnects. -i, --disable-ipv6 Disable IPv6 when enabling a VPN connection -a [COUNTRY_CODE] [VPN_CATEGORY] [PROTOCOL], --auto-connect [COUNTRY_CODE] [VPN_CATEGORY] [PROTOCOL] Configure NetworkManager to auto-connect to the chosen server type. Takes country code, category and protocol. commands: Each command has its own help page, which can be accessed via nordnm <COMMAND> --help remove (r) Remove active connections, auto-connect, kill-switch, disabling ipv6, data, mac settings or all. update (u) Update a specified setting. list (l) List the specified information. sync (s) Synchronise the optimal servers (based on load and latency) to NetworkManager. import (i) Import an OpenVPN config file to NetworkManager. mac (m) Global NetworkManager MAC address preferences. This command will affect ALL NetworkManager connections permanently.
Note: Each command has its own help section, which can be acccessed via nordnm <COMMAND> --help.
2.1 Example Usage
View available categories and countries:
sudo nordnm list --categories --countries
Synchronise current optimal servers, activate the kill-switch and auto-connect to a “normal” UDP server in the US:
sudo nordnm sync -ka us normal udp
Same as above, but don’t check for latest configuration files:
sudo nordnm sync -nka us normal udp
View metrics of the synchronised servers:
sudo nordnm list --active-servers
Set your MAC address to be randomised each time you connect to a network:
sudo nordnm mac --random
Change the auto-connect to another synchronised server:
sudo nordnm -a ru p2p udp
Import a specific OpenVPN configuration file while still using the killswitch and autoconnect features (Experimental):
sudo nordnm import /home/foo/config.ovpn -ak -u username -p password
Update the settings:
sudo nordnm update --settings
Update the user credentials:
sudo nordnm update --credentials
Disable the network kill-switch:
sudo nordnm remove --kill-switch
Remove all settings and files:
sudo nordnm remove --all
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file nordnm-0.8.1.tar.gz
.
File metadata
- Download URL: nordnm-0.8.1.tar.gz
- Upload date:
- Size: 37.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.5.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 35fe63fd5f2a25345d5caa59e9932336f58f1b563a49bac67170ced2fe81099f |
|
MD5 | 52f1a21db3add30fb1d8c173fbe7e3c0 |
|
BLAKE2b-256 | 002414b9ab0c99f185474b8ff063195d6f94ea56be9099b6990cbcb80f227e1a |