🔧 Configuration
Overview
In this page, you will find all the configuration options available for the relay-proxy.
The GO Feature Flag relay-proxy is highly configurable and can be adapted to your needs. Despite that you can start with a minimum configuration and fine tune it later.
Configuration file
The configuration of the relay proxy is based on a configuration file that you have to provide.
This is a yaml
file and usage is to call it goff-proxy.yaml
but you can name it as you will.
You can provide the configuration file with the option --config=/path_to_your_file.yaml
when launching the relay proxy.
go-feature-flag --config=/goff-proxy.yaml
By default, if you omit the --config
option, the relay proxy will look for a configuration file named goff-proxy.yaml
in (int this order):
./
(the current directory)/goff/
/etc/opt/goff/
Getting Started
The minimum configuration to start the relay proxy is to provide where to retrieve your feature flags configuration.
retrievers:
- kind: file
path: /goff/flags.yaml # Location of your feature flag files
All the other options are optional and can be added to the configuration file to fine-tune the relay proxy.
Environment variables
The primary way to configure the relay proxy is through a configuration file, but you can also use environment variables if you prefer.
You can override file configurations using environment variables.
Here are some things to know when you are using environment variables:
- To set an option, the environment variable should have the same name as the configuration option in uppercase.
For example, to set thelisten
option, you can set theLISTEN
environment variable.export LISTEN=8080
- If you want to set a nested field, you can use
_
to separate each field.
For example, to set theretrievers
option, you can set theRETRIEVERS
environment variable.export RETRIEVER_KIND=github
- If you want to set an array of string, you can add multiple values separated by a comma.
export AUTHORIZEDKEYS_EVALUATION=my-first-key,my-second-key
- If you are modifying an array of objects, you can use the index to set the value.
export RETRIEVERS_0_KIND=github
Configuration Options
retrievers
This is the configuration on how to retrieve the configuration of the files.
- option name:
retrievers
- type:
[]retriever
- default: none
- mandatory:
- You can have multiple retrievers at the same time, check "Using multiple retrievers" to see how it works.
- Configuration of a retriever depends on the one you are choosing. Check the list of retrievers and go on the detail page of your choice to configure it.
retrievers:
- kind: file
path: /goff/my-flags.yaml
- kind: s3
bucket: my-featureflag-bucket
item: flag/flags.goff.yaml
startWithRetrieverError
By default, the relay proxy will crash if it is not able to retrieve the flags from the configuration.
If you don't want your relay proxy to crash, you can set startWithRetrieverError
to true. Until the flag is retrievable the relay proxy will only answer with default values.
- option name:
startWithRetrieverError
- type: boolean
- default:
false
- mandatory:
persistentFlagConfigurationFile
If set, GO Feature Flag will store the flags configuration in this file to be able to serve the flags even if none of the retrievers is available during starting time.
By default, the flag configuration is not persisted and stays on the retriever system. By setting a file here, you ensure that GO Feature Flag will always start with a configuration but which can be out-dated.
- option name:
persistentFlagConfigurationFile
- type: string
- default: none
- mandatory:
- example:
/tmp/goff_persist_conf.yaml
fileFormat
This is the format of your flag configuration file.
- option name:
fileFormat
- type: string
- Acceptable values are :
yaml
,json
,toml
. - default:
yaml
- mandatory:
pollingInterval
This is the time interval in millisecond when the relay proxy is reloading the configuration file.
- option name:
pollingInterval
- type: int
- default:
60000
- The minimum time accepted is 1000 millisecond (1 second).
- mandatory:
enablePollingJitter
Set to true if you want to avoid having true periodicity when retrieving your flags. It is useful to avoid having spike on your flag configuration storage in case your application is starting multiple instance at the same time.
We ensure a deviation that is maximum ±10% of your polling interval.
- option name:
enablePollingJitter
- type: boolean
- default:
false
- mandatory:
listen
This is the port used by the relay proxy when starting the HTTP server.
- option name:
listen
- type: int
- default:
1031
- mandatory:
monitoringPort
If set the monitoring endpoints will be served on this specific port.
Check "Use specific port for the monitoring" to have more information.
- option name:
monitoringPort
- type: int
- default: none
- mandatory:
logLevel
The log level to use for the relay proxy.
Check "Logging" to have more information.
- option name:
logLevel
- type: string
- default:
INFO
- Acceptable values are
ERROR
,WARN
,INFO
,DEBUG
. - mandatory:
logFormat
The format to use for structured logs from the relay proxy.
Check "Logging" to have more information.
- option name:
logFormat
- type: string
- default:
json
- Acceptable values are
json
andlogfmt
. - mandatory:
enablePprof
This param is used to enable pprof endpoints if you wish to enable profiling.
Check "Profiling" to have more information.
- option name:
enablePprof
- type: boolean
- default:
false
- mandatory:
exporter
Exporter is the configuration used to export data.
- option name:
exporter
- type: exporter
- default: none
- mandatory:
- Configuration of an exporter depends on the one you are choosing. Check the list of exporters and go on the detail page of your choice to configure it.
notifier
Notifiers is the configuration on where to notify a flag changes.
- option name:
notifier
- type: notifier
- default: none
- mandatory:
- Configuration of a notifier depends on the one you are choosing. Check the list of notifiers and go on the detail page of your choice to configure it.
disableNotifierOnInit
If disableNotifierOnInit
is set to true, the relay proxy will not call any notifier when the flags are loaded for the 1st time (during initialization). This is useful if you do not want a Slack/Webhook notification saying that the flags have been added every time you start the proxy.
- option name:
disableNotifierOnInit
- type: boolean
- default:
false
- mandatory:
startAsAwsLambda
Allow to start the relay-proxy as a AWS Lambda, it means that it will start the server to receive request in the AWS format (see awsLambdaAdapter
to set the request/response format you are using).
Notifiers is the configuration on where to notify a flag changes.
- option name:
startAsAwsLambda
- type: boolean
- default:
false
- mandatory:
awsLambdaAdapter
This parameter allow you to decide which type of AWS lambda handler you want to use.
- option name:
awsLambdaAdapter
- type: string
- default:
APIGatewayV2
- Acceptable values are
APIGatewayV2
,APIGatewayV1
,ALB
. - mandatory:
- This param is used only if
startAsAwsLambda
istrue
.
debug
If debug
is set to true, we will set the log level to debug and set some components in debug mode (labstack/echo
, pprof
etc ...).
- option name:
debug
- type: boolean
- default:
false
- mandatory:
hideBanner
hideBanner
can be used to hide the startup banner.
- option name:
hideBanner
- type: boolean
- default:
false
- mandatory:
enableSwagger
Enables Swagger for testing the APIs directly. If you are enabling Swagger you will have to provide the host
configuration.
- option name:
enableSwagger
- type: boolean
- default:
false
- mandatory:
- The Swagger UI will be available at
http://<host>:<listen>/swagger/
.
host
host
is the DNS you will use to access the relay proxy.
- option name:
host
- type: string
- default:
localhost
- mandatory:
- This field is used by Swagger to query the API at the right place.
authorizedKeys
List of authorized API keys.
If you don't set any API keys, the relay proxy will be fully open to all requests
- option name:
authorizedKeys
- type: authorizedKeys
- default: none
- mandatory:
evaluationContextEnrichment
It is a free field that will be merged with the evaluation context sent during the evaluation.
It is useful to add common attributes to all the evaluations, such as a server version, environment, etc. These fields will be included in the custom attributes of the evaluation context.
If in the evaluation context you have a field with the same name, it will be overridden by the evaluationContextEnrichment
.
- option name:
evaluationContextEnrichment
- type: object
- default: none
- mandatory:
openTelemetryOtlpEndpoint
Endpoint of your OpenTelemetry OTLP collector, used to send traces.
You will be able to forward those traces to your OpenTelemetry solution directly from the collector.
- option name:
openTelemetryOtlpEndpoint
- type: string
- default: none
- mandatory:
Configuration Types
type authorizedKeys
authorizedKeys
is an object were it is possible to configure the list of API Keys that are accepted by the relay proxy.
authorizedKeys.evaluation
If set, we will check for each evaluation if an authorized key is provided.
Each request will need to provide one of authorized key inside Authorization
header with format Bearer <api-key>
.
- option name:
evaluation
- type: []string
- default: none
- mandatory:
authorizedKeys.admin
You need to set API keys in this field if you want to access the /v1/admin/*
endpoints.
Each request will need to provide one of authorized key inside Authorization
header with format Bearer <api-key>
.
- option name:
evaluation
- type: []string
- default: none
- mandatory:
- If no api key is configured the endpoint will be unreachable.
Example
# ...
authorizedKeys:
evaluation:
- "my-first-key"
- "my-second-key"
admin:
- "my-first-admin-key"
- "my-second-admin-key"
type retriever
A retriever is the component in charge of loading your flag configuration from a remote source.
retriever.kind
Configuring a retriever always start by setting the kind of retriever you want to use. This is the only common param between all the retrievers.
- option name:
kind
- type: string
- default: none
- mandatory:
To find the kind
to use for your retriever and the rest of the options, check the list of retrievers and go on the detail page of your choice to configure it.
Available retrievers:
type exporter
An exporter is the component in charge of sending your evaluation data to a remote source.
# ...
exporter:
kind: s3
bucket: evaluation-data-bucket
Every exporter
has its own configuration, check the list of exporters and go on the detail page of your choice to configure it.
Available exporters:
type notifier
A notifier is the component in charge of sending a notification when a flag changes to a remote system.
# ...
notifier:
- kind: discord
webhookUrl: "https://discord.com/api/webhooks/yyyy/xxxxxxx"
- kind: slack
webhookUrl: "https://hooks.slack.com/services/T00000000/B00000000/XXXXXXXXXXXXXXXXXXXXXXXX"
# ...
Every notifier
has its own configuration, check the list of notifiers and go on the detail page of your choice to configure it.
Available notifiers: