sourcegraph/internal/opencodegraph/amplitude_provider.go
Quinn Slack c9439d9456
OpenCodeGraph prototype (#58675)
This adds support for the OpenCodeGraph prototype. Feature-flagged off by default behind the `opencodegraph` feature flag. See https://www.loom.com/share/5549d92a7c244863ac86ce56692ca030 for more information.

Also, for our CodeMirror, remove `background:transparent` so that line bg applies to block widgets
2023-12-06 21:39:33 -08:00

58 lines
1.6 KiB
Go

package opencodegraph
import (
"context"
"fmt"
"github.com/grafana/regexp"
"github.com/sourcegraph/sourcegraph/schema"
)
func init() {
RegisterProvider(amplitudeProvider{})
}
type amplitudeProvider struct{}
func (amplitudeProvider) Name() string { return "amplitude" }
func (amplitudeProvider) Capabilities(ctx context.Context, params schema.CapabilitiesParams) (*schema.CapabilitiesResult, error) {
return &schema.CapabilitiesResult{
Selector: []*schema.Selector{
{Path: "**/*.ts?(x)", ContentContains: "eventLogger.log"},
},
}, nil
}
func (amplitudeProvider) Annotations(ctx context.Context, params schema.AnnotationsParams) (*schema.AnnotationsResult, error) {
var result schema.AnnotationsResult
events, ranges := telemetryCalls(params.Content)
for i, ev := range events {
id := fmt.Sprintf("%s:%d", ev, i)
item := &schema.OpenCodeGraphItem{
Id: id,
Title: "📊 Analytics: " + ev,
Url: "https://example.com/#not-yet-implemented",
Preview: true,
PreviewUrl: "https://example.com/#not-yet-implemented",
}
result.Items = append(result.Items, item)
result.Annotations = append(result.Annotations, &schema.OpenCodeGraphAnnotation{
Item: schema.OpenCodeGraphItemRef{Id: id},
Range: ranges[i],
})
}
return &result, nil
}
const anyQuote = "\"'`"
var logViewEventCall = regexp.MustCompile(`eventLogger.log(?:ViewEvent)?\([` + anyQuote + `]([^` + anyQuote + `]+)[` + anyQuote + `]`)
func telemetryCalls(content string) (events []string, ranges []schema.OpenCodeGraphRange) {
return firstSubmatchNamesAndRanges(logViewEventCall, content)
}