Secrets/Config
Configuration
Configuration values are named, typed values. They are managed by the ftl config
command-line.
To declare a configuration value use the following syntax:
// Simple string configuration
type ApiUrl = ftl.Config[string]
// Type-safe configuration
type DefaultUser = ftl.Config[Username]
Note that the name of the configuration value as represented in the FTL schema is the lower camel case version of the type name (e.g., ApiUrl
becomes apiUrl
).
Configuration values can be injected into FTL methods, such as //ftl:verb, HTTP ingress, Cron etc. To inject a configuration value, use the following syntax:
//ftl:verb
func Hello(ctx context.Context, req Request, defaultUser DefaultUser) error {
username := defaultUser.Get(ctx)
// ...
}
Configuration values can be injected into FTL methods, such as @Verb
, HTTP ingress, Cron etc. To inject a configuration value, use the following syntax:
@Export
@Verb
fun hello(helloRequest: HelloRequest, @Config("defaultUser") defaultUser: String): HelloResponse {
return HelloResponse("Hello, $defaultUser")
}
Configuration values can be injected into FTL methods, such as @Verb
, HTTP ingress, Cron etc. To inject a configuration value, use the following syntax:
@Export
@Verb
HelloResponse hello(HelloRequest helloRequest, @Config("defaultUser") String defaultUser) {
return new HelloResponse("Hello, " + defaultUser);
}
Secrets
Secrets are encrypted, named, typed values. They are managed by the ftl secret
command-line.
Declare a secret with the following:
// Simple string secret
type ApiToken = ftl.Secret[string]
// Type-safe secret
type ApiKey = ftl.Secret[Credentials]
Like configuration values, the name of the secret as represented in the FTL schema is the lower camel case version of the type name (e.g., ApiToken
becomes apiToken
).
Secrets can be injected into FTL methods, such as //ftl:verb, HTTP ingress, Cron etc. To inject a secret value, use the following syntax:
//ftl:verb
func CallApi(ctx context.Context, req Request, apiKey ApiKey) error {
credentials := apiKey.Get(ctx)
// ...
}
Secrets can be injected into FTL methods, such as @Verb
, HTTP ingress, Cron etc. To inject a secret value, use the following syntax:
@Export
@Verb
fun hello(helloRequest: HelloRequest, @Secret("apiKey") apiKey: String): HelloResponse {
return HelloResponse("Hello, ${api.call(apiKey)}")
}
Secrets can be injected into FTL methods, such as @Verb
, HTTP ingress, Cron etc. To inject a secret value, use the following syntax:
@Export
@Verb
HelloResponse hello(HelloRequest helloRequest, @Secret("apiKey") String apiKey) {
return new HelloResponse("Hello, " + api.call(apiKey));
}
Transforming secrets/configuration
Often, raw secret/configuration values aren't directly useful. For example, raw credentials might be used to create an API client. For those situations ftl.Map()
can be used to transform a configuration or secret value into another type:
var client = ftl.Map(ftl.Secret[Credentials]("credentials"),
func(ctx context.Context, creds Credentials) (*api.Client, error) {
return api.NewClient(creds)
})
This is not currently supported in Kotlin or Java.