Compare commits
4 Commits
v20220306.
...
v20220306.
Author | SHA1 | Date | |
---|---|---|---|
2998e1d39d | |||
5821d890b8 | |||
2dfdb1ad74 | |||
8d07304c03 |
1
.github/workflows/go.yml
vendored
1
.github/workflows/go.yml
vendored
@ -22,7 +22,6 @@ jobs:
|
||||
run: |
|
||||
git tag "v$(git show -s --format=%cd --date=format:%Y%m%d.%H%M%S)"
|
||||
git push --tags
|
||||
sudo mv snyk-linux* /usr/local/bin/
|
||||
|
||||
- name: Release binaries with GoReleaser
|
||||
uses: goreleaser/goreleaser-action@v2
|
||||
|
13
README.md
Normal file
13
README.md
Normal file
@ -0,0 +1,13 @@
|
||||
# mullvad-best-server
|
||||
Determines the mullvat.net server with the lowest latency.
|
||||
|
||||
## Installation
|
||||
|
||||
Download binary from releases for your platform and unpack.
|
||||
|
||||
## Usage
|
||||
Execute `mullvad-best-server`. It outputs the code, e.g. `de05`. You can then connect to it with e.g. wireguard using the normal shell scripts.
|
||||
|
||||
## Background
|
||||
The program uses `https://api.mullvad.net/www/relays/wireguard/` to get the current server list, pings the ones with the right country
|
||||
and outputs the server with the lowest ping.
|
11
main.go
11
main.go
@ -2,21 +2,26 @@ package main
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"github.com/go-ping/ping"
|
||||
"github.com/rs/zerolog"
|
||||
"github.com/rs/zerolog/log"
|
||||
"io"
|
||||
"io/ioutil"
|
||||
"net/http"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
var pings = make(map[string]time.Duration)
|
||||
|
||||
func main() {
|
||||
|
||||
zerolog.SetGlobalLevel(zerolog.InfoLevel)
|
||||
servers := getServers()
|
||||
bestIndex := selectBestServerIndex(servers)
|
||||
log.Info().Interface("best", servers[bestIndex]).Msg("Best Latency Server found.")
|
||||
log.Debug().Interface("server", servers[bestIndex]).Msg("Best latency server found.")
|
||||
hostname := strings.Split(servers[bestIndex].Hostname, "-")[0]
|
||||
fmt.Println(hostname)
|
||||
}
|
||||
|
||||
func selectBestServerIndex(servers []server) int {
|
||||
@ -69,7 +74,7 @@ func serverLatency(s server) (time.Duration, error) {
|
||||
}
|
||||
var duration time.Duration
|
||||
pinger.OnRecv = func(pkt *ping.Packet) {
|
||||
log.Info().Str("Server", s.Hostname).IPAddr("IP", pkt.IPAddr.IP).Dur("RTT", pkt.Rtt).Msg("Added server latency.")
|
||||
log.Debug().Str("Server", s.Hostname).IPAddr("IP", pkt.IPAddr.IP).Dur("RTT", pkt.Rtt).Msg("Added server latency.")
|
||||
duration = pkt.Rtt
|
||||
}
|
||||
err = pinger.Run()
|
||||
|
Reference in New Issue
Block a user