Documentation ¶
Overview ¶
Package gqlgen contains an implementation of a gqlgen tracer, and functions to construct and configure the tracer. The tracer can be passed to the gqlgen handler (see package github.com/99designs/gqlgen/handler)
Warning: Data obfuscation hasn't been implemented for graphql queries yet, any sensitive data in the query will be sent to Datadog as the resource name of the span. To ensure no sensitive data is included in your spans, always use parameterized graphql queries with sensitive data in variables.
Example ¶
package main import ( "log" "net/http" "github.com/99designs/gqlgen/graphql/handler/testserver" gqlgentrace "github.com/DataDog/dd-trace-go/contrib/99designs/gqlgen/v2" "github.com/DataDog/dd-trace-go/v2/ddtrace/tracer" ) func main() { tracer.Start() defer tracer.Stop() t := gqlgentrace.NewTracer( gqlgentrace.WithAnalytics(true), gqlgentrace.WithService("todo.server"), ) h := testserver.New() // replace with your own actual server h.Use(t) http.Handle("/query", h) log.Fatal(http.ListenAndServe(":8080", nil)) }
Output:
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewTracer ¶
func NewTracer(opts ...Option) graphql.HandlerExtension
NewTracer creates a graphql.HandlerExtension instance that can be used with a graphql.handler.Server. Options can be passed in for further configuration.
Types ¶
type Option ¶
type Option interface {
// contains filtered or unexported methods
}
An Option describes options for the gqlgen integration.
type OptionFn ¶
type OptionFn func(*config)
OptionFn represents an option that can be passed to gqlgen tracer.
func WithAnalytics ¶
WithAnalytics enables or disables Trace Analytics for all started spans.
func WithAnalyticsRate ¶
WithAnalyticsRate sets the sampling rate for Trace Analytics events correlated to started spans.
func WithCustomTag ¶
WithCustomTag will attach the value to the span tagged by the key.
func WithService ¶
WithService sets the given service name for the gqlgen server.
func WithoutTraceIntrospectionQuery ¶
func WithoutTraceIntrospectionQuery() OptionFn
WithoutTraceIntrospectionQuery skips creating spans for fields when the operation name is IntrospectionQuery.
func WithoutTraceTrivialResolvedFields ¶
func WithoutTraceTrivialResolvedFields() OptionFn
WithoutTraceTrivialResolvedFields skips creating spans for fields that have a trivial resolver. For example, a field resolved from an object w/o requiring a custom method is considered trivial.