Skip to content

TempoQueryBuilder🔗

Constructor🔗

func NewTempoQueryBuilder() *TempoQueryBuilder

Methods🔗

Build🔗

Builds the object.

func (builder *TempoQueryBuilder) Build() (variants.Dataquery, error)

Datasource🔗

For mixed data sources the selected datasource is on the query level.

For non mixed scenarios this is undefined.

TODO find a better way to do this ^ that's friendly to schema

TODO this shouldn't be unknown but DataSourceRef | null

func (builder *TempoQueryBuilder) Datasource(datasource dashboard.DataSourceRef) *TempoQueryBuilder

Exemplars🔗

For metric queries, how many exemplars to request, 0 means no exemplars

func (builder *TempoQueryBuilder) Exemplars(exemplars int64) *TempoQueryBuilder

Filters🔗

func (builder *TempoQueryBuilder) Filters(filters []cog.Builder[tempo.TraceqlFilter]) *TempoQueryBuilder

GroupBy🔗

Filters that are used to query the metrics summary

func (builder *TempoQueryBuilder) GroupBy(groupBy []cog.Builder[tempo.TraceqlFilter]) *TempoQueryBuilder

Hide🔗

If hide is set to true, Grafana will filter out the response(s) associated with this query before returning it to the panel.

func (builder *TempoQueryBuilder) Hide(hide bool) *TempoQueryBuilder

Limit🔗

Defines the maximum number of traces that are returned from Tempo

func (builder *TempoQueryBuilder) Limit(limit int64) *TempoQueryBuilder

MaxDuration🔗

@deprecated Define the maximum duration to select traces. Use duration format, for example: 1.2s, 100ms

func (builder *TempoQueryBuilder) MaxDuration(maxDuration string) *TempoQueryBuilder

MinDuration🔗

@deprecated Define the minimum duration to select traces. Use duration format, for example: 1.2s, 100ms

func (builder *TempoQueryBuilder) MinDuration(minDuration string) *TempoQueryBuilder

Query🔗

TraceQL query or trace ID

func (builder *TempoQueryBuilder) Query(query string) *TempoQueryBuilder

QueryType🔗

Specify the query flavor

TODO make this required and give it a default

func (builder *TempoQueryBuilder) QueryType(queryType string) *TempoQueryBuilder

RefId🔗

A unique identifier for the query within the list of targets.

In server side expressions, the refId is used as a variable name to identify results.

By default, the UI will assign A->Z; however setting meaningful names may be useful.

func (builder *TempoQueryBuilder) RefId(refId string) *TempoQueryBuilder

@deprecated Logfmt query to filter traces by their tags. Example: http.status_code=200 error=true

func (builder *TempoQueryBuilder) Search(search string) *TempoQueryBuilder

ServiceMapIncludeNamespace🔗

Use service.namespace in addition to service.name to uniquely identify a service.

func (builder *TempoQueryBuilder) ServiceMapIncludeNamespace(serviceMapIncludeNamespace bool) *TempoQueryBuilder

ServiceMapQuery🔗

Filters to be included in a PromQL query to select data for the service graph. Example: {client="app",service="app"}. Providing multiple values will produce union of results for each filter, using PromQL OR operator internally.

func (builder *TempoQueryBuilder) ServiceMapQuery(serviceMapQuery tempo.StringOrArrayOfString) *TempoQueryBuilder

ServiceName🔗

@deprecated Query traces by service name

func (builder *TempoQueryBuilder) ServiceName(serviceName string) *TempoQueryBuilder

SpanName🔗

@deprecated Query traces by span name

func (builder *TempoQueryBuilder) SpanName(spanName string) *TempoQueryBuilder

Spss🔗

Defines the maximum number of spans per spanset that are returned from Tempo

func (builder *TempoQueryBuilder) Spss(spss int64) *TempoQueryBuilder

Step🔗

For metric queries, the step size to use

func (builder *TempoQueryBuilder) Step(step string) *TempoQueryBuilder

TableType🔗

The type of the table that is used to display the search results

func (builder *TempoQueryBuilder) TableType(tableType tempo.SearchTableType) *TempoQueryBuilder

See also🔗