// To change feature flags, edit: // pkg/services/featuremgmt/registry.go // Then run tests in: // pkg/services/featuremgmt/toggles_gen_test.go // twice to generate and validate the feature flag files // // Alternatively, use `make gen-feature-toggles` package featuremgmt import ( "embed" "encoding/json" featuretoggle "github.com/grafana/grafana/pkg/apis/featuretoggle/v0alpha1" ) var ( // Register each toggle here standardFeatureFlags = []FeatureFlag{ { Name: "disableEnvelopeEncryption", Description: "Disable envelope encryption (emergency only)", Stage: FeatureStageGeneralAvailability, Owner: grafanaAsCodeSquad, HideFromAdminPage: true, AllowSelfServe: false, }, { Name: "live-service-web-worker", Description: "This will use a webworker thread to processes events rather than the main thread", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaAppPlatformSquad, }, { Name: "queryOverLive", Description: "Use Grafana Live WebSocket to execute backend queries", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaAppPlatformSquad, }, { Name: "panelTitleSearch", Description: "Search for dashboards using panel title", Stage: FeatureStagePublicPreview, Owner: grafanaAppPlatformSquad, HideFromAdminPage: true, }, { Name: "publicDashboards", Description: "[Deprecated] Public dashboards are now enabled by default; to disable them, use the configuration setting. This feature toggle will be removed in the next major version.", Stage: FeatureStageGeneralAvailability, Owner: grafanaSharingSquad, Expression: "true", // enabled by default AllowSelfServe: true, }, { Name: "publicDashboardsEmailSharing", Description: "Enables public dashboard sharing to be restricted to only allowed emails", Stage: FeatureStagePublicPreview, Owner: grafanaSharingSquad, HideFromDocs: true, HideFromAdminPage: true, }, { Name: "publicDashboardsScene", Description: "Enables public dashboard rendering using scenes", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaSharingSquad, }, { Name: "lokiExperimentalStreaming", Description: "Support new streaming approach for loki (prototype, needs special loki build)", Stage: FeatureStageExperimental, Owner: grafanaObservabilityLogsSquad, }, { Name: "featureHighlights", Description: "Highlight Grafana Enterprise features", Stage: FeatureStageGeneralAvailability, Owner: grafanaAsCodeSquad, AllowSelfServe: true, }, { Name: "migrationLocking", Description: "Lock database during migrations", Stage: FeatureStagePublicPreview, Owner: grafanaBackendPlatformSquad, }, { Name: "storage", Description: "Configurable storage for dashboards, datasources, and resources", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, }, { Name: "correlations", Description: "Correlations page", Stage: FeatureStageGeneralAvailability, Owner: grafanaExploreSquad, AllowSelfServe: true, }, { Name: "exploreContentOutline", Description: "Content outline sidebar", Stage: FeatureStageGeneralAvailability, Owner: grafanaExploreSquad, Expression: "true", // enabled by default FrontendOnly: true, AllowSelfServe: true, }, { Name: "datasourceQueryMultiStatus", Description: "Introduce HTTP 207 Multi Status for api/ds/query", Stage: FeatureStageExperimental, Owner: grafanaPluginsPlatformSquad, }, { Name: "autoMigrateOldPanels", Description: "Migrate old angular panels to supported versions (graph, table-old, worldmap, etc)", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigrateGraphPanel", Description: "Migrate old graph panel to supported time series panel - broken out from autoMigrateOldPanels to enable granular tracking", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigrateTablePanel", Description: "Migrate old table panel to supported table panel - broken out from autoMigrateOldPanels to enable granular tracking", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigratePiechartPanel", Description: "Migrate old piechart panel to supported piechart panel - broken out from autoMigrateOldPanels to enable granular tracking", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigrateWorldmapPanel", Description: "Migrate old worldmap panel to supported geomap panel - broken out from autoMigrateOldPanels to enable granular tracking", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigrateStatPanel", Description: "Migrate old stat panel to supported stat panel - broken out from autoMigrateOldPanels to enable granular tracking", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "autoMigrateXYChartPanel", Description: "Migrate old XYChart panel to new XYChart2 model", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "disableAngular", Description: "Dynamic flag to disable angular at runtime. The preferred method is to set `angular_support_enabled` to `false` in the [security] settings, which allows you to change the state at runtime.", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, HideFromAdminPage: true, }, { Name: "canvasPanelNesting", Description: "Allow elements nesting", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDatavizSquad, HideFromAdminPage: true, }, { Name: "newVizTooltips", Description: "New visualizations tooltips UX", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, AllowSelfServe: false, }, { Name: "scenes", Description: "Experimental framework to build interactive dashboards", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "disableSecretsCompatibility", Description: "Disable duplicated secret storage in legacy tables", Stage: FeatureStageExperimental, RequiresRestart: true, Owner: hostedGrafanaTeam, }, { Name: "logRequestsInstrumentedAsUnknown", Description: "Logs the path for requests that are instrumented as unknown", Stage: FeatureStageExperimental, Owner: hostedGrafanaTeam, }, { // Some plugins rely on topnav feature flag being enabled, so we cannot remove this until we // can afford the breaking change, or we've detemined no one else is relying on it Name: "topnav", Description: "Enables topnav support in external plugins. The new Grafana navigation cannot be disabled.", Stage: FeatureStageDeprecated, Expression: "true", // enabled by default Owner: grafanaFrontendPlatformSquad, }, { Name: "returnToPrevious", Description: "Enables the return to previous context functionality", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaFrontendPlatformSquad, }, { Name: "grpcServer", Description: "Run the GRPC server", Stage: FeatureStagePublicPreview, Owner: grafanaAppPlatformSquad, HideFromAdminPage: true, }, { Name: "unifiedStorage", Description: "SQL-based k8s storage", Stage: FeatureStageExperimental, RequiresDevMode: true, RequiresRestart: true, // new SQL tables created Owner: grafanaAppPlatformSquad, }, { Name: "cloudWatchCrossAccountQuerying", Description: "Enables cross-account querying in CloudWatch datasources", Stage: FeatureStageGeneralAvailability, Expression: "true", // enabled by default Owner: awsDatasourcesSquad, AllowSelfServe: true, }, { Name: "showDashboardValidationWarnings", Description: "Show warnings when dashboards do not validate against the schema", Stage: FeatureStageExperimental, Owner: grafanaDashboardsSquad, }, { Name: "mysqlAnsiQuotes", Description: "Use double quotes to escape keyword in a MySQL query", Stage: FeatureStageExperimental, Owner: grafanaBackendPlatformSquad, }, { Name: "accessControlOnCall", Description: "Access control primitives for OnCall", Stage: FeatureStagePublicPreview, Owner: identityAccessTeam, HideFromAdminPage: true, }, { Name: "nestedFolders", Description: "Enable folder nesting", Stage: FeatureStageGeneralAvailability, Owner: grafanaBackendPlatformSquad, Expression: "true", // enabled by default }, { Name: "nestedFolderPicker", Description: "Enables the new folder picker to work with nested folders. Requires the nestedFolders feature toggle", Stage: FeatureStageGeneralAvailability, Owner: grafanaFrontendPlatformSquad, FrontendOnly: true, Expression: "true", // enabled by default AllowSelfServe: true, }, { Name: "alertingBacktesting", Description: "Rule backtesting API for alerting", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "editPanelCSVDragAndDrop", Description: "Enables drag and drop for CSV and Excel files", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaDatavizSquad, }, { Name: "alertingNoNormalState", Description: "Stop maintaining state of alerts that are not firing", Stage: FeatureStagePublicPreview, RequiresRestart: false, Owner: grafanaAlertingSquad, HideFromAdminPage: true, }, { Name: "logsContextDatasourceUi", Description: "Allow datasource to provide custom UI for context view", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaObservabilityLogsSquad, Expression: "true", // turned on by default AllowSelfServe: true, }, { Name: "lokiQuerySplitting", Description: "Split large interval queries into subqueries with smaller time intervals", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaObservabilityLogsSquad, Expression: "true", // turned on by default AllowSelfServe: true, }, { Name: "lokiQuerySplittingConfig", Description: "Give users the option to configure split durations for Loki queries", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityLogsSquad, }, { Name: "individualCookiePreferences", Description: "Support overriding cookie preferences per user", Stage: FeatureStageExperimental, Owner: grafanaBackendPlatformSquad, }, { Name: "prometheusMetricEncyclopedia", Description: "Adds the metrics explorer component to the Prometheus query builder as an option in metric select", Expression: "true", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaObservabilityMetricsSquad, AllowSelfServe: true, }, { Name: "influxdbBackendMigration", Description: "Query InfluxDB InfluxQL without the proxy", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaObservabilityMetricsSquad, Expression: "true", // enabled by default AllowSelfServe: false, }, { Name: "influxqlStreamingParser", Description: "Enable streaming JSON parser for InfluxDB datasource InfluxQL query language", Stage: FeatureStageExperimental, Owner: grafanaObservabilityMetricsSquad, }, { Name: "influxdbRunQueriesInParallel", Description: "Enables running InfluxDB Influxql queries in parallel", Stage: FeatureStagePrivatePreview, FrontendOnly: false, Owner: grafanaObservabilityMetricsSquad, }, { Name: "prometheusDataplane", Description: "Changes responses to from Prometheus to be compliant with the dataplane specification. In particular, when this feature toggle is active, the numeric `Field.Name` is set from 'Value' to the value of the `__name__` label.", Expression: "true", Stage: FeatureStageGeneralAvailability, Owner: grafanaObservabilityMetricsSquad, AllowSelfServe: true, }, { Name: "lokiMetricDataplane", Description: "Changes metric responses from Loki to be compliant with the dataplane specification.", Stage: FeatureStageGeneralAvailability, Expression: "true", Owner: grafanaObservabilityLogsSquad, AllowSelfServe: true, }, { Name: "lokiLogsDataplane", Description: "Changes logs responses from Loki to be compliant with the dataplane specification.", Stage: FeatureStageExperimental, Owner: grafanaObservabilityLogsSquad, }, { Name: "dataplaneFrontendFallback", Description: "Support dataplane contract field name change for transformations and field name matchers where the name is different", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Expression: "true", Owner: grafanaObservabilityMetricsSquad, AllowSelfServe: true, }, { Name: "disableSSEDataplane", Description: "Disables dataplane specific processing in server side expressions.", Stage: FeatureStageExperimental, Owner: grafanaObservabilityMetricsSquad, }, { Name: "alertStateHistoryLokiSecondary", Description: "Enable Grafana to write alert state history to an external Loki instance in addition to Grafana annotations.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "alertStateHistoryLokiPrimary", Description: "Enable a remote Loki instance as the primary source for state history reads.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "alertStateHistoryLokiOnly", Description: "Disable Grafana alerts from emitting annotations when a remote Loki instance is available.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "unifiedRequestLog", Description: "Writes error logs to the request logger", Stage: FeatureStageExperimental, Owner: grafanaBackendPlatformSquad, }, { Name: "renderAuthJWT", Description: "Uses JWT-based auth for rendering instead of relying on remote cache", Stage: FeatureStagePublicPreview, Owner: grafanaAsCodeSquad, HideFromAdminPage: true, }, { Name: "refactorVariablesTimeRange", Description: "Refactor time range variables flow to reduce number of API calls made when query variables are chained", Stage: FeatureStagePublicPreview, Owner: grafanaDashboardsSquad, HideFromAdminPage: true, // Non-feature, used to test out a bug fix that impacts the performance of template variables. }, { Name: "enableElasticsearchBackendQuerying", Description: "Enable the processing of queries and responses in the Elasticsearch data source through backend", Stage: FeatureStageGeneralAvailability, Owner: grafanaObservabilityLogsSquad, Expression: "true", // enabled by default AllowSelfServe: true, }, { Name: "faroDatasourceSelector", Description: "Enable the data source selector within the Frontend Apps section of the Frontend Observability", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: appO11ySquad, }, { Name: "enableDatagridEditing", Description: "Enables the edit functionality in the datagrid panel", FrontendOnly: true, Stage: FeatureStagePublicPreview, Owner: grafanaDatavizSquad, }, { Name: "extraThemes", Description: "Enables extra themes", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaFrontendPlatformSquad, }, { Name: "lokiPredefinedOperations", Description: "Adds predefined query operations to Loki query editor", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaObservabilityLogsSquad, }, { Name: "pluginsFrontendSandbox", Description: "Enables the plugins frontend sandbox", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaPluginsPlatformSquad, }, { Name: "dashboardEmbed", Description: "Allow embedding dashboard for external use in Code editors", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaAsCodeSquad, }, { Name: "frontendSandboxMonitorOnly", Description: "Enables monitor only in the plugin frontend sandbox (if enabled)", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaPluginsPlatformSquad, }, { Name: "sqlDatasourceDatabaseSelection", Description: "Enables previous SQL data source dataset dropdown behavior", FrontendOnly: true, Stage: FeatureStagePublicPreview, Owner: grafanaDatavizSquad, HideFromAdminPage: true, }, { Name: "lokiFormatQuery", Description: "Enables the ability to format Loki queries", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaObservabilityLogsSquad, }, { Name: "recordedQueriesMulti", Description: "Enables writing multiple items from a single query within Recorded Queries", Stage: FeatureStageGeneralAvailability, Expression: "true", Owner: grafanaObservabilityMetricsSquad, AllowSelfServe: false, }, { Name: "pluginsDynamicAngularDetectionPatterns", Description: "Enables fetching Angular detection patterns for plugins from GCOM and fallback to hardcoded ones", Stage: FeatureStageGeneralAvailability, FrontendOnly: false, Owner: grafanaPluginsPlatformSquad, Expression: "true", // enabled by default }, { Name: "vizAndWidgetSplit", Description: "Split panels between visualizations and widgets", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "prometheusIncrementalQueryInstrumentation", Description: "Adds RudderStack events to incremental queries", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaObservabilityMetricsSquad, }, { Name: "logsExploreTableVisualisation", Description: "A table visualisation for logs in Explore", Stage: FeatureStageGeneralAvailability, Expression: "true", // enabled by default, FrontendOnly: true, Owner: grafanaObservabilityLogsSquad, }, { Name: "awsDatasourcesTempCredentials", Description: "Support temporary security credentials in AWS plugins for Grafana Cloud customers", Stage: FeatureStageExperimental, Owner: awsDatasourcesSquad, }, { Name: "transformationsRedesign", Description: "Enables the transformations redesign", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Expression: "true", // enabled by default Owner: grafanaObservabilityMetricsSquad, AllowSelfServe: true, }, { Name: "mlExpressions", Description: "Enable support for Machine Learning in server-side expressions", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaAlertingSquad, }, { Name: "traceQLStreaming", Description: "Enables response streaming of TraceQL queries of the Tempo data source", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaObservabilityTracesAndProfilingSquad, }, { Name: "metricsSummary", Description: "Enables metrics summary queries in the Tempo data source", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityTracesAndProfilingSquad, }, { Name: "grafanaAPIServerWithExperimentalAPIs", Description: "Register experimental APIs with the k8s API server", Stage: FeatureStageExperimental, RequiresRestart: true, RequiresDevMode: true, Owner: grafanaAppPlatformSquad, }, { Name: "grafanaAPIServerEnsureKubectlAccess", Description: "Start an additional https handler and write kubectl options", Stage: FeatureStageExperimental, RequiresDevMode: true, RequiresRestart: true, Owner: grafanaAppPlatformSquad, }, { Name: "featureToggleAdminPage", Description: "Enable admin page for managing feature toggles from the Grafana front-end", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaOperatorExperienceSquad, RequiresRestart: true, }, { Name: "awsAsyncQueryCaching", Description: "Enable caching for async queries for Redshift and Athena. Requires that the datasource has caching and async query support enabled", Stage: FeatureStageGeneralAvailability, Expression: "true", // enabled by default Owner: awsDatasourcesSquad, }, { Name: "permissionsFilterRemoveSubquery", Description: "Alternative permission filter implementation that does not use subqueries for fetching the dashboard folder", Stage: FeatureStageExperimental, Owner: grafanaBackendPlatformSquad, }, { Name: "prometheusConfigOverhaulAuth", Description: "Update the Prometheus configuration page with the new auth component", Owner: grafanaObservabilityMetricsSquad, Stage: FeatureStageGeneralAvailability, Expression: "true", // on by default AllowSelfServe: false, }, { Name: "configurableSchedulerTick", Description: "Enable changing the scheduler base interval via configuration option unified_alerting.scheduler_tick_interval", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaAlertingSquad, RequiresRestart: true, HideFromDocs: true, }, { Name: "influxdbSqlSupport", Description: "Enable InfluxDB SQL query language support with new querying UI", Stage: FeatureStageGeneralAvailability, FrontendOnly: false, Owner: grafanaObservabilityMetricsSquad, RequiresRestart: true, AllowSelfServe: true, Expression: "true", // enabled by default }, { Name: "alertingNoDataErrorExecution", Description: "Changes how Alerting state manager handles execution of NoData/Error", Stage: FeatureStageGeneralAvailability, FrontendOnly: false, Owner: grafanaAlertingSquad, RequiresRestart: true, Expression: "true", // enabled by default }, { Name: "angularDeprecationUI", Description: "Display Angular warnings in dashboards and panels", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaPluginsPlatformSquad, Expression: "true", // Enabled by default }, { Name: "dashgpt", Description: "Enable AI powered features in dashboards", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaDashboardsSquad, Expression: "true", // enabled by default }, { Name: "aiGeneratedDashboardChanges", Description: "Enable AI powered features for dashboards to auto-summary changes when saving", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "reportingRetries", Description: "Enables rendering retries for the reporting feature", Stage: FeatureStagePublicPreview, FrontendOnly: false, Owner: grafanaSharingSquad, RequiresRestart: true, }, { Name: "sseGroupByDatasource", Description: "Send query to the same datasource in a single request when using server side expressions. The `cloudWatchBatchQueries` feature toggle should be enabled if this used with CloudWatch.", Stage: FeatureStageExperimental, Owner: grafanaObservabilityMetricsSquad, }, { Name: "libraryPanelRBAC", Description: "Enables RBAC support for library panels", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaDashboardsSquad, RequiresRestart: true, }, { Name: "lokiRunQueriesInParallel", Description: "Enables running Loki queries in parallel", Stage: FeatureStagePrivatePreview, FrontendOnly: false, Owner: grafanaObservabilityLogsSquad, }, { Name: "wargamesTesting", Description: "Placeholder feature flag for internal testing", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: hostedGrafanaTeam, }, { Name: "alertingInsights", Description: "Show the new alerting insights landing page", FrontendOnly: true, Stage: FeatureStageGeneralAvailability, Owner: grafanaAlertingSquad, Expression: "true", // enabled by default AllowSelfServe: false, HideFromAdminPage: true, // This is moving away from being a feature toggle. }, { Name: "externalCorePlugins", Description: "Allow core plugins to be loaded as external", Stage: FeatureStageExperimental, Owner: grafanaPluginsPlatformSquad, }, { Name: "pluginsAPIMetrics", Description: "Sends metrics of public grafana packages usage by plugins", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaPluginsPlatformSquad, }, { Name: "idForwarding", Description: "Generate signed id token for identity that can be forwarded to plugins and external services", Stage: FeatureStageExperimental, Owner: identityAccessTeam, }, { Name: "externalServiceAccounts", Description: "Automatic service account and token setup for plugins", HideFromAdminPage: true, Stage: FeatureStagePublicPreview, Owner: identityAccessTeam, }, { Name: "panelMonitoring", Description: "Enables panel monitoring through logs and measurements", Stage: FeatureStageGeneralAvailability, Expression: "true", // enabled by default Owner: grafanaDatavizSquad, FrontendOnly: true, }, { Name: "enableNativeHTTPHistogram", Description: "Enables native HTTP Histograms", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: hostedGrafanaTeam, }, { Name: "formatString", Description: "Enable format string transformer", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "transformationsVariableSupport", Description: "Allows using variables in transformations", FrontendOnly: true, Stage: FeatureStagePublicPreview, Owner: grafanaDatavizSquad, }, { Name: "kubernetesPlaylists", Description: "Use the kubernetes API in the frontend for playlists, and route /api/playlist requests to k8s", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, RequiresRestart: true, // changes the API routing }, { Name: "kubernetesSnapshots", Description: "Routes snapshot requests from /api to the /apis endpoint", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, RequiresRestart: true, // changes the API routing }, { Name: "kubernetesQueryServiceRewrite", Description: "Rewrite requests targeting /ds/query to the query service", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, RequiresRestart: true, // changes the API routing RequiresDevMode: true, }, { Name: "cloudWatchBatchQueries", Description: "Runs CloudWatch metrics queries as separate batches", Stage: FeatureStagePublicPreview, Owner: awsDatasourcesSquad, }, { Name: "recoveryThreshold", Description: "Enables feature recovery threshold (aka hysteresis) for threshold server-side expression", Stage: FeatureStageGeneralAvailability, FrontendOnly: false, Owner: grafanaAlertingSquad, RequiresRestart: true, Expression: "true", }, { Name: "lokiStructuredMetadata", Description: "Enables the loki data source to request structured metadata from the Loki server", Stage: FeatureStageGeneralAvailability, FrontendOnly: false, Owner: grafanaObservabilityLogsSquad, Expression: "true", }, { Name: "teamHttpHeaders", Description: "Enables Team LBAC for datasources to apply team headers to the client requests", Stage: FeatureStagePublicPreview, FrontendOnly: false, Owner: identityAccessTeam, }, { Name: "awsDatasourcesNewFormStyling", Description: "Applies new form styling for configuration and query editors in AWS plugins", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: awsDatasourcesSquad, }, { Name: "cachingOptimizeSerializationMemoryUsage", Description: "If enabled, the caching backend gradually serializes query responses for the cache, comparing against the configured `[caching]max_value_mb` value as it goes. This can can help prevent Grafana from running out of memory while attempting to cache very large query responses.", Stage: FeatureStageExperimental, Owner: grafanaOperatorExperienceSquad, FrontendOnly: false, }, { Name: "panelTitleSearchInV1", Description: "Enable searching for dashboards using panel title in search v1", RequiresDevMode: true, Stage: FeatureStageExperimental, Owner: grafanaBackendPlatformSquad, }, { Name: "managedPluginsInstall", Description: "Install managed plugins directly from plugins catalog", Stage: FeatureStageGeneralAvailability, RequiresDevMode: false, Owner: grafanaPluginsPlatformSquad, Expression: "true", // enabled by default }, { Name: "prometheusPromQAIL", Description: "Prometheus and AI/ML to assist users in creating a query", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityMetricsSquad, }, { Name: "addFieldFromCalculationStatFunctions", Description: "Add cumulative and window functions to the add field from calculation transformation", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "alertmanagerRemoteSecondary", Description: "Enable Grafana to sync configuration and state with a remote Alertmanager.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "alertmanagerRemotePrimary", Description: "Enable Grafana to have a remote Alertmanager instance as the primary Alertmanager.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "alertmanagerRemoteOnly", Description: "Disable the internal Alertmanager and only use the external one defined.", Stage: FeatureStageExperimental, Owner: grafanaAlertingSquad, }, { Name: "annotationPermissionUpdate", Description: "Change the way annotation permissions work by scoping them to folders and dashboards.", Stage: FeatureStageGeneralAvailability, RequiresDevMode: false, Expression: "true", // enabled by default Owner: identityAccessTeam, }, { Name: "extractFieldsNameDeduplication", Description: "Make sure extracted field names are unique in the dataframe", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "dashboardSceneForViewers", Description: "Enables dashboard rendering using Scenes for viewer roles", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "dashboardSceneSolo", Description: "Enables rendering dashboards using scenes for solo panels", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "dashboardScene", Description: "Enables dashboard rendering using scenes for all roles", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, }, { Name: "panelFilterVariable", Description: "Enables use of the `systemPanelFilterVar` variable to filter panels in a dashboard", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, HideFromDocs: true, }, { Name: "pdfTables", Description: "Enables generating table data as PDF in reporting", Stage: FeatureStagePublicPreview, FrontendOnly: false, Owner: grafanaSharingSquad, }, { Name: "ssoSettingsApi", Description: "Enables the SSO settings API and the OAuth configuration UIs in Grafana", Stage: FeatureStagePublicPreview, AllowSelfServe: true, FrontendOnly: false, Owner: identityAccessTeam, }, { Name: "canvasPanelPanZoom", Description: "Allow pan and zoom in canvas panel", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "logsInfiniteScrolling", Description: "Enables infinite scrolling for the Logs panel in Explore and Dashboards", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityLogsSquad, }, { Name: "flameGraphItemCollapsing", Description: "Allow collapsing of flame graph items", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityTracesAndProfilingSquad, }, { Name: "datatrails", Description: "Enables the new core app datatrails", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaDashboardsSquad, HideFromDocs: true, }, { Name: "alertingSimplifiedRouting", Description: "Enables users to easily configure alert notifications by specifying a contact point directly when editing or creating an alert rule", Stage: FeatureStagePublicPreview, FrontendOnly: false, Owner: grafanaAlertingSquad, }, { Name: "logRowsPopoverMenu", Description: "Enable filtering menu displayed when text of a log line is selected", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Expression: "true", Owner: grafanaObservabilityLogsSquad, }, { Name: "pluginsSkipHostEnvVars", Description: "Disables passing host environment variable to plugin processes", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaPluginsPlatformSquad, }, { Name: "tableSharedCrosshair", Description: "Enables shared crosshair in table panel", FrontendOnly: true, Stage: FeatureStageExperimental, Owner: grafanaDatavizSquad, }, { Name: "regressionTransformation", Description: "Enables regression analysis transformation", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { // this is mainly used a a way to quickly disable query hints as a safe guard for our infrastructure Name: "lokiQueryHints", Description: "Enables query hints for Loki", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Expression: "true", Owner: grafanaObservabilityLogsSquad, AllowSelfServe: false, }, { Name: "kubernetesFeatureToggles", Description: "Use the kubernetes API for feature toggle management in the frontend", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaOperatorExperienceSquad, AllowSelfServe: false, HideFromAdminPage: true, }, { Name: "enablePluginsTracingByDefault", Description: "Enable plugin tracing for all external plugins", FrontendOnly: false, Stage: FeatureStageGeneralAvailability, Owner: grafanaPluginsPlatformSquad, RequiresRestart: true, Expression: "true", // enabled by default }, { Name: "cloudRBACRoles", Description: "Enabled grafana cloud specific RBAC roles", Stage: FeatureStageExperimental, Owner: identityAccessTeam, HideFromDocs: true, RequiresRestart: true, }, { Name: "alertingQueryOptimization", Description: "Optimizes eligible queries in order to reduce load on datasources", Stage: FeatureStageGeneralAvailability, Owner: grafanaAlertingSquad, AllowSelfServe: false, }, { Name: "newFolderPicker", Description: "Enables the nested folder picker without having nested folders enabled", Stage: FeatureStageExperimental, Owner: grafanaFrontendPlatformSquad, FrontendOnly: true, }, { Name: "jitterAlertRulesWithinGroups", Description: "Distributes alert rule evaluations more evenly over time, including spreading out rules within the same group", FrontendOnly: false, Stage: FeatureStagePublicPreview, Owner: grafanaAlertingSquad, AllowSelfServe: false, HideFromDocs: true, HideFromAdminPage: false, RequiresRestart: true, }, { Name: "onPremToCloudMigrations", Description: "In-development feature that will allow users to easily migrate their on-prem Grafana instances to Grafana Cloud.", Stage: FeatureStageExperimental, Owner: grafanaOperatorExperienceSquad, }, { Name: "alertingSaveStatePeriodic", Description: "Writes the state periodically to the database, asynchronous to rule evaluation", Stage: FeatureStagePrivatePreview, FrontendOnly: false, Owner: grafanaAlertingSquad, }, { Name: "promQLScope", Description: "In-development feature that will allow injection of labels into prometheus queries.", Stage: FeatureStageExperimental, Owner: grafanaObservabilityMetricsSquad, }, { Name: "sqlExpressions", Description: "Enables using SQL and DuckDB functions as Expressions.", Stage: FeatureStageExperimental, FrontendOnly: false, Owner: grafanaAppPlatformSquad, }, { Name: "nodeGraphDotLayout", Description: "Changed the layout algorithm for the node graph", Stage: FeatureStageExperimental, FrontendOnly: true, Owner: grafanaObservabilityTracesAndProfilingSquad, }, { Name: "groupToNestedTableTransformation", Description: "Enables the group to nested table transformation", Stage: FeatureStagePublicPreview, FrontendOnly: true, Owner: grafanaDatavizSquad, }, { Name: "newPDFRendering", Description: "New implementation for the dashboard-to-PDF rendering", Stage: FeatureStagePublicPreview, Owner: grafanaSharingSquad, }, { Name: "kubernetesAggregator", Description: "Enable grafana aggregator", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, RequiresRestart: true, }, { Name: "expressionParser", Description: "Enable new expression parser", Stage: FeatureStageExperimental, Owner: grafanaAppPlatformSquad, RequiresRestart: true, }, { Name: "groupByVariable", Description: "Enable groupBy variable support in scenes dashboards", Stage: FeatureStageExperimental, Owner: grafanaDashboardsSquad, AllowSelfServe: false, HideFromDocs: true, HideFromAdminPage: true, }, { Name: "betterPageScrolling", Description: "Removes CustomScrollbar from the UI, relying on native browser scrollbars", Stage: FeatureStageGeneralAvailability, FrontendOnly: true, Owner: grafanaFrontendPlatformSquad, Expression: "true", // enabled by default }, { Name: "scopeFilters", Description: "Enables the use of scope filters in Grafana", FrontendOnly: false, Stage: FeatureStageExperimental, Owner: grafanaDashboardsSquad, RequiresRestart: false, AllowSelfServe: false, HideFromDocs: true, HideFromAdminPage: true, }, { Name: "ssoSettingsSAML", Description: "Use the new SSO Settings API to configure the SAML connector", Stage: FeatureStageExperimental, Owner: identityAccessTeam, HideFromDocs: true, HideFromAdminPage: true, }, } ) //go:embed toggles_gen.json var f embed.FS // Get the cached feature list (exposed as a k8s resource) func GetEmbeddedFeatureList() (featuretoggle.FeatureList, error) { features := featuretoggle.FeatureList{} body, err := f.ReadFile("toggles_gen.json") if err == nil { err = json.Unmarshal(body, &features) } return features, err }