Skip to content

grafana/grafana-azure-sdk-go

Repository files navigation

github.com/grafana/grafana-azure-sdk-go

SDK for integration of Grafana datasources with Azure services.

Packages

azsettings

Common Azure configuration. Can be read from either the environment variables of the Grafana instance (if supplied to the plugin) or from the context supplied to the plugin (if available).

This can be achieved by making use of ReadSettings which will determine the settings based on the available context.

Note: If the plugin context contains any Azure related variable then it will be used in place of any environment variables present.

azcredentials

The built-in AzureCredentials:

  • AadCurrentUserCredentials
  • AzureManagedIdentityCredentials
  • AzureClientSecretCredentials
  • AzureClientSecretOboCredentials

azhttpclient

Azure authentication middleware for Grafana Plugin SDK httpclient.

Usage

// Initialize the authentication options
authOpts := azhttpclient.NewAuthOptions(azureSettings)

// Configure instance-level scopes
authOpts.Scopes([]string{"https://datasource.example.org/.default"})

// Optionally, register custom token providers
authOpts.AddTokenProvider("custom-auth-type", func (...) (aztokenprovider.AzureTokenProvider, error) {
	return NewCustomTokenProvider(...), nil
})

// Configure the client
clientOpts := httpclient.Options{}
azhttpclient.AddAzureAuthentication(&clientOpts, authOpts, credentials)

httpClient, err := httpclient.NewProvider().New(clientOpts)

Endpoints

The Azure authentication middleware supports specifying a list of allowed endpoints for HTTP requests.

This logic is currently utilised in the Azure Data Explorer data source which also supports user-specified endpoints in addition to the default endpoints.

Endpoints can be specified as URLs with or without ports. A scheme is required in the URL. If no port is specified the scheme must be one of http or https which will default the port to 80 or 443 respectively.

Wildcards can also be specified in the URL and they can be nested. A prefix wildcard can be used e.g. https://*.kusto.windows.net. This will match any address with the suffix kusto.windows.net (but note that it will not match https://kusto.windows.net as prefix path segments are expected) and the https scheme. A nested wildcard endpoint can also be used e.g. https://test.*.windows.net which will much any value in the wildcard position (but note that it will only match a single path segment rather than multiple). Finally, prefix and nested wildcards can be mixed e.g. https://*.test.*.windows.net which will match endpoints like https://one.two.three.test.any.windows.net.

azusercontext

Context object CurrentUserContext of the currently signed-in Grafana user which can be passed via context between business layers.

Used by token provider to get information about the current user for user identity authentication.

Read/write functions:

  • context = azusercontext.WithCurrentUser(context, currentUser) extends given context with information about the current user.
  • currentUser = azusercontext.GetCurrentUser(context) extracts current user from the given context

Helper functions for datasource requests:

  • WithUserFromQueryReq extracts current user from query request and adds to context.
  • WithUserFromResourceReq extracts current user from resource call and adds to context.
  • WithUserFromHealthCheckReq extracts current from health check request and adds to context.

aztokenprovider

util

  • maputil

License

Apache 2.0 License

About

No description, website, or topics provided.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 21

Languages