influxdb/flux/client.go

89 lines
1.5 KiB
Go
Raw Normal View History

Flux/connections page (#4026) * Load services on manages sources page Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Add Flux dropdown on manage sources page Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Add flux connection dropdown with create, select, and update Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Prevent creation of Flux connection with duplicate name Fixed bug where refreshing page allowed for Flux or connections with duplicate names to be created Co-authored-by: Iris Scholten <ischolten.is@gmail.com> * Add ability to delete a FluxService from the fluxservice dropdown Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Change FluxPage to use the active flux connection set by FluxConnectionPage Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Ensure that only flux services are loaded into redux services * Polish styles for Flux Connection Page Co-authored-by: Alex Paxton <thealexpaxton@gmail.com> Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Add pingflux as a part of adding and updating a flux service Co-authored-by: Chris Goller <goller@gmail.com> Co-authored-by: Alirie Gray <alirie.gray@gmail.com> * Add Swagger routes and definitions for Service endpoints Co-authored-by: Iris Scholten <ischolten.is@gmail.com> * Replace flux overlay with redirect to flux connections pages * Add test for FluxConnectionPage Co-authored-by: Iris Scholten <ischolten.is@gmail.com> * Replace hard-coded string with enum * Use active from metadata instead of service object in ServiceDropdown Co-authored-by: Iris Scholten <ischolten.is@gmail.com> * Add generic for getDeep on service metadata property * Capitalize enum constant values in FluxFormMode * Show error notification when user reaches edit route for nonexistant flux Co-authored-by: Iris Scholten <ischolten.is@gmail.com> * Add tests for FluxDropdown * Update types for async functions
2018-07-27 01:16:02 +00:00
package flux
import (
"context"
"crypto/tls"
"fmt"
"io/ioutil"
"net/http"
"net/url"
"time"
"github.com/influxdata/platform/chronograf"
)
// Shared transports for all clients to prevent leaking connections.
var (
skipVerifyTransport = &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
defaultTransport = &http.Transport{}
)
// Client is how we interact with Flux.
type Client struct {
URL *url.URL
InsecureSkipVerify bool
Timeout time.Duration
}
// Ping checks the connection of a Flux.
func (c *Client) Ping(ctx context.Context) error {
t := 2 * time.Second
if c.Timeout > 0 {
t = c.Timeout
}
ctx, cancel := context.WithTimeout(ctx, t)
defer cancel()
err := c.pingTimeout(ctx)
return err
}
func (c *Client) pingTimeout(ctx context.Context) error {
resps := make(chan (error))
go func() {
resps <- c.ping(c.URL)
}()
select {
case resp := <-resps:
return resp
case <-ctx.Done():
return chronograf.ErrUpstreamTimeout
}
}
func (c *Client) ping(u *url.URL) error {
u.Path = "ping"
req, err := http.NewRequest("GET", u.String(), nil)
if err != nil {
return err
}
hc := &http.Client{}
if c.InsecureSkipVerify {
hc.Transport = skipVerifyTransport
} else {
hc.Transport = defaultTransport
}
resp, err := hc.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return err
}
if resp.StatusCode != http.StatusNoContent {
var err = fmt.Errorf(string(body))
return err
}
return nil
}