2016-09-21 22:03:07 +00:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
2016-10-01 02:20:32 +00:00
|
|
|
"encoding/json"
|
2016-09-29 22:07:35 +00:00
|
|
|
"fmt"
|
2016-10-01 02:20:32 +00:00
|
|
|
"net/http"
|
2016-09-29 22:07:35 +00:00
|
|
|
"strconv"
|
|
|
|
|
2016-09-21 22:03:07 +00:00
|
|
|
"github.com/go-openapi/runtime/middleware"
|
|
|
|
"github.com/influxdata/mrfusion"
|
|
|
|
"github.com/influxdata/mrfusion/models"
|
|
|
|
"golang.org/x/net/context"
|
|
|
|
|
|
|
|
op "github.com/influxdata/mrfusion/restapi/operations"
|
|
|
|
)
|
|
|
|
|
|
|
|
type InfluxProxy struct {
|
2016-09-30 23:46:28 +00:00
|
|
|
Srcs mrfusion.SourcesStore
|
|
|
|
ServersStore mrfusion.ServersStore
|
|
|
|
TimeSeries mrfusion.TimeSeries
|
|
|
|
KapacitorProxy mrfusion.Proxy
|
2016-09-21 22:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *InfluxProxy) Proxy(ctx context.Context, params op.PostSourcesIDProxyParams) middleware.Responder {
|
2016-09-29 22:07:35 +00:00
|
|
|
id, err := strconv.Atoi(params.ID)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting ID %s", params.ID)}
|
|
|
|
return op.NewPostSourcesIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
src, err := h.Srcs.Get(ctx, id)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 404, Message: fmt.Sprintf("Unknown ID %s", params.ID)}
|
|
|
|
return op.NewPostSourcesIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = h.TimeSeries.Connect(ctx, &src); err != nil {
|
|
|
|
errMsg := &models.Error{Code: 400, Message: fmt.Sprintf("Unable to connect to source %s", params.ID)}
|
|
|
|
return op.NewPostSourcesIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
2016-09-21 22:03:07 +00:00
|
|
|
query := mrfusion.Query{
|
2016-09-21 22:11:29 +00:00
|
|
|
Command: *params.Query.Query,
|
2016-09-21 22:37:01 +00:00
|
|
|
DB: params.Query.Db,
|
2016-09-21 22:11:29 +00:00
|
|
|
RP: params.Query.Rp,
|
2016-09-21 22:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
response, err := h.TimeSeries.Query(ctx, query)
|
|
|
|
if err != nil {
|
|
|
|
if err == mrfusion.ErrUpstreamTimeout {
|
|
|
|
e := &models.Error{
|
|
|
|
Code: 408,
|
|
|
|
Message: "Timeout waiting for Influx response",
|
|
|
|
}
|
|
|
|
|
|
|
|
return op.NewPostSourcesIDProxyRequestTimeout().WithPayload(e)
|
|
|
|
}
|
|
|
|
// TODO: Here I want to return the error code from influx.
|
|
|
|
e := &models.Error{
|
|
|
|
Code: 400,
|
|
|
|
Message: err.Error(),
|
|
|
|
}
|
|
|
|
|
|
|
|
return op.NewPostSourcesIDProxyBadRequest().WithPayload(e)
|
|
|
|
}
|
|
|
|
|
|
|
|
res := &models.ProxyResponse{
|
|
|
|
Results: response,
|
|
|
|
}
|
|
|
|
return op.NewPostSourcesIDProxyOK().WithPayload(res)
|
|
|
|
}
|
2016-09-30 23:46:28 +00:00
|
|
|
|
2016-10-01 02:20:32 +00:00
|
|
|
func (h *InfluxProxy) KapacitorProxyPost(ctx context.Context, params op.PostKapacitorsIDProxyParams) middleware.Responder {
|
2016-09-30 23:46:28 +00:00
|
|
|
id, err := strconv.Atoi(params.ID)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting ID %s", params.ID)}
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
srv, err := h.ServersStore.Get(ctx, id)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 404, Message: fmt.Sprintf("Unknown ID %s", params.ID)}
|
|
|
|
return op.NewPostKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = h.KapacitorProxy.Connect(ctx, &srv); err != nil {
|
|
|
|
errMsg := &models.Error{Code: 400, Message: fmt.Sprintf("Unable to connect to servers store %s", params.ID)}
|
|
|
|
return op.NewPostKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
2016-10-01 02:20:32 +00:00
|
|
|
body, err := json.Marshal(params.Query)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting to JSON %v", err)}
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
2016-09-30 23:46:28 +00:00
|
|
|
req := &mrfusion.Request{
|
|
|
|
Method: "POST",
|
|
|
|
Path: params.Path,
|
2016-10-01 02:20:32 +00:00
|
|
|
Body: body,
|
2016-09-30 23:46:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := h.KapacitorProxy.Do(ctx, req)
|
|
|
|
defer resp.Body.Close()
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error with proxy %v", err)}
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-10-01 02:20:32 +00:00
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
|
|
var j interface{}
|
|
|
|
err = dec.Decode(&j)
|
|
|
|
if err != nil && err.Error() == "EOF" && resp.StatusCode != http.StatusOK {
|
|
|
|
err = nil
|
|
|
|
}
|
|
|
|
|
2016-09-30 23:46:28 +00:00
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error reading body of response: %v", err)}
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
2016-10-01 02:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(resp.StatusCode).WithPayload(j)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *InfluxProxy) KapacitorProxyPatch(ctx context.Context, params op.PatchKapacitorsIDProxyParams) middleware.Responder {
|
|
|
|
id, err := strconv.Atoi(params.ID)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting ID %s", params.ID)}
|
|
|
|
return op.NewPatchKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
srv, err := h.ServersStore.Get(ctx, id)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 404, Message: fmt.Sprintf("Unknown ID %s", params.ID)}
|
|
|
|
return op.NewPatchKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = h.KapacitorProxy.Connect(ctx, &srv); err != nil {
|
|
|
|
errMsg := &models.Error{Code: 400, Message: fmt.Sprintf("Unable to connect to servers store %s", params.ID)}
|
|
|
|
return op.NewPatchKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
body, err := json.Marshal(params.Query)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting to JSON %v", err)}
|
|
|
|
return op.NewPostKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
req := &mrfusion.Request{
|
|
|
|
Method: "PATCH",
|
|
|
|
Path: params.Path,
|
|
|
|
Body: body,
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := h.KapacitorProxy.Do(ctx, req)
|
|
|
|
defer resp.Body.Close()
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error with proxy %v", err)}
|
|
|
|
return op.NewPatchKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
|
|
var j interface{}
|
|
|
|
err = dec.Decode(&j)
|
|
|
|
if err != nil && err.Error() == "EOF" && resp.StatusCode != http.StatusOK {
|
|
|
|
err = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error reading body of response: %v", err)}
|
|
|
|
return op.NewPatchKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return op.NewPatchKapacitorsIDProxyDefault(resp.StatusCode).WithPayload(j)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *InfluxProxy) KapacitorProxyGet(ctx context.Context, params op.GetKapacitorsIDProxyParams) middleware.Responder {
|
|
|
|
id, err := strconv.Atoi(params.ID)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting ID %s", params.ID)}
|
|
|
|
return op.NewGetKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
srv, err := h.ServersStore.Get(ctx, id)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 404, Message: fmt.Sprintf("Unknown ID %s", params.ID)}
|
|
|
|
return op.NewGetKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = h.KapacitorProxy.Connect(ctx, &srv); err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Unable to connect to servers store %s", params.ID)}
|
|
|
|
return op.NewGetKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
req := &mrfusion.Request{
|
|
|
|
Method: "GET",
|
|
|
|
Path: params.Path,
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := h.KapacitorProxy.Do(ctx, req)
|
|
|
|
defer resp.Body.Close()
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error with proxy %v", err)}
|
|
|
|
return op.NewGetKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.StatusCode == http.StatusNoContent {
|
|
|
|
return op.NewGetKapacitorsIDProxyNoContent()
|
|
|
|
}
|
|
|
|
|
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
|
|
var j interface{}
|
|
|
|
err = dec.Decode(&j)
|
|
|
|
if err != nil && err.Error() == "EOF" && resp.StatusCode != http.StatusOK {
|
|
|
|
err = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error reading body of response: %v", err)}
|
|
|
|
return op.NewGetKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
return op.NewGetKapacitorsIDProxyDefault(resp.StatusCode).WithPayload(j)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *InfluxProxy) KapacitorProxyDelete(ctx context.Context, params op.DeleteKapacitorsIDProxyParams) middleware.Responder {
|
|
|
|
id, err := strconv.Atoi(params.ID)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error converting ID %s", params.ID)}
|
|
|
|
return op.NewDeleteKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
srv, err := h.ServersStore.Get(ctx, id)
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 404, Message: fmt.Sprintf("Unknown ID %s", params.ID)}
|
|
|
|
return op.NewDeleteKapacitorsIDProxyNotFound().WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = h.KapacitorProxy.Connect(ctx, &srv); err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Unable to connect to servers store %s", params.ID)}
|
|
|
|
return op.NewDeleteKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
}
|
|
|
|
|
|
|
|
req := &mrfusion.Request{
|
|
|
|
Method: "DELETE",
|
|
|
|
Path: params.Path,
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := h.KapacitorProxy.Do(ctx, req)
|
|
|
|
defer resp.Body.Close()
|
|
|
|
if err != nil {
|
|
|
|
errMsg := &models.Error{Code: 500, Message: fmt.Sprintf("Error with proxy %v", err)}
|
|
|
|
return op.NewDeleteKapacitorsIDProxyDefault(500).WithPayload(errMsg)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.StatusCode == http.StatusNoContent {
|
|
|
|
return op.NewGetKapacitorsIDProxyNoContent()
|
|
|
|
}
|
2016-09-30 23:46:28 +00:00
|
|
|
|
2016-10-01 02:20:32 +00:00
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
|
|
var j interface{}
|
|
|
|
err = dec.Decode(&j)
|
|
|
|
if err != nil && err.Error() == "EOF" && resp.StatusCode != http.StatusOK {
|
|
|
|
err = nil
|
2016-09-30 23:46:28 +00:00
|
|
|
}
|
|
|
|
|
2016-10-01 02:20:32 +00:00
|
|
|
return op.NewDeleteKapacitorsIDProxyDefault(resp.StatusCode).WithPayload(j)
|
2016-09-30 23:46:28 +00:00
|
|
|
}
|