2018-08-28 19:53:20 +00:00
|
|
|
package source
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/influxdata/platform"
|
|
|
|
"github.com/influxdata/platform/http"
|
|
|
|
"github.com/influxdata/platform/http/influxdb"
|
2018-09-11 22:56:51 +00:00
|
|
|
"github.com/influxdata/platform/query"
|
2018-08-28 19:53:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// NewQueryService creates a bucket service from a source.
|
2018-09-11 22:56:51 +00:00
|
|
|
func NewQueryService(s *platform.Source) (query.ProxyQueryService, error) {
|
2018-08-28 19:53:20 +00:00
|
|
|
switch s.Type {
|
|
|
|
case platform.SelfSourceType:
|
|
|
|
// TODO(fntlnz): this is supposed to call a query service directly locally,
|
|
|
|
// we are letting it err for now since we have some refactoring to do on
|
|
|
|
// how services are instantiated
|
|
|
|
return nil, fmt.Errorf("self source type not implemented")
|
|
|
|
case platform.V2SourceType:
|
2018-08-31 17:52:40 +00:00
|
|
|
// This is an influxd that calls another influxd, the query path is /v1/query - in future /v2/query
|
|
|
|
// it basically is the same as Self but on an external influxd.
|
2018-08-28 19:53:20 +00:00
|
|
|
return &http.SourceProxyQueryService{
|
|
|
|
InsecureSkipVerify: s.InsecureSkipVerify,
|
2018-10-04 19:11:45 +00:00
|
|
|
Addr: s.URL,
|
2018-08-28 19:53:20 +00:00
|
|
|
SourceFields: s.SourceFields,
|
|
|
|
}, nil
|
|
|
|
case platform.V1SourceType:
|
|
|
|
// This can be an influxdb or an influxdb + fluxd.
|
|
|
|
// If it is an influxdb alone it is just a source configured with the url of an influxdb
|
|
|
|
// and will only accept "influxql" compilers, if it has a fluxd it will also accept "flux" compilers.
|
|
|
|
// If the compiler used is "influxql" the proxy request will be made on the platform.URL directly.
|
|
|
|
// If the compiler used is "flux" the proxy request will be made on the platform.V1SourceFields.FluxURL
|
|
|
|
return &influxdb.SourceProxyQueryService{
|
|
|
|
InsecureSkipVerify: s.InsecureSkipVerify,
|
|
|
|
URL: s.URL,
|
|
|
|
SourceFields: s.SourceFields,
|
|
|
|
V1SourceFields: s.V1SourceFields,
|
|
|
|
OrganizationID: s.OrganizationID,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
return nil, fmt.Errorf("unsupported source type %s", s.Type)
|
|
|
|
}
|