Compare commits

..

4 Commits

Author SHA1 Message Date
Bastian Doetsch
130a048394 fix design after adding badge in README.md 2022-03-06 17:47:47 +01:00
Bastian Doetsch
0be7f66582 updated README.md with badge 2022-03-06 17:46:55 +01:00
Bastian Doetsch
0f014cf9f3 updated README.md with usage information 2022-03-06 17:37:44 +01:00
Bastian Doetsch
230e89e2b7 allow full json output for best server using flag -o json 2022-03-06 17:36:21 +01:00
2 changed files with 20 additions and 2 deletions

View File

@@ -1,13 +1,19 @@
# mullvad-best-server # mullvad-best-server
Determines the mullvat.net server with the lowest latency. ![Build](https://github.com/bastiandoetsch/mullvad-best-server/actions/workflows/go.yml/badge.svg)
Determines the mullvat.net wireguard server with the lowest latency.
## Installation ## Installation
Download binary from releases for your platform and unpack. Download binary from releases for your platform and unpack.
## Usage ## Usage
### Default 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. 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.
### Extended Output
If you want the full server information, execute `mullvad-best-server -o json`. It returns the full json output of the server information.
## Background ## Background
The program uses `https://api.mullvad.net/www/relays/wireguard/` to get the current server list, pings the ones with the right country 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. and outputs the server with the lowest ping.

12
main.go
View File

@@ -2,6 +2,7 @@ package main
import ( import (
"encoding/json" "encoding/json"
"flag"
"fmt" "fmt"
"github.com/go-ping/ping" "github.com/go-ping/ping"
"github.com/rs/zerolog" "github.com/rs/zerolog"
@@ -17,11 +18,22 @@ var pings = make(map[string]time.Duration)
func main() { func main() {
zerolog.SetGlobalLevel(zerolog.InfoLevel) zerolog.SetGlobalLevel(zerolog.InfoLevel)
var outputFlag = flag.String("o", "short", "Output format. 'json' outputs server json")
flag.Parse()
servers := getServers() servers := getServers()
bestIndex := selectBestServerIndex(servers) bestIndex := selectBestServerIndex(servers)
log.Debug().Interface("server", 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] hostname := strings.Split(servers[bestIndex].Hostname, "-")[0]
if *outputFlag != "json" {
fmt.Println(hostname) fmt.Println(hostname)
} else {
serverJson, err := json.Marshal(servers[bestIndex])
if err != nil {
log.Fatal().Err(err)
}
fmt.Println(string(serverJson))
}
} }
func selectBestServerIndex(servers []server) int { func selectBestServerIndex(servers []server) int {