mirror of
https://github.com/grafana/grafana.git
synced 2025-07-29 03:22:24 +08:00

* Fix error source for clientSecret not found errir * Use errors.New as we are not formatting the error
51 lines
1.8 KiB
Go
51 lines
1.8 KiB
Go
package azuremonitor
|
|
|
|
import (
|
|
"context"
|
|
"crypto/tls"
|
|
"errors"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/grafana/grafana-azure-sdk-go/v2/azcredentials"
|
|
"github.com/grafana/grafana-azure-sdk-go/v2/azhttpclient"
|
|
"github.com/grafana/grafana-azure-sdk-go/v2/azsettings"
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend/httpclient"
|
|
|
|
"github.com/grafana/grafana/pkg/tsdb/azuremonitor/types"
|
|
)
|
|
|
|
type Provider interface {
|
|
New(...httpclient.Options) (*http.Client, error)
|
|
GetTransport(...httpclient.Options) (http.RoundTripper, error)
|
|
GetTLSConfig(...httpclient.Options) (*tls.Config, error)
|
|
}
|
|
|
|
func newHTTPClient(ctx context.Context, route types.AzRoute, model types.DatasourceInfo, settings *backend.DataSourceInstanceSettings, azureSettings *azsettings.AzureSettings, clientProvider Provider) (*http.Client, error) {
|
|
clientOpts, err := settings.HTTPClientOptions(ctx)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error getting HTTP options: %w", err)
|
|
}
|
|
|
|
for header, value := range route.Headers {
|
|
clientOpts.Header.Add(header, value)
|
|
}
|
|
|
|
// Use Azure credentials if the route has OAuth scopes configured
|
|
if len(route.Scopes) > 0 {
|
|
if cred, ok := model.Credentials.(*azcredentials.AzureClientSecretCredentials); ok && cred.ClientSecret == "" {
|
|
return nil, backend.DownstreamError(errors.New("unable to initialize HTTP Client: clientSecret not found"))
|
|
}
|
|
|
|
authOpts := azhttpclient.NewAuthOptions(azureSettings)
|
|
authOpts.AllowUserIdentity()
|
|
// Allows requests from the same identity but different Grafana users to be identified as such by the server
|
|
authOpts.AddRateLimitSession(true)
|
|
authOpts.Scopes(route.Scopes)
|
|
azhttpclient.AddAzureAuthentication(&clientOpts, authOpts, model.Credentials)
|
|
}
|
|
|
|
return clientProvider.New(clientOpts)
|
|
}
|