| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- package pluginproxy
- import (
- "context"
- "fmt"
- "net/http"
- "net/url"
- "strings"
- m "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/plugins"
- "github.com/grafana/grafana/pkg/util"
- "golang.org/x/oauth2/google"
- )
- //ApplyRoute should use the plugin route data to set auth headers and custom headers
- func ApplyRoute(ctx context.Context, req *http.Request, proxyPath string, route *plugins.AppPluginRoute, ds *m.DataSource) {
- proxyPath = strings.TrimPrefix(proxyPath, route.Path)
- data := templateData{
- JsonData: ds.JsonData.Interface().(map[string]interface{}),
- SecureJsonData: ds.SecureJsonData.Decrypt(),
- }
- interpolatedURL, err := InterpolateString(route.Url, data)
- if err != nil {
- 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
- }
- req.URL.Scheme = routeURL.Scheme
- req.URL.Host = routeURL.Host
- req.Host = routeURL.Host
- req.URL.Path = util.JoinURLFragments(routeURL.Path, proxyPath)
- if err := addHeaders(&req.Header, route, data); err != nil {
- logger.Error("Failed to render plugin headers", "error", err)
- }
- tokenProvider := newAccessTokenProvider(ds, route)
- if route.TokenAuth != nil {
- if token, err := tokenProvider.getAccessToken(data); err != nil {
- logger.Error("Failed to get access token", "error", err)
- } else {
- req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", token))
- }
- }
- authenticationType := ds.JsonData.Get("authenticationType").MustString("jwt")
- if route.JwtTokenAuth != nil && authenticationType == "jwt" {
- if token, err := tokenProvider.getJwtAccessToken(ctx, data); err != nil {
- logger.Error("Failed to get access token", "error", err)
- } else {
- req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", token))
- }
- }
- if authenticationType == "gce" {
- tokenSrc, err := google.DefaultTokenSource(ctx, route.JwtTokenAuth.Scopes...)
- if err != nil {
- logger.Error("Failed to get default token from meta data server", "error", err)
- } else {
- token, err := tokenSrc.Token()
- if err != nil {
- logger.Error("Failed to get default access token from meta data server", "error", err)
- } else {
- req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", token.AccessToken))
- }
- }
- }
- logger.Info("Requesting", "url", req.URL.String())
- }
- func addHeaders(reqHeaders *http.Header, route *plugins.AppPluginRoute, data templateData) error {
- for _, header := range route.Headers {
- interpolated, err := InterpolateString(header.Content, data)
- if err != nil {
- return err
- }
- reqHeaders.Add(header.Name, interpolated)
- }
- return nil
- }
|