Features
- ExpressVPN: OpenVPN additional ciphers (#1047)
- Storage:
- add
"keep"boolean field for servers to keep manually added servers - log time difference as a friendly duration
- add
- Updater: configurable minimum ratio of servers found
UPDATER_MIN_RATIOenvironment variable-minratioflag for CLI operation
- Docker: upgrade Alpine from 3.15 to 3.16 (#1005)
- Update servers data: Perfect privacy, Purevpn, Privatevpn, Private Internet Access, ProtonVPN, IPVanish, Surfshark
- Environment variables: clean values by removing surrounding spaces and suffix new line characters
- Wireguard: add debug logs for IPv6 detection which can be enabled with
LOG_LEVEL=debug
Fixes
- ExpressVPN: OpenVPN
fragmentoption taken into account (#1047) - Private internet access:
- load custom certificate to communicate with their API
- restrict custom port choice
- ProtonVPN:
- set free field for free servers, fixing
FREE_ONLYbehavior - remove duplicate entry IPs
- restrict custom port choice
- set free field for free servers, fixing
- Wireguard: continue on ipv6 route add permission denial
- VPN: do not close wait error channel on consumer side
- Port forwarding: set file owned by the uid and gid set by
PUIDandPGID - Private Internet Access: remove duplicate log of port forwarding data expiration
- Pprof settings: override method used correctly in global settings
- Updater: Fix CLI operation not setting DNS server
- IPVanish: remove duplicate server entries
- Custom: validate custom OpenVPN file at settings validation
Documentation
- Bug issue template: fix render of logs to be
plain textinstead oflog - ProtonVPN: document in code to remove
SERVER_NAMES - Update maintenance.md document
Maintenance
Easy to add VPN providers
internal/provider/examplenew package- Readme: simplify heading description
internal/updater: check each server has minimal informationinternal/storage: modify JSON tests to not need all providers listedinternal/provider/commonnew package: shared interfaces and errors for all providersinternal/provider: newProviderscontains a map from provider string name to provider interface- Use the same provider object for both updating servers and to setup the VPN
- Initialize all providers at start in the
Providersmap internal/provider/*:- incorporate updating
FetchServersmethod inProviderinterface - Rename each provider updater subpackage name to
updater - add
Name()method per provider - rename all provider structs to
Provider - rename all test functions to
Test_Provider_GetConnection
- incorporate updating
internal/updater: Updaterupdatemethod takes in a slice of provider stringsinternal/storage: common sorting for all serversinternal/provider/surshark/servers/locationdata.gomerging bothinternal/models/location.goandinternal/constants/surfshark.gointernal/models: provider to servers map inallServers:- Custom JSON marshaling methods for
AllServers - Simplify formatting CLI
- Simplify updater code
- Simplify filter choices for config validation
- Simplify all servers deep copying
- Simplify provider constructor switch
- Simplify storage merging
- Simplify storage reading and extraction
- Custom JSON marshaling methods for
internal/storage/servers.json: change provider names to match string constants in code- From
piatoprivate internet access, and reset version to1 - From
perfectprivacytoperfect privacy, and reset version to1 - From
vpnunlimitedtovpn unlimited, and reset version to1
- From
internal/cli: refactorFormatServersto use provider stringsinternal/provider/utils: unexport no longer externally needed functionsinternal/provider: addGetConnectiontest
Continuous integration
- Fix trigger for Docker image publish job
- Merge jobs and workflows into the
verifyjob of the CI workflow:- CodeQL job
- Dependabot workflow
- Fork workflow
- Fix behavior on pull requests from forked repositories
- Run Docker Hub description job only on base repository
- Run Docker image publish job only on base repository
- Build base repository pull request Docker images with tag
:pr-N(#1026) - Add skip workflow for required verify job
- Restrict permissions to read actions+contents for all jobs
- Remove go.mod tidy check job
- Not really needed with newer
go install - Conflicts with Go 1.17 go.mod format
- Conflicts with manual indirect dependency upgrade
- Not really needed with newer
- Bump docker/setup-buildx-action from 1 to 2 (#977)
- Bump docker/setup-qemu-action from 1 to 2 (#978)
- Bump docker/build-push-action from 2.10.0 to 3.0.0 (#979)
- Bump docker/metadata-action from 3 to 4 (#980)
- Bump docker/login-action from 1 to 2 (#981)
- Bump crazy-max/ghaction-github-labeler from 3 to 4 (#1007)
Other
Storage: memory and thread safe servers data storage
- only pass hardcoded versions to read file and discard outdated servers
- unexport
SyncServersmethod - minimal deep copying and data duplication
- add merged servers mutex for thread safety
- settings: get filter choices from storage for settings validation
- updater:
- update servers to the storage
- get servers count from storage directly
- equality check done by the storage
- connection: filter servers in storage
- formatter: format servers to Markdown in storage
- PIA: get server by name from storage directly
internal/openvpn/extract:extract.PEMreplaces all PEM parse functionsinternal/constants/openvpnnew package for OpenVPN related constants.internal/wireguard: add check for empty public key for Wireguardinternal/publicip:- Exported
Fetcherinterface - Inject
Fetcherto publicip loop and updaters - Get public IP and information at the same time
- Only query ipinfo.io
- Make
MultiInfopart of theFetchobject internal/publicip/ipinfopackage
- Exported
- Updater:
- DNS address as
host:portstring in settings structure - Remove unneeded ctx error check in cyberghost updating code
UpdateServersreturns an error if it fails updating a single provider- Inject a common resolver to each provider instead of creating a unique one per provider, and use resolver settings on every call to its
.Resolvemethod - Move out minServers check from resolver
internal/updater/loopsubpackageinternal/server: more restrictive updater loop interface
- DNS address as
- Renamings:
- updater: rename all
presolvertoparallelResolver - storage: rename
InfoErrorertoInfoer - provider: rename all
BuildConfmethods toOpenVPNConfig - updater: rename all
GetServersmethods toFetchServers
- updater: rename all
- Entire codebase changes:
- remove unexported Go interfaces
- remove package comments
- return concrete types, accept interfaces
- Upgrade
gopkg.in/yaml.v3to v3.0.1 to fix (dull) vulnerability alert on Github
Development
- See Easy to add VPN providers related work
.vscode/launch.jsonto update servers - Credits to @Rohaqgo4.org/unsafe/assume-no-moving-gcupgraded to allow development using Go 1.18 withoutASSUME_NO_MOVING_GC_UNSAFE_RISK_IT_WITH=go1.18- Linting:
- upgrade golangci-lint from v1.44.2 to v1.46.2
- review exclude rules
ireturn,execinqueryandnosprintfhostportlinters added
- Use casers instead of
strings.Titleto remove Go 1.18 linting warnings- Add
golang.org/x/textdependency - Update code to use
cases.Title(language.English)
- Add
- Bump github.com/stretchr/testify from 1.7.1 to 1.7.2 (#1016)