This SDK is mostly analogous to the Rust SDK, except where necessary.
All functions of the Connector interface are analogous to their Rust counterparts.
The SDK fully supports NDC Specification v0.1.6 and Connector Deployment spec with following features:
- Connector HTTP server
- Authentication
- Observability with OpenTelemetry and Prometheus
- Go 1.21+
Downgrade to SDK v0.x If you are using Go v1.19+
Check out the generation tool to quickly setup and develop data connectors.
The SDK exports a Start
function, which takes a connector
object, that is an object that implements the Connector
interface defined in connector/types.go
This function should be your starting point.
A connector can thus start likes so:
import "github.com/hasura/ndc-sdk-go/connector"
type Configuration struct { ... }
type State struct { ... }
type Connector struct { ... }
/* implementation of the Connector interface removed for brevity */
func main() {
if err := connector.Start[Configuration, State](&Connector{}); err != nil {
panic(err)
}
}
The Start
function create a CLI application with following commands:
Commands:
serve
Serve the NDC connector.
Flags:
-h, --help Show context-sensitive help.
--log-level="info" Log level ($HASURA_LOG_LEVEL).
--service-name=STRING OpenTelemetry service name ($OTEL_SERVICE_NAME).
--otlp-endpoint=STRING OpenTelemetry receiver endpoint that is set as default for all types ($OTEL_EXPORTER_OTLP_ENDPOINT).
--otlp-traces-endpoint=STRING OpenTelemetry endpoint for traces ($OTEL_EXPORTER_OTLP_TRACES_ENDPOINT).
--otlp-metrics-endpoint=STRING OpenTelemetry endpoint for metrics ($OTEL_EXPORTER_OTLP_METRICS_ENDPOINT).
--otlp-logs-endpoint=STRING OpenTelemetry endpoint for logs ($OTEL_EXPORTER_OTLP_LOGS_ENDPOINT).
--otlp-insecure Disable LTS for OpenTelemetry exporters ($OTEL_EXPORTER_OTLP_INSECURE).
--otlp-traces-insecure Disable LTS for OpenTelemetry traces exporter ($OTEL_EXPORTER_OTLP_TRACES_INSECURE).
--otlp-metrics-insecure Disable LTS for OpenTelemetry metrics exporter ($OTEL_EXPORTER_OTLP_METRICS_INSECURE).
--otlp-logs-insecure Disable LTS for OpenTelemetry logs exporter ($OTEL_EXPORTER_OTLP_LOGS_INSECURE).
--otlp-protocol=STRING OpenTelemetry receiver protocol for all types ($OTEL_EXPORTER_OTLP_PROTOCOL).
--otlp-traces-protocol=STRING OpenTelemetry receiver protocol for traces ($OTEL_EXPORTER_OTLP_TRACES_PROTOCOL).
--otlp-metrics-protocol=STRING OpenTelemetry receiver protocol for metrics ($OTEL_EXPORTER_OTLP_METRICS_PROTOCOL).
--otlp-logs-protocol=STRING OpenTelemetry receiver protocol for logs ($OTEL_EXPORTER_OTLP_LOGS_PROTOCOL).
--otlp-compression="gzip" Enable compression for OTLP exporters. Accept: none, gzip ($OTEL_EXPORTER_OTLP_COMPRESSION)
--otlp-trace-compression="gzip" Enable compression for OTLP traces exporter. Accept: none, gzip ($OTEL_EXPORTER_OTLP_TRACES_COMPRESSION)
--otlp-metrics-compression="gzip" Enable compression for OTLP metrics exporter. Accept: none, gzip ($OTEL_EXPORTER_OTLP_METRICS_COMPRESSION)
--otlp-logs-compression="gzip" Enable compression for OTLP logs exporter. Accept: none, gzip ($OTEL_EXPORTER_OTLP_LOGS_COMPRESSION)
--metrics-exporter="none" Metrics export type. Accept: none, otlp, prometheus ($OTEL_METRICS_EXPORTER)
--logs-exporter="none" Logs export type. Accept: none, otlp ($OTEL_LOGS_EXPORTER)
--prometheus-port=PROMETHEUS-PORT Prometheus port for the Prometheus HTTP server. Use /metrics endpoint of the connector server if empty
($OTEL_EXPORTER_PROMETHEUS_PORT)
--disable-go-metrics Disable internal Go and process metrics
--server-read-timeout=DURATION Maximum duration for reading the entire request, including the body. A zero or negative value means there will be no timeout
($HASURA_SERVER_READ_TIMEOUT)
--server-read-header-timeout=DURATION Amount of time allowed to read request headers. If zero, the value of ReadTimeout is used ($HASURA_SERVER_READ_HEADER_TIMEOUT)
--server-write-timeout=DURATION Maximum duration before timing out writes of the response. A zero or negative value means there will be no timeout
($HASURA_SERVER_WRITE_TIMEOUT)
--server-idle-timeout=DURATION Maximum amount of time to wait for the next request when keep-alives are enabled. If zero, the value of ReadTimeout is used
($HASURA_SERVER_IDLE_TIMEOUT)
--server-max-header-kilobytes=1024 Maximum number of kilobytes the server will read parsing the request header's keys and values, including the request line
($HASURA_SERVER_MAX_HEADER_KILOBYTES)
--server-tls-cert-file=STRING Path of the TLS certificate file ($HASURA_SERVER_TLS_CERT_FILE)
--server-tls-key-file=STRING Path of the TLS key file ($HASURA_SERVER_TLS_KEY_FILE)
--configuration=STRING Configuration directory ($HASURA_CONFIGURATION_DIRECTORY)
--port=8080 Serve Port ($HASURA_CONNECTOR_PORT)
--service-token-secret=STRING Service token secret ($HASURA_SERVICE_TOKEN_SECRET)
Please refer to the NDC Spec for details on implementing the Connector interface, or see examples.
OpenTelemetry exporter is disabled by default unless one of --otlp-endpoint
, --otlp-traces-endpoint
or --otlp-metrics-endpoint
argument is set. By default, the SDK treats port 4318
as HTTP protocol and gRPC protocol for others.
If --otlp-*insecure
flags are not set, the SDK can also detect TLS connections via http(s).
Other configurations are inherited from the OpenTelemetry Go SDK. Currently the SDK supports traces
and metrics
. See Environment Variable Specification and OTLP Exporter Configuration.
The SDK supports OTLP and Prometheus metrics exporters that is enabled by --metrics-exporter
(OTEL_METRICS_EXPORTER
) flag. Supported values:
none
(default): disable the exporterotlp
: OTLP exporterprometheus
: Prometheus exporter via the/metrics
endpoint.
Prometheus exporter is served in the same HTTP server with the connector. If you want to run it on another port, configure the --prometheus-port
(OTEL_EXPORTER_PROMETHEUS_PORT
) flag.
Name | Type | Description |
---|---|---|
(<prefix>)_query_total | Counter | Total number of query requests |
(<prefix>)_query_total_time | Histogram | Total time taken to plan and execute a query |
(<prefix>)_query_explain_total | Counter | Total number of explain query requests |
(<prefix>)_query_explain_total_time | Histogram | Total time taken to plan and execute an explain query request, in seconds |
(<prefix>)_mutation_total | Counter | Total number of mutation requests |
(<prefix>)_query_mutation_total_time | Histogram | Total time taken to plan and execute a mutation request, in seconds |
(<prefix>)_mutation_explain_total | Counter | Total number of explain mutation requests |
(<prefix>)_query_mutation_explain_total_time | Histogram | Total time taken to plan and execute an explain mutation request, in seconds |
The prefix is empty by default. You can set the prefix for your connector by WithMetricsPrefix
option.
NDC Go SDK uses the standard log/slog that provides highly customizable and structured logging. By default, the logger is printed in JSON format and configurable level with --log-level
(HASURA_LOG_LEVEL) flag. You also can replace it with different logging libraries that can wrap the slog.Handler
interface, and set the logger with the WithLogger
or WithLoggerFunc
option.
The SDK uses Kong, a lightweight command-line parser to implement the CLI interface.
The default CLI already implements the serve
command, so you don't need to do anything. However, it's also easy to extend if you want to add more custom commands.
The SDK abstracts an interface for the CLI that requires embedding the base ServeCLI
command and can execute other commands.
type ConnectorCLI interface {
GetServeCLI() *ServeCLI
Execute(ctx context.Context, command string) error
}
And use the StartCustom
function to start the CLI.
See the custom CLI example in the reference connector.
The NDC spec types are borrowed from ndc-sdk-typescript that are generated from the NDC Spec Rust types.
Then the Go types are generated from that JSON Schema document into ./schema/schema.generated.go
.
In order to regenerate the types, download the json schema and run:
> cd typegen && ./regenerate-schema.sh