2021-07-28 23:10:02 +08:00
|
|
|
package endpoint
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/url"
|
|
|
|
"strconv"
|
|
|
|
)
|
|
|
|
|
2021-07-29 10:11:38 +08:00
|
|
|
// NewEndpoint new an Endpoint URL.
|
2021-07-28 23:10:02 +08:00
|
|
|
func NewEndpoint(scheme, host string, isSecure bool) *url.URL {
|
|
|
|
var query string
|
|
|
|
if isSecure {
|
|
|
|
query = "isSecure=true"
|
|
|
|
}
|
|
|
|
return &url.URL{Scheme: scheme, Host: host, RawQuery: query}
|
|
|
|
}
|
|
|
|
|
2021-07-29 10:11:38 +08:00
|
|
|
// ParseEndpoint parses an Endpoint URL.
|
|
|
|
func ParseEndpoint(endpoints []string, scheme string, isSecure bool) (string, error) {
|
|
|
|
for _, e := range endpoints {
|
|
|
|
u, err := url.Parse(e)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
2022-05-20 22:36:54 +08:00
|
|
|
if u.Scheme == scheme && IsSecure(u) == isSecure {
|
|
|
|
return u.Host, nil
|
2021-07-29 10:11:38 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return "", nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsSecure parses isSecure for Endpoint URL.
|
|
|
|
func IsSecure(u *url.URL) bool {
|
|
|
|
ok, err := strconv.ParseBool(u.Query().Get("isSecure"))
|
2021-07-28 23:10:02 +08:00
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return ok
|
|
|
|
}
|