All changes to the software that can be noticed from the users' perspective should have an entry in this file. Except very minor things that will not affect functionality, such as log message changes and minor GUI adjustments.
The format is based on Keep a Changelog.
Entries should have the imperative form, just like commit messages. Start each entry with words like add, fix, increase, force etc.. Not added, fixed, increased, forced etc.
Line wrap the file at 100 chars. That is over here -> |
- Added: for new features.
- Changed: for changes in existing functionality.
- Deprecated: for soon-to-be removed features.
- Removed: for now removed features.
- Fixed: for any bug fixes.
- Security: in case of vulnerabilities.
- Add a new Let's Encrypt root certificate.
- Add possibility to create account from the login screen.
- Add welcome screen for newly created accounts.
- Allow submitting voucher codes to add time to the account.
- Add Out Of Time screen for user to add more time to account once it expires.
- Move location of the account data (including the WireGuard keys), so that it isn't lost when the system cache is cleaned.
- Rename "Block when disconnected" setting to "Always require VPN" and add additional explanation of the setting.
- Embed TLS certificates used for HTTPS into the binary rather than loading them from disk at runtime.
- Ignore case when setting the relay or bridge location in the CLI.
- Upgrade OpenVPN from 2.4.8 to 2.4.9 and the OpenSSL version it uses from 1.1.1d to 1.1.1g.
- Upgrade shadowsocks-rust to version 1.8.10.
- Always enable the beta program when running a beta version.
- Increase relay list download failure retry interval from 5 to 15 minutes. And from 5 seconds to 15 minutes for the WireGuard key rotation retry interval.
- Adjust the minimum supported Android version to correctly reflect the supported versions decided in 2020.4-beta2. The app will now only install on Android 7 and later (API level 24).
- Fix crash when leaving WireGuard Key screen while key is still verifying.
- Fix crash that sometimes happens right after some other unrelated crash.
- Fix app not connecting when pressing the notification or quick-settings tile when the service isn't running. It would previously just open the app UI and stay in the disconnected state.
- Fix crash when requesting to connect from notification or quick-settings tile.
- Fix version update notifications not appearing.
- Fix UI losing any settings updates that happen after leaving the app and then coming back.
- Fix account expiration date disappearing in some circumstances.
- Fix notification reappearing after quitting the application.
- Retry when fetching account expiration fails.
This release is identical to 2020.4-beta4
- Fix bogus or absent update notifications on the desktop app due to incorrect deserialization of a struct sent from the daemon.
- App will now use packaged relay list if it's newer than the cached one.
- Fix relay list sort order.
- Remove all log files on uninstall. Clear install.log on upgrades.
- Add shell completions for the mullvad CLI. Installed for bash and zsh on Linux and zsh on macOS.
- Downgrade to Electron 7 due to issues with tray icon in Electron 8.
- Use rustls instead of OpenSSL for TLS encryption to the API and GeoIP location service.
- When required, attempt to enable IPv6 for network adapters instead of failing.
- Update the WireGuard Key screen so that it looks the same as on the desktop app. It is now reached through the Advanced settings screen.
- Enable IPv6 in WireGuard regardless of the specified MTU value, previously IPv6 was disabled if the MTU was below 1380.
- Improve offline detection logic.
- Enable missing IPv6 interface on the WireGuard TUN adapter when it has been disabled.
- Change button colors on problem report no email confirmation dialog to match the desktop version.
- Fix crash when attempting to run app from the non-default location, such as the SD card or from a different user profile.
- Ship native Node modules unpacked to prevent malware checks by macOS on each run. The malware checks delayed app startup when "block when disconnected" was enabled and performed system network requests to Apple.
- Fix failure to create tunnel when app is started with auto-connect enabled. This would sometimes lead to a traffic leak.
- Add possibility to create account in the desktop app.
- Add possibility to pay with voucher in the desktop app.
- Add WireGuard MTU setting.
- Allow
fc00::/7
instead offd00::/8
in the firewall when local network sharing is enabled. Should unblock all unique local addresses. - Upgrade from Electron 7 to Electron 8.
- Formalize what operating system versions we support in the readme. In practice this means dropped support for Android 5 and 6 and Fedora 28 and 29 right away, Ubuntu 16.04 support will end as soon as Ubuntu 20.04 comes out.
- Windows 7 only: Address packet loss issues with OpenVPN on some systems by reverting the TAP adapter driver to an older NDIS 5 driver.
- Add signal handlers on Linux, macOS and Android to better log critical faults with the daemon.
- Add WireGuard MTU setting to desktop app.
- Add option to receive notifications about new beta releases.
- Add option to enable auto-connecting behavior
- Include an initial relay list in the APK so that the app can connect to the VPN even if it fails to connect to the API after it is installed.
- Add a reconnect button to disconnect and connect again without closing the tunnel device to avoid leaking any data during the reconnection.
- Add quick settings tile to control the tunnel state.
- Enable IPv6 traffic through the tunnel.
- Prefer WireGuard when tunnel protocol is set to auto on Linux and MacOS.
- Wait for tunnel state machine to properly shut down, cleaning up the firewall properly on Windows during the daemon shutdown.
- Switch to new logo.
- Show better message when the app failed to block all connections after an error.
- Fix bug that could lead to Javascript error dialog to appear upon the desktop app termination.
- Fix rendering glitch in the map and improve the map's resource usage.
- Fix firewall rules to properly handle DNS requests over TCP when "Local network sharing" is disabled. Previously DNS requests over TCP would timeout.
- Fix notification action button not working when requesting to connect the tunnel after being disconnected for a long time.
- Make the settings screen scrollable, so that the quit button is reachable on small screens.
- Fix connectivity listener leak causing possible battery usage increase.
- Fix crash that could sometimes happen when restarting the background service.
- Fix incorrect location information sometimes shown in main screen.
- Fix bug where failing to initialize the route manager could cause the daemon to get stuck in a blocked state. This only affected WireGuard.
- When upgrading or reinstalling while connected, exit the daemon in a blocking state to prevent unintended leaks. This only affects upgrades from this release.
- Fix issue in daemon where the
block_when_disconnected
setting was sometimes not honored when stopping the daemon. I.e. traffic could flow freely after the daemon was stopped.
- Fix issue where IPv6 traffic could leak outside of the tunnel.
This release is identical to 2020.3-beta1
- Fix stack overflow caused by WireGuard key rotation timers. When the daemon crashed it was restarted automatically. But it did not connect (depending on settings), leaving a leak.
This release is identical to 2020.2-beta1
- Add reconnect button to the desktop app.
- Add monochrome option for the tray icon on Windows and Linux.
- Show OS notification when account is close to expiry on desktop platforms.
- Warn users running old app versions when creating problem report.
- Add option to enable or disable local network sharing.
- Show account history in login fragment
- Change project copyright and company name from Amagicom AB to Mullvad VPN AB
- Only reconnect when settings change if a relevant tunnel protocol is used.
- Adjust padding of tray icon on Windows and Linux to better match other icons.
- Change the zoomlevel of the map in the desktop app to make it less zoomed in.
- Bundle new API IP with the app (Old: 193.138.218.73, new: 193.138.218.78)
- Remove city/country labels on map in the desktop app.
- Fix app sometimes getting stuck in connecting state when using WireGuard.
- Fix crash when removing the service from foreground on Android versions below API level 24.
- Fix crash that happened in certain situations when retrieving the relay list.
- Fix crash caused by initialization race condition.
- Fix "exhausted namespace" installation error on some non-English systems.
- Stop DNS leak that could happen on all desktop platforms if "Local network sharing" was enabled and the device had a default DNS resolver on the local private network. The leak could happen during these states: While connecting, when blocked due to an error happening and when disconnected if the "block when disconnected" setting was enabled. This issue has been present on all previous versions of the app.
- Prevent DNS leak that could happen while connected if "Local network sharing" was enabled and the device had a default DNS resolver on the local private network. This issue was only present in the 2020.1 release.
This release is identical to 2020.1-beta1
- Add translations for Finnish and Danish.
- Copy WireGuard key when clicking on it.
- Sign all binaries in the app instead of just the installer.
- Increase OpenVPN ping timeout from 20 to 25 seconds. Might make working tunnels disconnect a bit less frequently.
- Use traffic data from WireGuard to infer connectivity, instead of continuously pinging. Should improve stability of the connection and reduce power use.
- Update
wireguard-go
tov0.0.20200121
- Remove WireGuard keys from accounts when they are removed from the local account history.
- Upgrade from Electron 6 to Electron 7.
- Disable WireGuard protocol option if there's no WireGuard key.
- Wait for traffic to be routed through the tunnel device before advertising blocked state.
- Connect automatically if
MullvadVpnService
is started with an intent which has theandroid.net.VpnService
action. Effectively, this should enable Always On behavior on Android versions where it's supported. - Allow notification to be dismissed when the UI is not shown and the tunnel is disconnected.
- Use a branded TAP driver for OpenVPN to prevent conflicts with other software and solve issues related to driver upgrades. Also use the NDIS 6 driver on Windows 7.
- Be more aggressive when installing routes, in effect taking ownership of existing duplicate route entries. This allows the daemon to initialize properly even if a previous instance did not have a clean shutdown.
- Don't try to replace WireGuard key if account has too many keys already.
- Fix bogus update notification caused by an outdated cache.
- Fix layout issues when showing messages in WireGuard key view.
- Fix translation of "System default" after selecting "System default" in language settings.
- Fix regression due to which a TAP adapter issue was not given as the specific block reason when the tunnel could not be started.
- Fix occasional failure to shut down the old daemon process during installation by killing it if necessary.
- Make WireGuard work with IPv6 enabled even if there is no functioning TAP adapter for OpenVPN.
- Restart daemon when coming back from system hibernation with terminated user session, since it's perceived as a cold boot from the user's perspective, so the app should act accordingly.
- Change the optimization level for releases from the default value to
s
, as a temporary fix for the system service crashing on Windows for newer CPU models.
- Fix notification message to not show
null
version when version check cache is stale right after an update. - Fix
null
pointer exception when connectivity event intent has no network info. - Fix fast loop trying to fetch location and preventing the device from sleeping. This should improve battery life in some cases.
- Fix crash when starting the app right after quitting it.
- Restart background service if it stops responding.
- Fix crash when VPN permission is revoked, either manually or by starting another VPN app.
- Fix crash caused by local JNI reference table overflow after running for a long time.
- Dismiss notification after service has stopped.
- Don't show missing connectivity error message in WireGuard key management screen if a reconnection is expected to happen.
- Fix showing new key as invalid immediately after regeneration.
- DNS management with static
/etc/resolv.conf
will now work even when no/etc/resolv.conf
exists.
- Add automatic key rotation for WireGuard (every 7 days by default). This limits the potential for an attacker to correlate traffic with a public key and identity, and reduces the harm of software that might leak the private tunnel IP (since it is no longer fixed).
- Stop OpenVPN from loading
C:\etc\ssl\openssl.cnf
on start. This file was being loaded when an OpenVPN tunnel was being created. Any user could create the file, and the process loading it runs as the SYSTEM user. Since the config file allows loading arbitrary code, it was an attack vector allowing local unprivileged users to run code as SYSTEM.
- Limit macOS firewall rules to only allow UDP packets in the rules meant to enable being a DHCPv4 server when local network sharing is enabled.
- Fix improved WireGuard port selection.
- Register 'NSI' service as a dependency of the daemon service.
- Set daemon service SID type as 'unrestricted'.
- Properly tear down routes after disconnecting from WireGuard relays.
- Fix bug that prohibited WireGuard from working over port 53.
- Stop CVE-2019-14899 by dropping all packets destined for the tunnel IP coming in on some other interface than the tunnel.
- Add
mullvad relay set tunnel-protocol
subcommand to the CLI to specify what tunnel protocol to use. - Add
mullvad reconnect
subcommand to the CLI to make the app pick a new server and reconnect.
- Full WireGuard support, GUI and CLI.
- Install Wintun driver that provides the WireGuard TUN adapter.
- Remove Mullvad TAP adapter on uninstall. Also remove the TAP driver if there are no other TAP adapters in the system.
- Add connectivity status check. Stopping the app from sitting in a reconnect loop while the device is offline.
- Notifications shown when connecting to a server include its location.
- Upgrade OpenVPN from 2.4.7 to 2.4.8.
- Upgrade OpenSSL from 1.1.1c to 1.1.1d.
- When using WireGuard without specifying a specific relay port, port 53 will be used after 2 failed connection attempts for 2 out of 4 each successive connection attempts
- Use a larger icon in notifications on Windows 10.
- Only update DNS settings if updating would change the effective settings. This is a work-around
to avoid invoking
netsh
unnecessarily and getting stuck in associated hangs. - Don't restart the service immediately if it aborts several times in a row. Leave a window of ten minutes to allow for addressing the issue.
- Upgrade libsodium from 1.0.17 to 1.0.18.
- Upgrade NDIS 6 TAP driver from 9.21.2 to 9.24.2.
- Improve stability on Linux by using the routing netlink socket in its own thread.
- When trying to use
resolvconf
for managing DNS, the daemon will check ifdnsmasq
is running and misconfigured. - Improve stability on Linux by simplifying route management code.
- Detect removal of the OpenVPN TAP adapter on reconnection attempts.
- Improve robustness in path environment variable logic in Windows installer. Handle the case where the registry value type is incorrectly set to be a regular string rather than an expandable string.
- Fix suspend and resume issues with OpenVPN by upgrading the TAP driver.
- Minor adjustment in online/offline detection logic. This change addresses misbehaving drivers that report the adapter flags incorrectly.
- Don't try to fetch location when the app knows that it has no connectivity. This should reduce wake-ups (improving battery life) and also fix very large log files consuming storage space.
- Fix crash when a new version event is received while the app is in the main screen.
- Force OpenVPN to use TLS 1.2 or newer, and limit the TLS 1.3 ciphers to only the strongest ones. The Mullvad servers have never allowed any insecure ciphers, so this was not really a problem. Just one extra safety precaution.
This release is for Android only.
- Use authenticated URLs to go to wireguard key page on website.
- WireGuard key fragment has been made more similar to its desktop counterpart.
- Fix bad file descriptor errors caused by sending a file descriptor between the daemon and the
wireguard-go
library. - Recreate tun device after a fixed number of connection attempts on the same tun device. Breaks infinite reconnection loops on broken tun devices.
- Add ability to submit vouchers from the CLI.
- Add a symlink for
mullvad-problem-report
directly in/usr/bin
. So the tool is available.
- Install the OpenVPN certificate to avoid the TAP adapter driver installation warning on Windows 8 and newer.
- Rename the
problem-report
tool tomullvad-problem-report
.
- Fix Norwegian (Bokmal) language detection.
- Fix missing localizations when formatting date and time in Norwegian (Bokmal).
- Use authenticated URL to go to account page from expired account view.
- Remove
mullvad
andmullvad-problem-report
symlinks from/usr/local/bin
on uninstall.
- Add ability to change the desktop GUI language from within Settings.
- Add ability to create new accounts from the CLI.
- Add CLI tools (the resource/ directory) to the system PATH.
- Notarize release builds with Apple. Making them run without warning on 10.15 Catalina.
- Add settings button in launch and login screens. Making it possible to reach the problem report.
- Add support for Android 5.x Lollipop.
- Allow logging in without connectivity.
- Account and WireGuard keys links in the App will now log the user in automatically.
- Update FAQ URL to
https://mullvad.net/help/tag/mullvad-app/
.
- Remove support for
MULLVAD_LOCALE
environment variable.
- Remove connect action button in notification when logged out.
- Fix
mullvad relay update
to trigger a relay list download even if the existing cache is new. - Don't include problem-report arguments in error logging. Stops user email from ending up in the log file on error.
- Fix handling of tunnel file descriptor for WireGuard. Duplicating and closing it correctly.
- Show WireGuard key age in local timezone instead of UTC.
- Android 6 and older: Fix notification button icons.
- Fix collapsing tunnel information causing tunnel out IP address information to be lost.
- Various stability fixes.
- More adjustments in online/offline detection logic. Should prevent more users from being stuck in the offline state. Should also make the app notice network disconnects faster.
This release is identical to 2019.8-beta1
- Add ability to replace the WireGuard key with a new one. Allows manual key rotation.
- Show age of currently set WireGuard key.
- Add bridge selection under "Select location" view, when the bridge mode is set to "On".
- Initial support for the Android platform.
- Decreased default MTU for WireGuard to 1380 to improve performance over 4G
- WireGuard key page now shows a label explaining why buttons are disabled when in a blocked state
- WireGuard key generation will try to replace old key if one exists.
- Show banner about new app versions only if current platform has changes in latest release.
- Don't make a GeoIP lookup by default in CLI status command. Add --location flag for enabling it.
- Sort relay locations and hostnames with natural sorting. Meaning
se10
will show up afterse2
. - Show inactive relays as disabled instead of hiding them completely from location selection list.
- Upgrade Electron from version 4 to version 6.
- Change uninstaller registry key name from
Mullvad VPN
to a generated GUID.
- Fix old settings deserialization to allow migrating settings from versions older than 2019.6.
- Fix various small issues in GUI<->daemon communication.
- Make GUI WireGuard key verification resilient to failure.
- Fix issue where daemon would try and connect with UDP when the tunnel protocol is set to OpenVPN and the bridge mode is set to "On".
- Don't start ping monitor loop if first ping fails when checking WireGuard connection.
- Respect localization when sorting the relay locations list.
- Unregister the app properly from the OS when running the bundled
uninstall.sh
script.
- Fix bug in netlink parsing in offline detection code.
- Removed logic that implemented monitoring and enforcement of DNS settings.
- Add more details to the block reason shown in GUI when the daemon fails to generate tunnel parameters.
- Check and adjust relay and bridge constraints when they are updated, so no incompatible combinations are used.
- Fix panic when running CLI "mullvad relay set custom" without any more arguments.
- Add new settings page for generating and verifying wireguard keys.
- Automatically generate and upload WireGuard keys on Linux and macOS.
- Allow activating and using WireGuard from the GUI under advanced settings on Linux and macOS.
- Add
factory-reset
CLI command for removing settings, logs and clearing the cache.
- Upgrade OpenVPN from 2.4.6 to 2.4.7.
- Upgrade OpenSSL from 1.1.0h to 1.1.1c.
- Upgrade wireguard-go library to v0.0.20190805.
- Mark CLI
bridge set state
argument as required to avoid a crash. - The VPN service on Windows will now be restarted when it crashes.
- Retry to connect when WireGuard tunnel fails due to a bad file descriptor.
- Improve resolv.conf based DNS management to detect changes to file.
- Add simplified Chinese translations.
- Add a switch to turn off system notifications under Preferences in the GUI.
- Add migration logic to restore lost settings after major Windows update.
- Add the Mullvad CLI frontend and problem report CLI tool to the PATH, so it can be run directly from a terminal.
- Fix the mix of traditional and simplified Chinese. Separating them to two locales and fall back to English where translations are missing.
- Adjust network interface checks in offline detection logic. Prevents the app from being stuck in the offline state when the computer is in fact online.
- Fix some netlink packet parsing error in DNS handling.
- Improve offline check so if it fails, it always fails as online.
- Add Norwegian translations.
- Add support for roaming between connections when using wireguard.
- Allow mDNS/discover to 239.255.255.251 when local network sharing is enabled. This change fixes the Wi-Fi calling via iPhone when both devices are on the same network.
- Allow incoming DHCPv4 requests and outgoing responses if allow local network is enabled. Enables being a DHCPv4 server.
- Add GUI translations for Italian, Japanese, Dutch, Portugese, Russian and Turkish.
- Add missing GUI translations for Czech Republic, USA and UK in the select location view.
- Add translations for the current location displayed on the main screen in the GUI.
- Allow a subset of NDP (Router solicitation, router advertisement and redirects) in the firewall.
- Add automatic Shadowsocks bridge usage. Will automatically try to obfuscate the tunnel via Shadowsocks after a number of failed connection attempts.
- Automatically include frontend logs in problem report when ran from CLI.
- Add standard window decorations to the application window.
- Relax the allow local network rules slightly. only checking either source or destination IP field instead of both. They are still unroutable.
- CLI commands that are just intermediate commands, and require another level of subcommands, will automatically print the available subcommands, instead of an error if none is given.
- Remove the
help
subcommand in the CLI. Instead get help with the--help
long flag.
- Stop allowing the wrong IPv6 net fe02::/16 in the firewall when allow local network was enabled. Instead allow the correct multicast nets ff02::/16 and ff05::/16.
- Fix the regression that allowed to get past the login screen using the invalid account token.
- Fix the GUI crash caused by a derefence of the already released remote object in Electron.
- Raise max number of open files for the daemon to 1024. Should prevent threads from panicking.
- Fix the visual defect that resulted in a semi-transparent grey line rendered above the window.
- Add better offline detection.
- Fix
systemd-resolved
detection by better checking/etc/resolv.conf
symlinks. - Improve detection of whether NetworkManager is the preferred DNS solution.
This release is identical to 2019.4-beta1
- When IPv6 is enabled, get both exit IP versions from am.i.mullvad.net and show.
- Add translations for country and city names in the relay list and map.
- Reset the tray icon padlock to the unsecured state when losing connectivity with the daemon.
- Increase timeout when updating DNS settings. Should make the DNS management fail less often.
- Use dynamic naming of TAP adapter to avoid collisions with existing adapters.
- On Windows Surface devices the keyboard now shows up correctly when selecting the account token input field.
- Make the firewall rules permanent until reboot, or until the daemon removes them. Should make the kill switch active even if the daemon dies unexpectedly.
- Correct dependencies on installer logger plugin to resolve installation issues on Windows 7/8.
- Remove the Mullvad OpenVPN intermediate transition CA. Used when transitioning from the old to the new root CA. Now the app only bundles and trust the new Mullvad root CA valid until 2028.
- Read the relay list from cache only if it's newer than the version bundled in the app.
- Integrate initial Shadowsocks proxy support. Accessible via CLI.
- Add initial Wireguard support on macOS and Linux. Accessible via CLI.
- Improve "Out of time" view button leading to the account website by unlocking internet access before opening the browser
- Add translations for German, Spanish, French, Swedish, Chinese languages
- Fix the potential reconnect loop in GUI, triggered by the timeout when receiving the initial state of the daemon.
- Fix the bug which caused the account token history to remain stale after logout.
- Fix some notifications not appearing depending on how the window is shown and hidden while the tunnel state changes.
- Fix DNS when using IPv6.
- Fix the bug when the "Out of time" view remained visible, even when the app managed to reconnect the VPN tunnel after a successful credit top-up.
- Sort the relay location list alphabetically in the GUI.
- Fix startup failure when network device with a hardware address that's not a MAC address is present.
- Improve error handling related to DNS management at the time of establishing the tunnel.
- Increase the timeout to the Mullvad API from 5 to 10 seconds.
- Increase
NetworkManager
DBus RPC timeout from 1 second to 3 seconds. - Improve notification look by adding application name and icon.
This release is identical to 2019.1-beta1
- Handle "block when disconnected" extra kill-switch level in the GUI, showing the disconnected state as blocked when appropriate and also having a toggle switch for the setting in the Advanced Settings screen.
- Add a drop-down warning to notify the user when the account credits are running low.
- Allow the 169.254.0.0/16 private network in addition to the other networks allowed when local network sharing is enabled.
- Improve the confirmation dialog when submitting a bug report without an email specified.
- Add a monochromatic tray icon option for the GUI.
- Detect if the computer is offline. If so, don't sit in a reconnect loop, instead block and show an error message.
- Add a toggle switch to allow the app to start minimized on Linux, so that only the tray icon is initially visible.
- Disable buttons and menus that open external links when the app knows that there is no internet connection.
- The auto-start and auto-connect toggles in the GUI have been reworked so that auto-connect configures the GUI to automatically connect when it starts and so that it will only auto-connect on boot when both settings are set.
- Stop GUI from glitching during the short reconnect state.
- Dismiss notifications automatically after four seconds in all platforms.
- Fix error printed from the CLI when issuing
relay update
. - Fix relay list update interval. Should now handle sleep better.
- Prevent GUI from sending connect commands to the daemon every time it establishes a connection to it. Only send connect once (if auto-connect is enabled.)
- Prevent possible reconnect loop where the GUI would indefinitely reconnect to the daemon.
- Fix the bug which enabled users to return to the login view if they went to settings while logging in.
- Handle in the GUI, if something external changes the account token in the daemon. I.e. triggered by CLI unsetting or resetting it.
- Fix Debian package not upgrading properly due to a bug in the post-remove script.
- Wait for NetworkManager and systemd-resolved services to start before daemon starts on platforms with systemd and those two services. Prevents the daemon from using the wrong DNS API.
- Gracefully block when TAP adapter is missing or disabled, instead of retrying to connect.
- Poll netfilter to verify firewall rules were added correctly. On Ubuntu 14.04 netfilter did not return any error, but it also ignored the rules the daemon tried to add.
This release is identical to 2018.6-beta1
- CLI command
relay update
that triggers an update of the relay list in the daemon. - Add extra level of kill-switch called "block when disconnected". Blocks all network traffic even
in the disconnected state. Not activated by default and can be changed via the CLI subcommand
block-when-disconnected
.
- Detect if the computer is offline. If so, don't sit in a reconnect loop, instead block and show an error message.
- Add ability to debug firewall rules with the
TALPID_FIREWALL_DEBUG
variable.
- Install tray icon in visible part of the notification area.
- Split DNS management from Firewall management to allow restoring DNS earlier and showing more detailed errors to users.
- Cancel pending system notifications when the app becomes visible.
- Transition to connected state after all routes are configured. Avoids problems with reaching the internet directly after the app says it's connected.
- Disable keep alive on API RPC requests. Should stop reuse of invalid sockets after tunnel state changes.
- Fix permissions on log dir so problem-report tool has permission to read daemon logs.
- Use proper app id in the registry. This avoids false-positives with certain anti-virus software.
- Handle sleep/resume events to quickly restore the tunnel when the machine wakes up.
- Add default route to fix NLA issues (Microsoft Store/Office/etc say the machine is offline).
- Update installer to not rely on WMI when enumerating network adapters.
- Increase timeout waiting for OpenVPN to shut down cleanly.
- Sign the bundled openvpn.exe binary. Should make some anti-virus software complain less.
- Replace OpenVPN root CA certificate bundled with the app to the new Mullvad root CA.
- Improve packaging on RPM based distros by re-enabling the daemon after an upgrade
- Fall back and try to connect over TCP port 443 if protocol is set to automatic and two attempts with UDP fail in a row. If that also fails, alternate between UDP and TCP with random ports.
- Add new system and in-app notifications to inform the user when the app becomes outdated, unsupported or may have security issues.
- Allow the user to view the relay in/out IP address in the GUI.
- Add OpenVPN proxy support via CLI.
- Allow DHCPv6 in the firewall.
- Pick new random relay for each reconnect attempt instead of just retrying with the same one.
- Make the
problem-report
tool fall back to the bundled API IP if DNS resolution fails.
- Correctly backup and restore search domains and other DNS settings.
- Disable GPU acceleration on Linux to fix App on Ubuntu 14.04 and other older distributions.
- Improve DNS management detection. Evaluates which way the system handles DNS before each new VPN tunnel is established instead of only on computer boot.
- Set DNS search domain when using the systemd-resolved. Makes it work on Ubuntu 18.10.
- Fix crash on Windows 7 when closing installer.
- Block all traffic to DNS servers other than the correct one in the tunnel. Stops potential DNS leaks when "Local network sharing" was enabled and DNS management failed.
- Fix so changing the OpenVPN mssfix setting triggers setting up a new tunnel with the new setting.
- Place Mssfix setting inside scrollable area.
- Fix so mssfix can be unset. Previously emptying the textbox did nothing.
- The app will have its window resized correctly when display scaling settings are changed. This should also fix bad window behaviour on startup.
- Fixed systemd-resolved DNS management. Skip using it as the DNS manager if it's running in consumer mode.
- Allow configuration of OpenVPN mssfix option with GUI (under Advanced Settings).
- Monitor and enforce IPv6 DNS settings on network interfaces (previously IPv4-only).
- Add support for DNS configuration using systemd-resolved and NetworkManager.
- Auto-hide scrollbars on macOS only, leaving them visible on other platforms.
- Instead of showing the public IP of the device in the UI, we show the hostname of the VPN server the app is connected to. Or nothing if not connected anywhere.
- Passing
--connect-timeout 30
to OpenVPN to decrease the time the daemon will wait until it tries to reconnect again in the case of a broken TCP connection. - Increase timeout parameter to OpenVPN from 15 to 20 seconds. Should make active VPN tunnels drop less frequent when on unstable networks.
- Reduce the transparency of "blocking internet" banner to increase the text readability.
- Make the quit button visible without needing to scroll down in the settings view.
- Move CLI binary to
/usr/bin/
as to have the CLI binary in the user'sPATH
by default.
- Remove
--comp-lzo
argument to OpenVPN. Disables any possibility of establishing a VPN tunnel with compression.
- Use different method for identifying network interfaces during installation. Should solve some installation errors.
- Properly restore DNS settings on network interfaces. Fixes issue #352.
- Allow packets to the fe80::/10 and fe02::/16 IPv6 networks when local network sharing is enabled. Should allow IPv6 over the LAN, and mDNS host discovery which in turn should allow Apple AirDrop and Handover among other IPv6 based LAN discovery services.
- Add support for DNS configuration using resolvconf.
- Logging in no longer requires a connection with the Mullvad API server.
- Replace repeated
Disconnecting
followed byConnecting
notifications with a singleReconnecting
notification.
- Don't temporarily show the unsecured state in the GUI when the app is reconnecting or blocking.
- Periodically update list of relays in the GUI.
- Redact IPv6 address that start or end with double colons in problem reports.
- Improve tray icon response time by disabling the double click handling.
- Prevent Electron from executing/navigating to files being drag-and-dropped onto the app GUI. This fixes MUL-01-001
- Move the CLI binary (
mullvad
) back into theResources/
directory. A bug caused the app to not be signed if it was placed in the app root directory.
- Lock the installation directory to
C:\Program Files\Mullvad VPN
. This prevents potential local privilege escalation by ensuring all binaries executed by theSYSTEM
user, as part of the Mullvad system service, are stored where unprivileged users can't modify them. This fixes MUL-01-004.
- Add option to enable or disable IPv6 on the tunnel interface. It's disabled by default.
- Log panics in the daemon to the log file.
- Warn in the Settings screen if a new version is available.
- Add a "blocked" state in the app that blocks the entire network and shows a message about what went wrong. Then it waits for user action.
- Add support for Ubuntu 14.04 and other distributions that use the Upstart init system.
- Make scrollbar thumb draggable.
- Ability to expand cities with multiple servers and configure the app to use a specific server.
- Add firewall rules allowing traffic to the SSDP/WS-discover multicast IP, 239.255.255.250, if local area network sharing is activated. This allows discovery of devices using these protocols.
- Add uninstall script that can uninstall and remove all the files installed by the app.
- Extend uninstaller to also remove logs, cache and optionally settings.
- Add installation log (%PROGRAMDATA%\Mullvad VPN\install.log).
- The "Buy more credit" button is changed to open a dedicated account login page instead of one having a create account form first.
- The CLI command to list relays is now shorter,
mullvad relay list
instead ofmullvad relay list locations
. - Replace WebSockets with Unix domain sockets/Named pipes for IPC. The location
of the socket can be controlled with
MULLVAD_RPC_SOCKET_PATH
. - Update the relay list if it's out of date when the daemon starts.
- Move the CLI binary (
mullvad
) on macOS and Linux up one level, so it's installed directly into the app installation directory instead of theresource
directory.
- Fix incorrect window position when using external display.
- Don't auto-connect the daemon on start if no account token is set. This prevents the daemon from blocking all internet if logging out from the app.
- The app window is now shown in its previous location, instead of at the center of the screen.
- Remove daemon log, cache and configuration directories during full uninstallation of the app.
- Restart the daemon automatically on upgrade.
- Fix systemd unit file to support older versions of systemd (e.g., in Debian 8).
- Fix edge cases when window's arrow appeared misaligned and pointed to the wrong menubar item.
- Make the pkg installer kill any running GUI process after installation is done. Prevents accidentally running an old GUI with a newer daemon.
- Failing to restore DNS settings on daemon start does not make the daemon exit with an error, just log the error and continue.
This release is identical to 2018.2-beta3
- Create a new UI log file for every UI execution session, and preserve the log from the previous session.
- Account token can be copied to the clipboard by clicking on it in the account settings screen.
- Automatically scroll to selected country/city in locations view.
- Show system notifications when connection state changes and the window is not visible.
- Add launch view displayed when connecting to system service.
- Format the expiry date and time using the system locale.
- Account tokens are now required to have at least ten digits.
- Rename directores for settings, logs and cache from
mullvad-daemon
tomullvad-vpn
.
- Use local user directory to store system service settings and GUI electron cache, instead of the roaming user directory.
- Where the system service would use
%LOCALAPPDATA%\Mullvad\Mullvad VPN\
it now just uses%LOCALAPPDATA%\Mullvad VPN\
- Ignore empty strings as redaction requests in the problem report tool, to avoid adding redacted markers between every character of the log message.
- Previously logged in users won't be going through login view when restarting the app, instead will be taken straight to main view.
- Bundle the root CA signing the API and only trust that single one, limiting trust to a single root CA
- Add a unique UUID to problem reports. Makes it easier for Mullvad support staff to find reports.
- Add "auto-connect" setting in daemon, and make it configurable from CLI. Determines if the daemon should secure the network and start establishing a tunnel directly when it starts on boot.
- Add "auto-connect" and "auto-start" options to the application preferences view.
- Include version information (meta data) in executables and DLLs.
- Include manifest in daemon so it always runs with administrator privileges.
- Add sidebar graphic in installer/uninstaller.
- App now uses statically linked OpenSSL on all platforms.
- Add OpenVPN logs at the top of the problem report instead of middle, to aid support work.
- Lower per log size limit in the problem report to 128 kiB.
- Relay list is now updated periodically automatically, not only when the daemon starts.
- Rename tunnel interface to "Mullvad".
- Change tunnel interface metric for both IPv4 and IPv6.
- Disable account input when logging in.
- Keep the user input in problem report form while the app runs, or until the report is successfully submitted.
- Hide the app icon from taskbar.
- Autohide the main window on focus loss.
- Loosen up firewall rules to allow incoming requests on tunnel interface.
- Properly stop the service, announcing errors to the system, in the event of initialization or runtime error.
- Refresh account expiration when account view becomes visible.
- Add
tunnel
subcommand to manage tunnel specific options in the CLI. - Add support for passing the
--mssfix
argument to OpenVPN tunnels. - Add details to mullvad CLI interface error for when it doesn't trust the RPC file.
- Include the last two OpenVPN logs in problem reports instead of only the last.
- Prevent two instances of the daemon to run at the same time.
- Add CLI command for fetching latest app versions and verifies whether the running version is supported.
- Add
version
subcommand in the CLI to show information about current versions. - Add a flag to daemon to print log entries to standard output without timestamps.
- Filter out and ignore DNS lookup results for api.mullvad.net that are bogus (private etc.)
- Bundle the Mullvad API IP address with the app and introduce a disk cache fallback method for when DNS resolution fails.
- Automatic rotation of the daemon log. The existing log is renamed to
daemon.old.log
on daemon startup. - Add
status listen
subcommand in the CLI to continuously monitor the tunnel state. - Log errors present in initialization sequence to the log file.
- Add colors to terminal output.
- Warn if daemon is running as a non-root user.
- Make the pkg installer uninstall any
<=2018.1
version of the app before installing itself.
- Changed "Contact support" label to "Report a problem" in settings menu
- Change all occurrences of "MullvadVPN" into "Mullvad VPN", this affects paths and window captions etc.
- Improve account token hint to be the same length as an expected token.
- Update
problem-report
binary to automatically collect log files in predefined known Mullvad log directories. - Replaced previously bundled OpenVPN 2.4.4 with statically linked 2.4.6 version containing Mullvad patches for faster connect and other improvements.
- Increase the OpenVPN receive and send buffers from 524288 to 1048576 bytes (1MiB).
- Make the log, cache, settings and RPC address directories configurable via the following
environment variables:
MULLVAD_LOG_DIR
,MULLVAD_CACHE_DIR
,MULLVAD_SETTINGS_DIR
andMULLVAD_RPC_ADDRESS_PATH
.
- The installer changed from dmg to pkg format.
- The daemon is installed as a launchd daemon and started on install and on boot.
- Move daemon logs to
/var/log/mullvad-daemon/
, settings to/etc/mullvad-daemon/
and cache to/var/root/Library/Caches/mullvad-daemon/
.
- Remove the
shutdown
command from the CLI.
- Fix scroll flickering.
- Fix bug in account input field that advanced the cursor to the end regardless its prior position.
- Redact all 16 digit numbers from problem report logs. Extra safety against accidentally sending account numbers.
- Fix OpenVPN plugin search directory to be the installation directory.
- Reduce RPC timeout to Mullvad API server.
- Fix OpenVPN warning about usage of AES-256-CBC cipher.
- Fix "Out of time" screen status icon position.
- If necessary, create parent directories for RPC connection info file and tunnel log.
- Fix error message when attempting to login when the daemon isn't running .
- Redact all account numbers in the account number history from problem reports instead of only the currently logged in one.
- Increase a timeout for problem report collection to fix a timeout error on slower machines.
- Fix a memory leak in the problem report collection routine.
- Fix an issue when viewing a problem report brought up a dialog to choose the application to open the file.
- Show the app version in the settings view.
- Require confirmation when sending problem reports without an email address.
- Fix erroneous styles in the settings view.
- Update the CRL with newly revoked server certificates.
- Uses the https://am.i.mullvad.net/ service to figure out location and public IP of the device. The app then shows this information in the unsecured state.
- Argument to the daemon,
--resource-dir <path>
, that allows customizing where it will look for needed resource files. - A very stylish map now indicates where you are connecting through.
- Fixed a bug where the problem report tool would redact some things in the logs which were not IPv6 addresses, but looked like ones.
- Show a better error message when api.mullvad.net is unreachable.
- Fix bug getting daemon state on frontend start instead of assuming it.
- "Allow LAN" setting that configures if the app should allow communication to the LAN (private networks: 10/8, 192.168/16 and 172.16/12) while the app is in the secured state.
- The app can now be used to connect to all our servers rather than a smaller subset. The list of servers is automatically updated when the app starts.
- The location selector now shows if the country or city has any active servers.
- The tray icon now indicates whether the app is allowing traffic outside the tunnel or not. If the app blocks traffic because the tunnel is not connected the tray icon will indicate this with a green lock with a red dot.
- While connecting, a message telling the user that internet accesss is blocked is shown.
- Default to selecting servers in Sweden to increase the likelyhood of a fast and stable connection.
- Scrollbars will automatically hide when not scrolling.
- Remove the unsafe Camellia and Seed ciphers from the list of allowed OpenVPN ciphers.
- Buffer size and fast-io parameters to OpenVPN. Can double the speed on high latency connections.
- Download a list of our current servers on startup, instead of having a bundled list of servers in the app that does not receive updates.
- Backup account numbers in a file so that they are harder to lose.
- Include the OpenVPN log in the problem report. IP addresses and MAC addresses are redacted before the logs are sent.
- Hold off notifying the frontend of the 'unsecure' state until the VPN tunnel is actually completely disconnected.
- Show the VPN GUI on all macOS workspaces, not only the one where it was started.
- Renamed daemon binary from
mullvadd
tomullvad-daemon
.
- DNS leak found when using redirect firewall rules and a custom DNS forwarder. Replaced all of that with strict DNS blocking firewall rules and SystemConfiguration integration where DNS settings are injected to the operating system settings and constantly monitored for external changes.
- Possibility to shut down the daemon via an RPC call.
- Problem reports, for collecting and sending app logs to Mullvad support. This is fully opt-in and must be triggered by the user.
- Possibility to change between UDP and TCP as well as select port for OpenVPN to use.
- Possibility to copy the account number in the field where it's displayed in the GUI.
- Escape shell arguments better in both backend daemon and GUI.
- Rename the macOS PF firewall anchor created by the program to "mullvad".
- Change settings format from toml to json. To enable storing more advanced settings types.
- Shut down the backend daemon when quitting the app from the GUI. It was previously kept alive.
- Sign the macOS binaries with SHA1 in addition to SHA256. Enables running on 10.9 and 10.10.
- Upgrade the OpenVPN plugin to reduce risk of panics
- Change log level to reduce log file size
- Introduce minimum delay between failed VPN tunnel connections, to reduce load on the computer in special cases
- Authenticate RPC connections towards the backend
- Reject revoked server certificates
Nothing of interest
- Automatically secure connection on login
- Upgrade JSON-RPC library for more stable communication to our account server
- Remove the auto-secure setting
- Show the destination country while securing the connection
- Clean up the server list
- No longer clear the account token input field when navigating to and from the settings
- Show the main UI window on start when the user is not logged in
- Support for removing the account number from the CLI.
- Improved logging in the frontend in case of backend communication failure.
- Fix logout bug not removing the account number correctly.
- Don't show city and country in the frontend when tunnel is not connected.
- Don't try to automatically establish a tunnel from the frontend if the login failed.
- Initial closed beta release. Can set up a tunnel and protect against leaks on macOS.