Commit 887387cd by Marcus Efraimsson Committed by GitHub

Merge pull request #12974 from grafana/ds-proxy-json-data

dsproxy: interpolate route url
parents 0223a75d c75e0712
...@@ -320,9 +320,15 @@ func (proxy *DataSourceProxy) applyRoute(req *http.Request) { ...@@ -320,9 +320,15 @@ func (proxy *DataSourceProxy) applyRoute(req *http.Request) {
SecureJsonData: proxy.ds.SecureJsonData.Decrypt(), SecureJsonData: proxy.ds.SecureJsonData.Decrypt(),
} }
routeURL, err := url.Parse(proxy.route.Url) interpolatedURL, err := interpolateString(proxy.route.Url, data)
if err != nil { if err != nil {
logger.Error("Error parsing plugin route url") logger.Error("Error interpolating proxy url", "error", err)
return
}
routeURL, err := url.Parse(interpolatedURL)
if err != nil {
logger.Error("Error parsing plugin route url", "error", err)
return return
} }
......
...@@ -49,6 +49,13 @@ func TestDSRouteRule(t *testing.T) { ...@@ -49,6 +49,13 @@ func TestDSRouteRule(t *testing.T) {
{Name: "x-header", Content: "my secret {{.SecureJsonData.key}}"}, {Name: "x-header", Content: "my secret {{.SecureJsonData.key}}"},
}, },
}, },
{
Path: "api/common",
Url: "{{.JsonData.dynamicUrl}}",
Headers: []plugins.AppPluginRouteHeader{
{Name: "x-header", Content: "my secret {{.SecureJsonData.key}}"},
},
},
}, },
} }
...@@ -57,7 +64,8 @@ func TestDSRouteRule(t *testing.T) { ...@@ -57,7 +64,8 @@ func TestDSRouteRule(t *testing.T) {
ds := &m.DataSource{ ds := &m.DataSource{
JsonData: simplejson.NewFromAny(map[string]interface{}{ JsonData: simplejson.NewFromAny(map[string]interface{}{
"clientId": "asd", "clientId": "asd",
"dynamicUrl": "https://dynamic.grafana.com",
}), }),
SecureJsonData: map[string][]byte{ SecureJsonData: map[string][]byte{
"key": key, "key": key,
...@@ -83,6 +91,17 @@ func TestDSRouteRule(t *testing.T) { ...@@ -83,6 +91,17 @@ func TestDSRouteRule(t *testing.T) {
}) })
}) })
Convey("When matching route path and has dynamic url", func() {
proxy := NewDataSourceProxy(ds, plugin, ctx, "api/common/some/method")
proxy.route = plugin.Routes[3]
proxy.applyRoute(req)
Convey("should add headers and interpolate the url", func() {
So(req.URL.String(), ShouldEqual, "https://dynamic.grafana.com/some/method")
So(req.Header.Get("x-header"), ShouldEqual, "my secret 123")
})
})
Convey("Validating request", func() { Convey("Validating request", func() {
Convey("plugin route with valid role", func() { Convey("plugin route with valid role", func() {
proxy := NewDataSourceProxy(ds, plugin, ctx, "api/v4/some/method") proxy := NewDataSourceProxy(ds, plugin, ctx, "api/v4/some/method")
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment