2020-04-15 01:20:00 +02:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
2020-10-04 23:01:10 +02:00
|
|
|
"crypto/tls"
|
2020-10-05 01:49:02 +02:00
|
|
|
"net"
|
2020-04-15 01:20:00 +02:00
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2020-10-04 23:01:10 +02:00
|
|
|
secureHttpClient *http.Client
|
|
|
|
insecureHttpClient *http.Client
|
2020-04-15 01:20:00 +02:00
|
|
|
)
|
|
|
|
|
2020-10-23 21:58:59 +02:00
|
|
|
// GetHttpClient returns the shared HTTP client
|
2020-10-04 23:01:10 +02:00
|
|
|
func GetHttpClient(insecure bool) *http.Client {
|
|
|
|
if insecure {
|
|
|
|
if insecureHttpClient == nil {
|
|
|
|
insecureHttpClient = &http.Client{
|
|
|
|
Timeout: time.Second * 10,
|
|
|
|
Transport: &http.Transport{
|
|
|
|
TLSClientConfig: &tls.Config{
|
|
|
|
InsecureSkipVerify: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2020-04-15 01:20:00 +02:00
|
|
|
}
|
2020-10-04 23:01:10 +02:00
|
|
|
return insecureHttpClient
|
|
|
|
} else {
|
|
|
|
if secureHttpClient == nil {
|
|
|
|
secureHttpClient = &http.Client{
|
|
|
|
Timeout: time.Second * 10,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return secureHttpClient
|
2020-04-15 01:20:00 +02:00
|
|
|
}
|
|
|
|
}
|
2020-10-05 01:49:02 +02:00
|
|
|
|
2020-10-23 21:58:59 +02:00
|
|
|
// CanCreateConnectionToTcpService checks whether a connection can be established with a TCP service
|
2020-10-05 01:49:02 +02:00
|
|
|
func CanCreateConnectionToTcpService(address string) bool {
|
|
|
|
conn, err := net.DialTimeout("tcp", address, 5*time.Second)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
_ = conn.Close()
|
|
|
|
return true
|
|
|
|
}
|