2014-12-25 23:12:12 +00:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
|
|
|
//
|
2015-03-07 21:36:35 +01:00
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
2017-02-09 07:52:18 +01:00
|
|
|
// You can obtain one at https://mozilla.org/MPL/2.0/.
|
2014-12-25 23:12:12 +00:00
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2020-02-13 14:43:00 +01:00
|
|
|
"context"
|
2015-09-20 15:30:25 +02:00
|
|
|
"crypto/tls"
|
|
|
|
"errors"
|
2014-12-25 23:12:12 +00:00
|
|
|
"flag"
|
2015-09-20 15:30:25 +02:00
|
|
|
"fmt"
|
|
|
|
"net/url"
|
2014-12-25 23:12:12 +00:00
|
|
|
"os"
|
2015-09-20 15:30:25 +02:00
|
|
|
"time"
|
2014-12-25 23:12:12 +00:00
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/config"
|
2015-08-06 11:29:25 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/discover"
|
2019-08-15 16:29:37 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/events"
|
2015-09-22 19:38:46 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/protocol"
|
2014-12-25 23:12:12 +00:00
|
|
|
)
|
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
var timeout = 5 * time.Second
|
2014-12-25 23:12:12 +00:00
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
func main() {
|
2014-12-25 23:12:12 +00:00
|
|
|
var server string
|
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
flag.StringVar(&server, "server", "", "Announce server (blank for default set)")
|
|
|
|
flag.DurationVar(&timeout, "timeout", timeout, "Query timeout")
|
|
|
|
flag.Usage = usage
|
2014-12-25 23:12:12 +00:00
|
|
|
flag.Parse()
|
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
if flag.NArg() != 1 {
|
|
|
|
flag.Usage()
|
2014-12-25 23:12:12 +00:00
|
|
|
os.Exit(64)
|
|
|
|
}
|
|
|
|
|
|
|
|
id, err := protocol.DeviceIDFromString(flag.Args()[0])
|
|
|
|
if err != nil {
|
2015-09-20 15:30:25 +02:00
|
|
|
fmt.Println(err)
|
2014-12-25 23:12:12 +00:00
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
2015-09-20 15:30:25 +02:00
|
|
|
if server != "" {
|
|
|
|
checkServers(id, server)
|
|
|
|
} else {
|
|
|
|
checkServers(id, config.DefaultDiscoveryServers...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type checkResult struct {
|
2016-05-04 19:38:12 +00:00
|
|
|
server string
|
|
|
|
addresses []string
|
2015-09-20 15:30:25 +02:00
|
|
|
error
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkServers(deviceID protocol.DeviceID, servers ...string) {
|
|
|
|
t0 := time.Now()
|
|
|
|
resc := make(chan checkResult)
|
|
|
|
for _, srv := range servers {
|
|
|
|
srv := srv
|
|
|
|
go func() {
|
|
|
|
res := checkServer(deviceID, srv)
|
|
|
|
res.server = srv
|
|
|
|
resc <- res
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
2016-08-15 08:37:32 +02:00
|
|
|
for range servers {
|
2015-09-20 15:30:25 +02:00
|
|
|
res := <-resc
|
|
|
|
|
|
|
|
u, _ := url.Parse(res.server)
|
|
|
|
fmt.Printf("%s (%v):\n", u.Host, time.Since(t0))
|
|
|
|
|
|
|
|
if res.error != nil {
|
|
|
|
fmt.Println(" " + res.error.Error())
|
|
|
|
}
|
2016-05-04 19:38:12 +00:00
|
|
|
for _, addr := range res.addresses {
|
2015-09-20 15:30:25 +02:00
|
|
|
fmt.Println(" address:", addr)
|
|
|
|
}
|
2015-06-23 13:55:30 +01:00
|
|
|
}
|
2015-09-20 15:30:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func checkServer(deviceID protocol.DeviceID, server string) checkResult {
|
2022-04-09 16:04:56 +02:00
|
|
|
disco, err := discover.NewGlobal(server, tls.Certificate{}, nil, events.NoopLogger, nil)
|
2015-09-20 15:30:25 +02:00
|
|
|
if err != nil {
|
|
|
|
return checkResult{error: err}
|
2014-12-25 23:12:12 +00:00
|
|
|
}
|
2015-09-20 15:30:25 +02:00
|
|
|
|
|
|
|
res := make(chan checkResult, 1)
|
|
|
|
|
|
|
|
time.AfterFunc(timeout, func() {
|
|
|
|
res <- checkResult{error: errors.New("timeout")}
|
|
|
|
})
|
|
|
|
|
|
|
|
go func() {
|
2020-02-13 14:43:00 +01:00
|
|
|
addresses, err := disco.Lookup(context.Background(), deviceID)
|
2016-05-04 19:38:12 +00:00
|
|
|
res <- checkResult{addresses: addresses, error: err}
|
2015-09-20 15:30:25 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
return <-res
|
|
|
|
}
|
|
|
|
|
|
|
|
func usage() {
|
|
|
|
fmt.Printf("Usage:\n\t%s [options] <device ID>\n\nOptions:\n", os.Args[0])
|
|
|
|
flag.PrintDefaults()
|
2014-12-25 23:12:12 +00:00
|
|
|
}
|