mirror of
https://github.com/SigNoz/signoz.git
synced 2025-12-17 15:36:48 +00:00
* chore: update types 1. add partial bool to indicate if the value covers the partial interval 2. add optional unit if present (ex: duration_nano, metrics with units) 3. use pointers wherever necessary 4. add format options for request and remove redundant name in query envelope * chore: fix some gaps 1. make the range as [start, end) 2. provide the logs statement builder with the body column 3. skip the body filter on resource filter statement builder 4. remove unnecessary agg expr rewriter in metrics 5. add ability to skip full text in where clause visitor * chore: add API endpoint for new query range * chore: add bucket cache implementation * chore: add fingerprinting impl and add bucket cache to querier * chore: add provider factory
125 lines
3.3 KiB
Go
125 lines
3.3 KiB
Go
package fields
|
|
|
|
import (
|
|
"bytes"
|
|
"io"
|
|
"net/http"
|
|
|
|
"github.com/SigNoz/signoz/pkg/factory"
|
|
"github.com/SigNoz/signoz/pkg/http/render"
|
|
"github.com/SigNoz/signoz/pkg/telemetrylogs"
|
|
"github.com/SigNoz/signoz/pkg/telemetrymetadata"
|
|
"github.com/SigNoz/signoz/pkg/telemetrymetrics"
|
|
"github.com/SigNoz/signoz/pkg/telemetrystore"
|
|
"github.com/SigNoz/signoz/pkg/telemetrytraces"
|
|
"github.com/SigNoz/signoz/pkg/types/telemetrytypes"
|
|
)
|
|
|
|
type API struct {
|
|
telemetryStore telemetrystore.TelemetryStore
|
|
telemetryMetadataStore telemetrytypes.MetadataStore
|
|
}
|
|
|
|
// TODO: move this to module and remove metastore init
|
|
func NewAPI(
|
|
settings factory.ProviderSettings,
|
|
telemetryStore telemetrystore.TelemetryStore,
|
|
) *API {
|
|
telemetryMetadataStore := telemetrymetadata.NewTelemetryMetaStore(
|
|
settings,
|
|
telemetryStore,
|
|
telemetrytraces.DBName,
|
|
telemetrytraces.TagAttributesV2TableName,
|
|
telemetrytraces.SpanIndexV3TableName,
|
|
telemetrymetrics.DBName,
|
|
telemetrymetrics.AttributesMetadataTableName,
|
|
telemetrylogs.DBName,
|
|
telemetrylogs.LogsV2TableName,
|
|
telemetrylogs.TagAttributesV2TableName,
|
|
telemetrymetadata.DBName,
|
|
telemetrymetadata.AttributesMetadataLocalTableName,
|
|
)
|
|
|
|
return &API{
|
|
telemetryStore: telemetryStore,
|
|
telemetryMetadataStore: telemetryMetadataStore,
|
|
}
|
|
}
|
|
|
|
func (api *API) GetFieldsKeys(w http.ResponseWriter, r *http.Request) {
|
|
|
|
type fieldKeysResponse struct {
|
|
Keys map[string][]*telemetrytypes.TelemetryFieldKey `json:"keys"`
|
|
Complete bool `json:"complete"`
|
|
}
|
|
|
|
bodyBytes, _ := io.ReadAll(r.Body)
|
|
r.Body = io.NopCloser(bytes.NewBuffer(bodyBytes))
|
|
ctx := r.Context()
|
|
|
|
fieldKeySelector, err := parseFieldKeyRequest(r)
|
|
if err != nil {
|
|
render.Error(w, err)
|
|
return
|
|
}
|
|
|
|
keys, err := api.telemetryMetadataStore.GetKeys(ctx, fieldKeySelector)
|
|
if err != nil {
|
|
render.Error(w, err)
|
|
return
|
|
}
|
|
|
|
response := fieldKeysResponse{
|
|
Keys: keys,
|
|
Complete: len(keys) < fieldKeySelector.Limit,
|
|
}
|
|
|
|
render.Success(w, http.StatusOK, response)
|
|
}
|
|
|
|
func (api *API) GetFieldsValues(w http.ResponseWriter, r *http.Request) {
|
|
|
|
type fieldValuesResponse struct {
|
|
Values *telemetrytypes.TelemetryFieldValues `json:"values"`
|
|
Complete bool `json:"complete"`
|
|
}
|
|
|
|
bodyBytes, _ := io.ReadAll(r.Body)
|
|
r.Body = io.NopCloser(bytes.NewBuffer(bodyBytes))
|
|
ctx := r.Context()
|
|
|
|
fieldValueSelector, err := parseFieldValueRequest(r)
|
|
if err != nil {
|
|
render.Error(w, err)
|
|
return
|
|
}
|
|
|
|
allValues, err := api.telemetryMetadataStore.GetAllValues(ctx, fieldValueSelector)
|
|
if err != nil {
|
|
render.Error(w, err)
|
|
return
|
|
}
|
|
|
|
relatedValues, err := api.telemetryMetadataStore.GetRelatedValues(ctx, fieldValueSelector)
|
|
if err != nil {
|
|
// we don't want to return error if we fail to get related values for some reason
|
|
relatedValues = []string{}
|
|
}
|
|
|
|
values := &telemetrytypes.TelemetryFieldValues{
|
|
StringValues: allValues.StringValues,
|
|
NumberValues: allValues.NumberValues,
|
|
RelatedValues: relatedValues,
|
|
}
|
|
|
|
response := fieldValuesResponse{
|
|
Values: values,
|
|
Complete: len(values.StringValues) < fieldValueSelector.Limit &&
|
|
len(values.BoolValues) < fieldValueSelector.Limit &&
|
|
len(values.NumberValues) < fieldValueSelector.Limit &&
|
|
len(values.RelatedValues) < fieldValueSelector.Limit,
|
|
}
|
|
|
|
render.Success(w, http.StatusOK, response)
|
|
}
|