graphql-protect
can be configured in various ways, though we recommend configuring it via a protect.yml
. file
The best way to configure graphql-protect
is by specifying a protect.yml
in the same directory as you're running the binary.
The following outlines the structure of the yaml, as well as outlines the defaults for each configuration option.
web:
# Maximum duration to read the entire request
read_timeout: 5s
# Maximum duration before timing out writes of the response
write_timeout: 10s
# Maximum time to wait between idle requests for keep alive
idle_timeout: 120s
# Time to wait until forcibly shutting down protect, after receiving a shutdown signal
shutdown_timeout: 20s
# host and port to listen on
host: 0.0.0.0:8080
# path that receives GraphQL traffic
path: /graphql
# limit the maximum size of a request body that is allowed
# this helps prevent OOM attacks through excessively large request payloads.
# A limit of `0` disables this protection.
request_body_max_bytes: 102400
target:
# Target host and port to send traffic to after validating
host: http://localhost:8081
# Dial timeout waiting for a connection to complete with the target upstream
timeout: 10s
# Interval of keep alive probes
keep_alive: 180s
tracing:
# Headers to redact when sending tracing information
redacted_headers: []
schema:
# Path to a local file in which the schema can be found
path: "./schema.graphql"
# Automatically reload the schema file.
# It will reload the contents of the file referenced by the `schema.path` configuration option
# after each `schema.auto_reload.interval` has passed.
auto_reload:
# Enable automatic file reloading
enabled: true
# The interval in which the schema file should be reloaded
interval: 5m
# Configures whether we obfuscate graphql-protect validation errors such as max_aliases/max_tokens
# Recommended to set it to 'true' for public environments
obfuscate_validation_errors: false
# Configures if upstream errors need to be obfuscated, this can help you hide internals of your upstream landscape
obfuscate_upstream_errors: true
persisted_operations:
# Enable or disable the feature, disabled by default
enabled: false
# configures a '/internal/debug_trusted_documents' endpoint to print the persisted operations as json
# Make sure you DONT expose this endpoint publicly if you enable this feature!
enable_debug_endpoint: false
# Fail unknown operations, disable this feature to allow unknown operations to reach your GraphQL API
reject_on_failure: true
# Loader decides how persisted operations are loaded, see loader chapter for more details
loader:
# Type of loader to use
type: local
# Location to load persisted operations from
location: ./store
# Whether to reload persisted operations periodically
reload:
enabled: true
# The interval in which the persisted operations are refreshed
interval: 5m0s
# The timeout for the refreshing operation
timeout: 10s
block_field_suggestions:
enabled: true
mask: "[redacted]"
max_aliases:
# Enable the feature
enabled: true
# The maximum number of allowed aliases within a single request.
max: 15
# Reject the request when the rule fails. Disable this to allow the request
reject_on_failure: true
max_depth:
# protects against operations being too deep
field:
enabled: true
# The maximum allowed depth within a single request.
max: 15
# Reject the request when the rule fails. Disable this to allow the request
reject_on_failure: true
# protects against lists being nested too many times
list:
enabled: true
# The maximum allowed depth within a single request.
max: 15
# Reject the request when the rule fails. Disable this to allow the request
reject_on_failure: true
max_tokens:
# Enable the feature
enabled: true
# The maximum number of allowed tokens within a single request.
max: 10000
# Reject the request when the rule fails. Disable this to allow the request regardless of token count.
reject_on_failure: true
max_batch:
# Enable the feature
enabled: true
# The maximum number of operations within a single batched request.
max: 5
# Reject the request when the rule fails. Disable this to allow the request regardless of token count.
reject_on_failure: true
enforce_post:
# Enable enforcing POST http method
enabled: true
# Enable or disable logging of graphql errors
log_graphql_errors: false
log:
# text, or json for structured logging
format: text
For a more in-depth view of each option visit the accompanying documentation page of each individual protection.
While the validate run mode works with the same config as the normal mode, for simplicity's sake you can leave out quite some unused options. As an example checkout the config below:
schema:
# Path to a local file in which the schema can be found
path: "./schema.graphql"
persisted_operations:
enabled: true
# Store is the location on local disk where graphql-protect can find the persisted operations, it loads any `*.json` files on disk
loader:
# Type of loader to use
type: local
# Location to load persisted operations from
location: ./store
max_aliases:
# Enable the feature
enabled: true
# The maximum number of allowed aliases within a single request.
max: 15
block_field_suggestions:
enabled: true
mask: "[redacted]"
max_depth:
enabled: true
# The maximum allowed depth within a single request.
max: 15
max_tokens:
# Enable the feature
enabled: true
# The maximum number of allowed tokens within a single request.
max: 10000
max_batch:
# Enable the feature
enabled: true
# The maximum number of operations within a single batched request.
max: 5