Compare commits
4 Commits
v20220306.
...
v20220306.
Author | SHA1 | Date | |
---|---|---|---|
20e1092604 | |||
2998e1d39d | |||
5821d890b8 | |||
2dfdb1ad74 |
2
.github/workflows/go.yml
vendored
2
.github/workflows/go.yml
vendored
@ -9,6 +9,8 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Set up Go
|
- name: Set up Go
|
||||||
uses: actions/setup-go@v2
|
uses: actions/setup-go@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 (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
"github.com/go-ping/ping"
|
"github.com/go-ping/ping"
|
||||||
|
"github.com/rs/zerolog"
|
||||||
"github.com/rs/zerolog/log"
|
"github.com/rs/zerolog/log"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var pings = make(map[string]time.Duration)
|
var pings = make(map[string]time.Duration)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
zerolog.SetGlobalLevel(zerolog.InfoLevel)
|
||||||
servers := getServers()
|
servers := getServers()
|
||||||
bestIndex := selectBestServerIndex(servers)
|
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 {
|
func selectBestServerIndex(servers []server) int {
|
||||||
@ -69,7 +74,7 @@ func serverLatency(s server) (time.Duration, error) {
|
|||||||
}
|
}
|
||||||
var duration time.Duration
|
var duration time.Duration
|
||||||
pinger.OnRecv = func(pkt *ping.Packet) {
|
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
|
duration = pkt.Rtt
|
||||||
}
|
}
|
||||||
err = pinger.Run()
|
err = pinger.Run()
|
||||||
|
Reference in New Issue
Block a user